mirror of
https://github.com/NixOS/nixpkgs.git
synced 2026-03-08 01:24:09 +01:00
this creates some eval errors that will be fixed in the next commit
done with the following script:
```fish
\#!/usr/bin/env fish
set packagesjson (nix eval --impure --json --expr '
let
lib = import ./lib;
in
import pkgs/servers/x11/xorg/default.nix (lib.mapAttrs (
name: _:
if name == "lib" then
lib
else if name == "config" then
{ allowAliases = false; }
else
name
) (__functionArgs (import pkgs/servers/x11/xorg/default.nix))) { }
' | jq)
set one (grep '^ [A-Za-z0-9_-]*$' pkgs/servers/x11/xorg/default.nix | string trim | string replace -r '$' Z | sort | string sub -e -1)
set two (grep '^ [A-Za-z0-9_-]* = [A-Za-z0-9_-]*;$' pkgs/servers/x11/xorg/default.nix | cut -d= -f1 | string trim | string replace -r '$' Z | sort | string sub -e -1)
for arg in $one $two
set oname $arg
set nname (echo $packagesjson | jq -r .$oname)
if test $nname = null
echo (set_color red)warn:(set_color normal) unknown package xorg.$oname >&2
continue
end
echo $oname "->" $nname
# replace basic xorg.$name references
for file in (rg -F "xorg.$oname" --files-with-matches pkgs)
# special cases
sd -F "$oname = xorg.$oname;" "$nname = $nname;" $file
# replace
sd -F "xorg.$oname" "$nname" $file
# fixup function arguments
# prevent duplicate function args
if grep -E " ($oname|$nname),\$" $file >/dev/null
continue
end
if grep 'xorg\..' $file >/dev/null # case1: there is more so we can't just remove the function arg
if grep ' xorg,$' $file >/dev/null
sd ' xorg,$' " xorg,
$nname," $file
else if grep ' xorg ? .*,$' $file >/dev/null
sd 'xorg( ? .*),$' "xorg\$1,
$nname," $file
else
sd -F 'xorg,' "$nname,
xorg," $file
end
else # case there is no more xorg..* so we can just replace the function arg
sd 'xorg(| ? .*),.*$' "$nname," $file
end
end
end
nix fmt
```
205 lines
5.1 KiB
Nix
205 lines
5.1 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
fetchgit,
|
|
fetchzip,
|
|
runCommand,
|
|
lndir,
|
|
nim,
|
|
nimOverrides,
|
|
}:
|
|
|
|
let
|
|
fetchers = {
|
|
fetchzip =
|
|
{ url, sha256, ... }:
|
|
fetchzip {
|
|
name = "source";
|
|
inherit url sha256;
|
|
};
|
|
fetchgit =
|
|
{
|
|
fetchSubmodules ? false,
|
|
leaveDotGit ? false,
|
|
rev,
|
|
sha256,
|
|
url,
|
|
...
|
|
}:
|
|
fetchgit {
|
|
inherit
|
|
fetchSubmodules
|
|
leaveDotGit
|
|
rev
|
|
sha256
|
|
url
|
|
;
|
|
};
|
|
};
|
|
|
|
filterPropertiesToAttrs =
|
|
prefix: properties:
|
|
lib.pipe properties [
|
|
(builtins.filter ({ name, ... }: (lib.strings.hasPrefix prefix name)))
|
|
(map (
|
|
{ name, value }:
|
|
{
|
|
name = lib.strings.removePrefix prefix name;
|
|
inherit value;
|
|
}
|
|
))
|
|
builtins.listToAttrs
|
|
];
|
|
|
|
buildNimCfg =
|
|
{ backend, components, ... }:
|
|
let
|
|
componentSrcDirs = map (
|
|
{ properties, ... }:
|
|
let
|
|
fodProps = filterPropertiesToAttrs "nix:fod:" properties;
|
|
fod = fetchers.${fodProps.method} fodProps;
|
|
srcDir = fodProps.srcDir or "";
|
|
in
|
|
if srcDir == "" then fod else "${fod}/${srcDir}"
|
|
) components;
|
|
in
|
|
runCommand "nim.cfg"
|
|
{
|
|
outputs = [
|
|
"out"
|
|
"src"
|
|
];
|
|
nativeBuildInputs = [ lndir ];
|
|
}
|
|
''
|
|
cat << EOF >> $out
|
|
backend:${backend}
|
|
path:"$src"
|
|
EOF
|
|
mkdir -p "$src"
|
|
${lib.strings.concatMapStrings (d: ''
|
|
lndir "${d}" "$src"
|
|
'') componentSrcDirs}
|
|
'';
|
|
|
|
buildCommands = lib.attrsets.mapAttrsToList (
|
|
output: input: ''
|
|
nim compile $nimFlags --out:${output} ${input}
|
|
''
|
|
);
|
|
|
|
installCommands = lib.attrsets.mapAttrsToList (
|
|
output: input: ''
|
|
install -Dt $out/bin ${output}
|
|
''
|
|
);
|
|
|
|
applySbom =
|
|
sbom:
|
|
{
|
|
nimFlags ? [ ],
|
|
nimRelease ? true,
|
|
passthru ? { },
|
|
...
|
|
}@prevAttrs:
|
|
let
|
|
properties = # SBOM metadata.component.properties as an attrset.
|
|
lib.attrsets.recursiveUpdate (builtins.listToAttrs sbom.metadata.component.properties)
|
|
passthru.properties or { };
|
|
|
|
nimBin = # A mapping of Nim module file paths to names of programs.
|
|
lib.attrsets.recursiveUpdate (lib.pipe properties [
|
|
(lib.attrsets.filterAttrs (name: value: lib.strings.hasPrefix "nim:bin:" name))
|
|
(lib.attrsets.mapAttrs' (
|
|
name: value: {
|
|
name = lib.strings.removePrefix "nim:bin:" name;
|
|
value = "${properties."nim:binDir" or (properties."nim:srcDir" or ".")}/${value}";
|
|
}
|
|
))
|
|
]) passthru.nimBin or { };
|
|
in
|
|
{
|
|
strictDeps = true;
|
|
|
|
pname = prevAttrs.pname or sbom.metadata.component.name;
|
|
version = prevAttrs.version or sbom.metadata.component.version or null;
|
|
|
|
nimFlags =
|
|
nimFlags
|
|
++ (lib.optional nimRelease "-d:release")
|
|
++ (
|
|
let
|
|
srcDir = properties."nim:srcDir" or "";
|
|
in
|
|
lib.optional (srcDir != "") "--path:${srcDir}"
|
|
);
|
|
|
|
configurePhase =
|
|
prevAttrs.configurePhase or ''
|
|
runHook preConfigure
|
|
echo "nim.cfg << $nimCfg"
|
|
cat $nimCfg >> nim.cfg
|
|
cat << EOF >> nim.cfg
|
|
nimcache:"$NIX_BUILD_TOP/nimcache"
|
|
parallelBuild:$NIX_BUILD_CORES
|
|
EOF
|
|
runHook postConfigure
|
|
'';
|
|
|
|
buildPhase =
|
|
prevAttrs.buildPhase or ''
|
|
runHook preBuild
|
|
${lib.strings.concatLines (buildCommands nimBin)}
|
|
runHook postBuild
|
|
'';
|
|
|
|
installPhase =
|
|
prevAttrs.installPhase or ''
|
|
runHook preInstall
|
|
${lib.strings.concatLines (installCommands nimBin)}
|
|
runHook postInstall
|
|
'';
|
|
|
|
nativeBuildInputs = (prevAttrs.nativeBuildInputs or [ ]) ++ [ nim ];
|
|
|
|
nimCfg =
|
|
prevAttrs.nimCfg or (buildNimCfg {
|
|
backend = prevAttrs.nimBackend or properties."nim:backend" or "c";
|
|
inherit (sbom) components;
|
|
});
|
|
|
|
passthru = passthru // {
|
|
inherit sbom properties nimBin;
|
|
};
|
|
};
|
|
|
|
applyOverrides =
|
|
prevAttrs:
|
|
builtins.foldl' (
|
|
prevAttrs:
|
|
{ name, ... }@component:
|
|
if (builtins.hasAttr name nimOverrides) then
|
|
let
|
|
result = nimOverrides.${name} component prevAttrs;
|
|
in
|
|
prevAttrs // (if builtins.isAttrs result then result else result { })
|
|
else
|
|
prevAttrs
|
|
) prevAttrs prevAttrs.passthru.sbom.components;
|
|
|
|
compose =
|
|
callerArg: sbom: finalAttrs:
|
|
let
|
|
callerAttrs = if builtins.isAttrs callerArg then callerArg else callerArg finalAttrs;
|
|
sbomAttrs = callerAttrs // (applySbom sbom callerAttrs);
|
|
overrideAttrs = sbomAttrs // (applyOverrides sbomAttrs);
|
|
in
|
|
overrideAttrs;
|
|
in
|
|
callerArg: sbomArg:
|
|
let
|
|
sbom = if builtins.isAttrs sbomArg then sbomArg else builtins.fromJSON (builtins.readFile sbomArg);
|
|
overrideSbom = f: stdenv.mkDerivation (compose callerArg (sbom // (f sbom)));
|
|
in
|
|
(stdenv.mkDerivation (compose callerArg sbom)) // { inherit overrideSbom; }
|