Compare commits
10 commits
0a63667459
...
9315751220
Author | SHA1 | Date | |
---|---|---|---|
Jake Hamilton | 9315751220 | ||
Jake Hamilton | b414e151e6 | ||
Jake Hamilton | af571a03a4 | ||
Jake Hamilton | e76e67fe58 | ||
Jake Hamilton | 7385b21950 | ||
Jake Hamilton | bd51f4a088 | ||
Jake Hamilton | 0e03546da5 | ||
Jake Hamilton | 1f7ab7d09c | ||
Jake Hamilton | aa0fd6128b | ||
Jake Hamilton | 2be3111b2c |
|
@ -3,10 +3,10 @@
|
||||||
"lib": {
|
"lib": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "lib",
|
"dir": "lib",
|
||||||
"dirtyRev": "9850da8aa9dc9be22e237c9b424a18e801e53ecb-dirty",
|
"dirtyRev": "2be3111b2c0911f40b47fe0a1fb22b5f5188cf59-dirty",
|
||||||
"dirtyShortRev": "9850da8-dirty",
|
"dirtyShortRev": "2be3111-dirty",
|
||||||
"lastModified": 1718529861,
|
"lastModified": 1719251485,
|
||||||
"narHash": "sha256-tv/0C7ixH+9Ij+r+5nua48OlXXXnbdEsnenxX4eG/Sk=",
|
"narHash": "sha256-63NvfFVeTDITfNu60rmCUlaZtAeZUnvrIaOLSk9ScC8=",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "file:../?dir=lib"
|
"url": "file:../?dir=lib"
|
||||||
},
|
},
|
||||||
|
|
|
@ -43,7 +43,7 @@ lib: {
|
||||||
resolve =
|
resolve =
|
||||||
definition:
|
definition:
|
||||||
let
|
let
|
||||||
properties = builtins.addErrorContext "while evaluating definitions from `${definition.__file__}`:" (
|
properties = builtins.addErrorContext "while evaluating definitions from `${definition.__file__ or "<unknown>"}`:" (
|
||||||
lib.modules.apply.properties definition.value
|
lib.modules.apply.properties definition.value
|
||||||
);
|
);
|
||||||
normalize = value: {
|
normalize = value: {
|
||||||
|
|
|
@ -1100,6 +1100,43 @@ lib: {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
## Create a type that allows a value which is either the final type or is transformable
|
||||||
|
## to the final type.
|
||||||
|
##
|
||||||
|
## @type Attrs -> (Any -> Any) -> Attrs -> Attrs
|
||||||
|
coerceWithLocation =
|
||||||
|
initial: transform: final:
|
||||||
|
let
|
||||||
|
in
|
||||||
|
if initial.getSubModules != null then
|
||||||
|
builtins.throw "lib.types.coerceWithLocation's first argument may not have submodules, but got ${initial.description}"
|
||||||
|
else
|
||||||
|
lib.types.create {
|
||||||
|
name = "Coerce";
|
||||||
|
description = "${initial.description} that is transformed to ${final.description}";
|
||||||
|
fallback = final.fallback;
|
||||||
|
check = value: final.check value || (initial.check value && final.check (transform [ ] value));
|
||||||
|
merge =
|
||||||
|
location: definitions:
|
||||||
|
let
|
||||||
|
process = value: if initial.check value then transform location value else value;
|
||||||
|
normalize = definition: definition // { value = process definition.value; };
|
||||||
|
normalized = builtins.map normalize definitions;
|
||||||
|
in
|
||||||
|
final.merge location normalized;
|
||||||
|
getSubOptions = final.getSubOptions;
|
||||||
|
getSubModules = final.getSubModules;
|
||||||
|
withSubModules =
|
||||||
|
modules: lib.types.coerceWithLocation initial transform (final.withSubModules modules);
|
||||||
|
mergeType = x: y: null;
|
||||||
|
functor = lib.types.functor "coerceWithLocation" // {
|
||||||
|
wrapped = final;
|
||||||
|
};
|
||||||
|
children = {
|
||||||
|
inherit initial final;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
dag = {
|
dag = {
|
||||||
## Create a type that allows a DAG (Directed Acyclic Graph) of a given type.
|
## Create a type that allows a DAG (Directed Acyclic Graph) of a given type.
|
||||||
##
|
##
|
||||||
|
|
|
@ -8,10 +8,10 @@
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "foundation",
|
"dir": "foundation",
|
||||||
"dirtyRev": "9850da8aa9dc9be22e237c9b424a18e801e53ecb-dirty",
|
"dirtyRev": "2be3111b2c0911f40b47fe0a1fb22b5f5188cf59-dirty",
|
||||||
"dirtyShortRev": "9850da8-dirty",
|
"dirtyShortRev": "2be3111-dirty",
|
||||||
"lastModified": 1718529861,
|
"lastModified": 1719251485,
|
||||||
"narHash": "sha256-X1Wd6mDz8GTaoxt1ylkvZfrJOcZtspJrEjXMtJ2ZyG0=",
|
"narHash": "sha256-9G1TPBdlQNXCZf6A66bCT9m2vhodkSF+rDtqOVuFteY=",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "file:../?dir=foundation"
|
"url": "file:../?dir=foundation"
|
||||||
},
|
},
|
||||||
|
@ -24,10 +24,10 @@
|
||||||
"lib": {
|
"lib": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "lib",
|
"dir": "lib",
|
||||||
"dirtyRev": "9850da8aa9dc9be22e237c9b424a18e801e53ecb-dirty",
|
"dirtyRev": "2be3111b2c0911f40b47fe0a1fb22b5f5188cf59-dirty",
|
||||||
"dirtyShortRev": "9850da8-dirty",
|
"dirtyShortRev": "2be3111-dirty",
|
||||||
"lastModified": 1718529861,
|
"lastModified": 1719251485,
|
||||||
"narHash": "sha256-X1Wd6mDz8GTaoxt1ylkvZfrJOcZtspJrEjXMtJ2ZyG0=",
|
"narHash": "sha256-9G1TPBdlQNXCZf6A66bCT9m2vhodkSF+rDtqOVuFteY=",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "file:../?dir=lib"
|
"url": "file:../?dir=lib"
|
||||||
},
|
},
|
||||||
|
|
|
@ -14,7 +14,17 @@ in
|
||||||
build =
|
build =
|
||||||
package:
|
package:
|
||||||
let
|
let
|
||||||
phases = package.phases;
|
phases = lib.dag.apply.defaults package.phases {
|
||||||
|
unpack = lib.dag.entry.before [ "patch" ] "";
|
||||||
|
|
||||||
|
patch = lib.dag.entry.between [ "configure" ] [ "unpack" ] "";
|
||||||
|
|
||||||
|
configure = lib.dag.entry.between [ "build" ] [ "patch" ] "";
|
||||||
|
|
||||||
|
build = lib.dag.entry.between [ "install" ] [ "configure" ] "";
|
||||||
|
|
||||||
|
install = lib.dag.entry.after [ "build" ] "";
|
||||||
|
};
|
||||||
sorted = lib.dag.sort.topographic phases;
|
sorted = lib.dag.sort.topographic phases;
|
||||||
|
|
||||||
script = lib.strings.concatMapSep "\n" (
|
script = lib.strings.concatMapSep "\n" (
|
||||||
|
@ -70,7 +80,13 @@ in
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
in
|
in
|
||||||
built // { inherit (package) meta; };
|
built
|
||||||
|
// {
|
||||||
|
inherit (package) meta;
|
||||||
|
extras = {
|
||||||
|
inherit package;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,20 @@
|
||||||
# This file handles creating all of the exports for this project and is not
|
# This file handles creating all of the exports for this project and is not
|
||||||
# exported itself.
|
# exported itself.
|
||||||
{ lib, config }:
|
{ config }:
|
||||||
let
|
let
|
||||||
lib' = config.lib;
|
inherit (config) lib;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
freeform = lib.types.any;
|
# freeform = lib.types.any;
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
exports = {
|
exports = {
|
||||||
lib = config.lib;
|
inherit lib;
|
||||||
modules = import ./modules.nix;
|
modules = import ./modules.nix;
|
||||||
|
|
||||||
packages = {
|
packages = {
|
||||||
|
aux-a = config.packages.aux.a;
|
||||||
|
|
||||||
# foundation-gcc-x86_64 =
|
# foundation-gcc-x86_64 =
|
||||||
# (config.packages.foundation.gcc.versions."13.2.0".extend (args: {
|
# (config.packages.foundation.gcc.versions."13.2.0".extend (args: {
|
||||||
# config = {
|
# config = {
|
||||||
|
@ -24,11 +26,13 @@ in
|
||||||
# .config;
|
# .config;
|
||||||
foundation-gcc = config.packages.foundation.gcc;
|
foundation-gcc = config.packages.foundation.gcc;
|
||||||
foundation-binutils = config.packages.foundation.binutils;
|
foundation-binutils = config.packages.foundation.binutils;
|
||||||
foundation-linux-headers = config.packages.foundation.linux-headers.versions.latest.extend {
|
foundation-linux-headers = config.packages.foundation.linux-headers;
|
||||||
platform.host = lib.modules.overrides.force "x86_64-linux";
|
# foundation-linux-headers = config.packages.foundation.linux-headers.versions.latest.extend {
|
||||||
};
|
# platform.host = lib.modules.overrides.force "x86_64-linux";
|
||||||
|
# };
|
||||||
# example-x = config.packages.example.x;
|
# example-x = config.packages.example.x;
|
||||||
# cross-example-x-x86_64-linux = config.packages.cross.x86_64-linux.example.x;
|
cross-aux-a-x86_64-linux = config.packages.cross.x86_64-linux.aux.a;
|
||||||
|
cross-foundation-gcc-x86_64-linux = config.packages.cross.x86_64-linux.foundation.gcc;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ in
|
||||||
config = {
|
config = {
|
||||||
lib.options = {
|
lib.options = {
|
||||||
package = lib.options.create {
|
package = lib.options.create {
|
||||||
type = config.lib.types.package;
|
type = config.lib.types.package.base;
|
||||||
description = "A package definition.";
|
description = "A package definition.";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
{
|
{ lib, config }:
|
||||||
lib,
|
let
|
||||||
lib',
|
lib' = config.lib;
|
||||||
config,
|
in
|
||||||
}:
|
|
||||||
{
|
{
|
||||||
config = {
|
config = {
|
||||||
lib.packages = {
|
lib.packages = {
|
||||||
|
@ -15,6 +14,10 @@
|
||||||
);
|
);
|
||||||
in
|
in
|
||||||
builtins.map (dependency: dependency.package) available;
|
builtins.map (dependency: dependency.package) available;
|
||||||
|
|
||||||
|
build =
|
||||||
|
build': host': target':
|
||||||
|
builtins.mapAttrs (name: dep: lib'.packages.build dep build' host' target');
|
||||||
};
|
};
|
||||||
|
|
||||||
getLatest =
|
getLatest =
|
||||||
|
@ -25,54 +28,89 @@
|
||||||
in
|
in
|
||||||
builtins.head sorted;
|
builtins.head sorted;
|
||||||
|
|
||||||
|
resolve =
|
||||||
|
alias:
|
||||||
|
if alias ? versions then
|
||||||
|
alias.versions.${config.preferences.packages.version}
|
||||||
|
or (alias.versions.${lib'.packages.getLatest alias})
|
||||||
|
else
|
||||||
|
alias;
|
||||||
|
|
||||||
build =
|
build =
|
||||||
package: build: host: target:
|
alias: build: host: target:
|
||||||
let
|
let
|
||||||
resolved =
|
package = lib'.packages.resolve alias;
|
||||||
if package ? versions then
|
|
||||||
package.versions.${config.preferences.packages.version}
|
|
||||||
or (package.versions.${lib'.packages.getLatest package})
|
|
||||||
else
|
|
||||||
package;
|
|
||||||
|
|
||||||
buildDependencies =
|
buildDependencies =
|
||||||
build': host': target':
|
build': host': target':
|
||||||
builtins.mapAttrs (name: dep: lib'.packages.build dep build' host' target');
|
builtins.mapAttrs (name: dep: lib'.packages.build dep build' host' target');
|
||||||
|
|
||||||
result = resolved.extend (
|
platform = {
|
||||||
{ config }:
|
build = lib.modules.overrides.force build;
|
||||||
{
|
host = lib.modules.overrides.force host;
|
||||||
config = {
|
target = lib.modules.overrides.force target;
|
||||||
platform = {
|
};
|
||||||
build = build;
|
|
||||||
host = host;
|
|
||||||
target = lib.modules.override 150 target;
|
|
||||||
};
|
|
||||||
|
|
||||||
deps = {
|
withPlatform = lib.modules.run {
|
||||||
build = {
|
modules = package.__modules__ ++ [
|
||||||
only = buildDependencies build build build resolved.deps.build.only;
|
lib'.types.package.children.submodule
|
||||||
build = buildDependencies build build target resolved.deps.build.build;
|
(
|
||||||
host = buildDependencies build host target resolved.deps.build.host;
|
{ config }:
|
||||||
target = buildDependencies build target target resolved.deps.build.target;
|
{
|
||||||
};
|
config = {
|
||||||
host = {
|
__modules__ = package.__modules__;
|
||||||
only = buildDependencies host host host resolved.deps.host.only;
|
|
||||||
host = buildDependencies host host target resolved.deps.host.host;
|
|
||||||
target = buildDependencies host target target resolved.deps.host.target;
|
|
||||||
};
|
|
||||||
target = {
|
|
||||||
only = buildDependencies target target target resolved.deps.target.only;
|
|
||||||
target = buildDependencies target target target resolved.deps.target.target;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
package = config.builder.build config;
|
inherit platform;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
# Not all platform information can be effectively handled via submodules. To handle
|
||||||
|
# the case where a user copies the resolved config over we need to ensure that
|
||||||
|
# dependencies are appropriately updated.
|
||||||
|
withDeps = withPlatform.config // {
|
||||||
|
deps = {
|
||||||
|
build = {
|
||||||
|
only = buildDependencies build build build withPlatform.config.deps.build.only;
|
||||||
|
build = buildDependencies build build target withPlatform.config.deps.build.build;
|
||||||
|
host = buildDependencies build host target withPlatform.config.deps.build.host;
|
||||||
|
target = buildDependencies build target target withPlatform.config.deps.build.target;
|
||||||
};
|
};
|
||||||
}
|
host = {
|
||||||
);
|
only = buildDependencies host host host withPlatform.config.deps.host.only;
|
||||||
|
host = buildDependencies host host target withPlatform.config.deps.host.host;
|
||||||
|
target = buildDependencies host target target withPlatform.config.deps.host.target;
|
||||||
|
};
|
||||||
|
target = {
|
||||||
|
only = buildDependencies target target target withPlatform.config.deps.target.only;
|
||||||
|
target = buildDependencies target target target withPlatform.config.deps.target.target;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
withPackage = lib.modules.run {
|
||||||
|
modules = package.__modules__ ++ [
|
||||||
|
lib'.types.package.children.submodule
|
||||||
|
(
|
||||||
|
{ config }:
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
__modules__ = package.__modules__;
|
||||||
|
|
||||||
|
inherit platform;
|
||||||
|
|
||||||
|
deps = lib.modules.overrides.force withDeps.deps;
|
||||||
|
|
||||||
|
package = lib.modules.overrides.force (withDeps.builder.build withDeps);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
];
|
||||||
|
};
|
||||||
in
|
in
|
||||||
result;
|
withPackage.config;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1220,6 +1220,7 @@ in
|
||||||
vendor,
|
vendor,
|
||||||
kernel,
|
kernel,
|
||||||
abi,
|
abi,
|
||||||
|
...
|
||||||
}:
|
}:
|
||||||
types.cpu.check cpu
|
types.cpu.check cpu
|
||||||
&& types.vendor.check vendor
|
&& types.vendor.check vendor
|
||||||
|
@ -1227,6 +1228,17 @@ in
|
||||||
&& types.abi.check abi;
|
&& types.abi.check abi;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
platformWithBuildInfo = lib.types.create {
|
||||||
|
name = "systemWithBuildInfo";
|
||||||
|
description = "fully parsed representation of llvm- or nix-style platform tuple with build information";
|
||||||
|
merge = lib.options.merge.one;
|
||||||
|
check =
|
||||||
|
value:
|
||||||
|
lib.types.is "systemWithBuildInfo" value
|
||||||
|
&& value ? system
|
||||||
|
&& lib'.systems.types.platform.check value.system;
|
||||||
|
};
|
||||||
|
|
||||||
endian = lib.types.enum (builtins.attrValues types.endians);
|
endian = lib.types.enum (builtins.attrValues types.endians);
|
||||||
|
|
||||||
endians = setTypes types.generic.endian {
|
endians = setTypes types.generic.endian {
|
||||||
|
@ -2792,7 +2804,7 @@ in
|
||||||
assert resolved.useAndroidPrebuilt -> resolved.isAndroid;
|
assert resolved.useAndroidPrebuilt -> resolved.isAndroid;
|
||||||
assert assertions;
|
assert assertions;
|
||||||
# And finally, return the generated system info.
|
# And finally, return the generated system info.
|
||||||
resolved;
|
lib.types.set "systemWithBuildInfo" resolved;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
{
|
{ lib, config }:
|
||||||
lib,
|
let
|
||||||
lib',
|
inherit (config) preferences builders;
|
||||||
config,
|
|
||||||
}:
|
lib' = config.lib;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
config = {
|
config = {
|
||||||
lib.types = {
|
lib.types = {
|
||||||
|
@ -55,6 +56,10 @@
|
||||||
in
|
in
|
||||||
lib.types.either type (lib.types.list.of type);
|
lib.types.either type (lib.types.list.of type);
|
||||||
|
|
||||||
|
platform =
|
||||||
|
lib.types.coerce lib.types.string lib'.systems.withBuildInfo
|
||||||
|
lib'.systems.types.platformWithBuildInfo;
|
||||||
|
|
||||||
builder = lib.types.submodule {
|
builder = lib.types.submodule {
|
||||||
freeform = lib.types.any;
|
freeform = lib.types.any;
|
||||||
|
|
||||||
|
@ -66,256 +71,316 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
packages = lib.types.attrs.of (lib'.types.alias);
|
packages = lib.types.attrs.of (lib.types.attrs.of lib'.types.alias);
|
||||||
|
|
||||||
alias = lib.types.attrs.of (
|
dependencies =
|
||||||
lib.types.submodule {
|
build: host: target:
|
||||||
options = {
|
let
|
||||||
versions = lib.options.create {
|
initial = lib.types.raw;
|
||||||
description = "All available package versions.";
|
|
||||||
type = lib.types.attrs.of lib'.types.package;
|
transform =
|
||||||
};
|
value:
|
||||||
|
let
|
||||||
|
package = lib'.packages.resolve value;
|
||||||
|
in
|
||||||
|
lib'.packages.build package build host target;
|
||||||
|
in
|
||||||
|
lib.types.attrs.of (lib.types.coerce initial transform lib'.types.package);
|
||||||
|
|
||||||
|
alias = lib.types.submodule {
|
||||||
|
options = {
|
||||||
|
stable = lib.options.create {
|
||||||
|
description = "The stable version of the package.";
|
||||||
|
type = lib.types.nullish lib'.types.package;
|
||||||
};
|
};
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
dependencies = lib.types.attrs.of (
|
latest = lib.options.create {
|
||||||
lib.types.nullish (lib.types.either lib'.types.alias lib'.types.package)
|
description = "The latest version of the package.";
|
||||||
);
|
type = lib'.types.package;
|
||||||
|
};
|
||||||
|
|
||||||
package = lib.types.submodule (
|
versions = lib.options.create {
|
||||||
{ config, meta }:
|
description = "Available versions of the package.";
|
||||||
{
|
type = lib.types.attrs.of lib'.types.package;
|
||||||
options = {
|
default.value = { };
|
||||||
extend = lib.options.create {
|
};
|
||||||
description = "Extend the package's submodules with additional configuration.";
|
};
|
||||||
type = lib.types.function lib.types.raw;
|
};
|
||||||
default.value =
|
|
||||||
value:
|
package =
|
||||||
let
|
let
|
||||||
result = meta.extend {
|
normalize =
|
||||||
modules = if builtins.isAttrs value then [ { config = value; } ] else lib.lists.from.any value;
|
value:
|
||||||
|
if builtins.isFunction value || builtins.isList value then
|
||||||
|
value
|
||||||
|
else if value ? __modules__ then
|
||||||
|
value.__modules__
|
||||||
|
else
|
||||||
|
{ config = value; };
|
||||||
|
|
||||||
|
initial = lib.types.create {
|
||||||
|
name = "PackageConfig";
|
||||||
|
description = "configuration for a package";
|
||||||
|
check = value: builtins.isFunction value || builtins.isAttrs value || builtins.isList value;
|
||||||
|
merge =
|
||||||
|
location: definitions:
|
||||||
|
let
|
||||||
|
normalized = builtins.map (definition: lib.lists.from.any (normalize definition.value)) definitions;
|
||||||
|
in
|
||||||
|
builtins.concatLists normalized;
|
||||||
|
};
|
||||||
|
|
||||||
|
transform =
|
||||||
|
location: value:
|
||||||
|
let
|
||||||
|
modules = lib.lists.from.any (normalize value);
|
||||||
|
|
||||||
|
result = lib.modules.run {
|
||||||
|
prefix = location;
|
||||||
|
modules = modules ++ [
|
||||||
|
submodule
|
||||||
|
{ config.__modules__ = modules; }
|
||||||
|
];
|
||||||
|
};
|
||||||
|
in
|
||||||
|
result.config;
|
||||||
|
|
||||||
|
final = lib.types.raw;
|
||||||
|
|
||||||
|
deps =
|
||||||
|
build: host: target:
|
||||||
|
lib.types.submodule {
|
||||||
|
options = {
|
||||||
|
build = {
|
||||||
|
only = lib.options.create {
|
||||||
|
description = "Dependencies which are only used in the build environment.";
|
||||||
|
type = lib'.types.dependencies build build build;
|
||||||
|
default.value = { };
|
||||||
};
|
};
|
||||||
in
|
|
||||||
result.config;
|
|
||||||
};
|
|
||||||
|
|
||||||
name = lib.options.create {
|
build = lib.options.create {
|
||||||
description = "The name of the package.";
|
description = "Dependencies which are created in the build environment and are executed in the build environment.";
|
||||||
type = lib.types.string;
|
type = lib'.types.dependencies build build target;
|
||||||
default = {
|
default.value = { };
|
||||||
text = "\${config.pname}-\${config.version}";
|
};
|
||||||
value =
|
|
||||||
if config.pname != null && config.version != null then "${config.pname}-${config.version}" else "";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
pname = lib.options.create {
|
host = lib.options.create {
|
||||||
description = "The program name for the package";
|
description = "Dependencies which are created in the build environment and are executed in the host environment.";
|
||||||
type = lib.types.nullish lib.types.string;
|
type = lib'.types.dependencies build host target;
|
||||||
default.value = null;
|
default.value = { };
|
||||||
};
|
};
|
||||||
|
|
||||||
version = lib.options.create {
|
target = lib.options.create {
|
||||||
description = "The version for the package.";
|
description = "Dependencies which are created in the build environment and are executed in the target environment.";
|
||||||
type = lib.types.nullish lib.types.version;
|
type = lib'.types.dependencies build target target;
|
||||||
default.value = null;
|
default.value = { };
|
||||||
};
|
};
|
||||||
|
|
||||||
meta = {
|
|
||||||
description = lib.options.create {
|
|
||||||
description = "The description for the package.";
|
|
||||||
type = lib.types.nullish lib.types.string;
|
|
||||||
default.value = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
homepage = lib.options.create {
|
|
||||||
description = "The homepage for the package.";
|
|
||||||
type = lib.types.nullish lib.types.string;
|
|
||||||
default.value = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
license = lib.options.create {
|
|
||||||
description = "The license for the package.";
|
|
||||||
type = lib.types.nullish lib'.types.license;
|
|
||||||
default.value = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
free = lib.options.create {
|
|
||||||
description = "Whether the package is free.";
|
|
||||||
type = lib.types.bool;
|
|
||||||
default.value = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
insecure = lib.options.create {
|
|
||||||
description = "Whether the package is insecure.";
|
|
||||||
type = lib.types.bool;
|
|
||||||
default.value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
broken = lib.options.create {
|
|
||||||
description = "Whether the package is broken.";
|
|
||||||
type = lib.types.bool;
|
|
||||||
default.value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
main = lib.options.create {
|
|
||||||
description = "The main entry point for the package.";
|
|
||||||
type = lib.types.nullish lib.types.string;
|
|
||||||
default.value = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
platforms = lib.options.create {
|
|
||||||
description = "The platforms the package supports.";
|
|
||||||
type = lib.types.list.of lib.types.string;
|
|
||||||
default.value = [ ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
platform = {
|
|
||||||
build = lib.options.create {
|
|
||||||
description = "The build platform for the package.";
|
|
||||||
type = lib.types.string;
|
|
||||||
default.value = "x86_64-linux";
|
|
||||||
apply =
|
|
||||||
raw:
|
|
||||||
let
|
|
||||||
system = lib'.systems.from.string raw;
|
|
||||||
x = lib'.systems.withBuildInfo raw;
|
|
||||||
in
|
|
||||||
x;
|
|
||||||
};
|
|
||||||
|
|
||||||
host = lib.options.create {
|
|
||||||
description = "The host platform for the package.";
|
|
||||||
type = lib.types.string;
|
|
||||||
default.value = "x86_64-linux";
|
|
||||||
# apply = raw: let
|
|
||||||
# system = lib'.systems.from.string raw;
|
|
||||||
# in {
|
|
||||||
# inherit raw system;
|
|
||||||
|
|
||||||
# double = lib'.systems.into.double system;
|
|
||||||
# triple = lib'.systems.into.triple system;
|
|
||||||
# };
|
|
||||||
apply =
|
|
||||||
raw:
|
|
||||||
let
|
|
||||||
system = lib'.systems.from.string raw;
|
|
||||||
x = lib'.systems.withBuildInfo raw;
|
|
||||||
in
|
|
||||||
x;
|
|
||||||
};
|
|
||||||
|
|
||||||
target = lib.options.create {
|
|
||||||
description = "The target platform for the package.";
|
|
||||||
type = lib.types.string;
|
|
||||||
default.value = "x86_64-linux";
|
|
||||||
# apply = raw: let
|
|
||||||
# system = lib'.systems.from.string raw;
|
|
||||||
# in {
|
|
||||||
# inherit raw system;
|
|
||||||
|
|
||||||
# double = lib'.systems.into.double system;
|
|
||||||
# triple = lib'.systems.into.triple system;
|
|
||||||
# };
|
|
||||||
apply =
|
|
||||||
raw:
|
|
||||||
let
|
|
||||||
system = lib'.systems.from.string raw;
|
|
||||||
x = lib'.systems.withBuildInfo raw;
|
|
||||||
in
|
|
||||||
x;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
phases = lib.options.create {
|
|
||||||
description = "The phases for the package.";
|
|
||||||
type = lib.types.dag.of (lib.types.either lib.types.string (lib.types.function lib.types.string));
|
|
||||||
default.value = { };
|
|
||||||
};
|
|
||||||
|
|
||||||
env = lib.options.create {
|
|
||||||
description = "The environment for the package.";
|
|
||||||
type = lib.types.attrs.of lib.types.string;
|
|
||||||
default.value = { };
|
|
||||||
};
|
|
||||||
|
|
||||||
builder = lib.options.create {
|
|
||||||
description = "The builder for the package.";
|
|
||||||
type = lib'.types.builder;
|
|
||||||
};
|
|
||||||
|
|
||||||
deps = {
|
|
||||||
build = {
|
|
||||||
only = lib.options.create {
|
|
||||||
description = "Dependencies which are only used in the build environment.";
|
|
||||||
type = lib'.types.dependencies;
|
|
||||||
default.value = { };
|
|
||||||
};
|
};
|
||||||
|
|
||||||
build = lib.options.create {
|
host = {
|
||||||
description = "Dependencies which are created in the build environment and are executed in the build environment.";
|
only = lib.options.create {
|
||||||
type = lib'.types.dependencies;
|
description = "Dependencies which are only used in the host environment.";
|
||||||
default.value = { };
|
type = lib'.types.dependencies host host host;
|
||||||
|
default.value = { };
|
||||||
|
};
|
||||||
|
|
||||||
|
host = lib.options.create {
|
||||||
|
description = "Dependencies which are executed in the host environment.";
|
||||||
|
type = lib'.types.dependencies host host target;
|
||||||
|
default.value = { };
|
||||||
|
};
|
||||||
|
|
||||||
|
target = lib.options.create {
|
||||||
|
description = "Dependencies which are executed in the host environment which produces code for the target environment.";
|
||||||
|
type = lib'.types.dependencies host target target;
|
||||||
|
default.value = { };
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
host = lib.options.create {
|
target = {
|
||||||
description = "Dependencies which are created in the build environment and are executed in the host environment.";
|
only = lib.options.create {
|
||||||
type = lib'.types.dependencies;
|
description = "Dependencies which are only used in the target environment.";
|
||||||
default.value = { };
|
type = lib'.types.dependencies target target target;
|
||||||
};
|
default.value = { };
|
||||||
|
};
|
||||||
|
|
||||||
target = lib.options.create {
|
target = lib.options.create {
|
||||||
description = "Dependencies which are created in the build environment and are executed in the target environment.";
|
description = "Dependencies which are executed in the target environment.";
|
||||||
type = lib'.types.dependencies;
|
type = lib'.types.dependencies target target target;
|
||||||
default.value = { };
|
default.value = { };
|
||||||
};
|
};
|
||||||
};
|
|
||||||
|
|
||||||
host = {
|
|
||||||
only = lib.options.create {
|
|
||||||
description = "Dependencies which are only used in the host environment.";
|
|
||||||
type = lib'.types.dependencies;
|
|
||||||
default.value = { };
|
|
||||||
};
|
|
||||||
|
|
||||||
host = lib.options.create {
|
|
||||||
description = "Dependencies which are executed in the host environment.";
|
|
||||||
type = lib'.types.dependencies;
|
|
||||||
default.value = { };
|
|
||||||
};
|
|
||||||
|
|
||||||
target = lib.options.create {
|
|
||||||
description = "Dependencies which are executed in the host environment which produces code for the target environment.";
|
|
||||||
type = lib'.types.dependencies;
|
|
||||||
default.value = { };
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
target = {
|
|
||||||
only = lib.options.create {
|
|
||||||
description = "Dependencies which are only used in the target environment.";
|
|
||||||
type = lib'.types.dependencies;
|
|
||||||
default.value = { };
|
|
||||||
};
|
|
||||||
|
|
||||||
target = lib.options.create {
|
|
||||||
description = "Dependencies which are executed in the target environment.";
|
|
||||||
type = lib'.types.dependencies;
|
|
||||||
default.value = { };
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
package = lib.options.create {
|
submodule =
|
||||||
description = "The built derivation.";
|
{ config }:
|
||||||
type = lib.types.derivation;
|
let
|
||||||
default.value = config.builder.build config;
|
build = config.platform.build;
|
||||||
|
host = config.platform.host;
|
||||||
|
target = config.platform.target;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
__modules__ = lib.options.create {
|
||||||
|
description = "User specified modules for the package definition.";
|
||||||
|
type = lib.types.list.of (initial // { merge = lib.options.merge.one; });
|
||||||
|
# writable = false;
|
||||||
|
internal = true;
|
||||||
|
default.value = [ ];
|
||||||
|
};
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = lib.options.create {
|
||||||
|
description = "The description for the package.";
|
||||||
|
type = lib.types.nullish lib.types.string;
|
||||||
|
default.value = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
homepage = lib.options.create {
|
||||||
|
description = "The homepage for the package.";
|
||||||
|
type = lib.types.nullish lib.types.string;
|
||||||
|
default.value = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
license = lib.options.create {
|
||||||
|
description = "The license for the package.";
|
||||||
|
type = lib.types.nullish lib'.types.license;
|
||||||
|
default.value = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
free = lib.options.create {
|
||||||
|
description = "Whether the package is free.";
|
||||||
|
type = lib.types.bool;
|
||||||
|
default.value = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
insecure = lib.options.create {
|
||||||
|
description = "Whether the package is insecure.";
|
||||||
|
type = lib.types.bool;
|
||||||
|
default.value = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
broken = lib.options.create {
|
||||||
|
description = "Whether the package is broken.";
|
||||||
|
type = lib.types.bool;
|
||||||
|
default.value = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
main = lib.options.create {
|
||||||
|
description = "The main entry point for the package.";
|
||||||
|
type = lib.types.nullish lib.types.string;
|
||||||
|
default.value = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
platforms = lib.options.create {
|
||||||
|
description = "The platforms the package supports.";
|
||||||
|
type = lib.types.list.of lib.types.string;
|
||||||
|
default.value = [ ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
platform = {
|
||||||
|
build = lib.options.create {
|
||||||
|
description = "The build platform for the package.";
|
||||||
|
type = lib'.types.platform;
|
||||||
|
default.value = lib'.systems.withBuildInfo "x86_64-linux";
|
||||||
|
};
|
||||||
|
|
||||||
|
host = lib.options.create {
|
||||||
|
description = "The host platform for the package.";
|
||||||
|
type = lib'.types.platform;
|
||||||
|
default.value = lib'.systems.withBuildInfo "x86_64-linux";
|
||||||
|
};
|
||||||
|
|
||||||
|
target = lib.options.create {
|
||||||
|
description = "The target platform for the package.";
|
||||||
|
type = lib'.types.platform;
|
||||||
|
default.value = lib'.systems.withBuildInfo "x86_64-linux";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
name = lib.options.create {
|
||||||
|
description = "The name of the package.";
|
||||||
|
type = lib.types.string;
|
||||||
|
default = {
|
||||||
|
text = "\${config.pname}-\${config.version}";
|
||||||
|
value =
|
||||||
|
if config.pname != null && config.version != null then "${config.pname}-${config.version}" else "";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
pname = lib.options.create {
|
||||||
|
description = "The program name for the package";
|
||||||
|
type = lib.types.nullish lib.types.string;
|
||||||
|
default.value = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
version = lib.options.create {
|
||||||
|
description = "The version for the package.";
|
||||||
|
type = lib.types.nullish lib.types.version;
|
||||||
|
default.value = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
builder = lib.options.create {
|
||||||
|
description = "The builder for the package.";
|
||||||
|
type = lib'.types.builder;
|
||||||
|
};
|
||||||
|
|
||||||
|
phases = lib.options.create {
|
||||||
|
description = "The phases for the package.";
|
||||||
|
type = lib.types.dag.of lib.types.string;
|
||||||
|
default.value = { };
|
||||||
|
};
|
||||||
|
|
||||||
|
env = lib.options.create {
|
||||||
|
description = "The environment for the package.";
|
||||||
|
type = lib.types.attrs.of lib.types.string;
|
||||||
|
default.value = { };
|
||||||
|
};
|
||||||
|
|
||||||
|
package = lib.options.create {
|
||||||
|
description = "The built derivation.";
|
||||||
|
type = lib.types.derivation;
|
||||||
|
default.value = config.builder.build config;
|
||||||
|
};
|
||||||
|
|
||||||
|
deps = lib.options.create {
|
||||||
|
description = "The dependencies for the package.";
|
||||||
|
type = deps build host target;
|
||||||
|
default.value = { };
|
||||||
|
apply = value: {
|
||||||
|
build = {
|
||||||
|
only = lib'.packages.dependencies.build build build build value.build.only;
|
||||||
|
build = lib'.packages.dependencies.build build build target value.build.build;
|
||||||
|
host = lib'.packages.dependencies.build build host target value.build.host;
|
||||||
|
target = lib'.packages.dependencies.build build target target value.build.target;
|
||||||
|
};
|
||||||
|
host = {
|
||||||
|
only = lib'.packages.dependencies.build host host host value.host.only;
|
||||||
|
host = lib'.packages.dependencies.build host host target value.host.host;
|
||||||
|
target = lib'.packages.dependencies.build host target target value.host.target;
|
||||||
|
};
|
||||||
|
target = {
|
||||||
|
only = lib'.packages.dependencies.build target target target value.target.only;
|
||||||
|
target = lib'.packages.dependencies.build target target target value.target.target;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
type = (lib.types.coerceWithLocation initial transform final) // {
|
||||||
|
name = "Package";
|
||||||
|
description = "a package definition";
|
||||||
};
|
};
|
||||||
}
|
in
|
||||||
);
|
type
|
||||||
|
// {
|
||||||
|
children = type.children // {
|
||||||
|
inherit submodule;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
36
tidepool/src/packages/aux/a.nix
Normal file
36
tidepool/src/packages/aux/a.nix
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
{ lib', config }:
|
||||||
|
let
|
||||||
|
inherit (config) builders packages;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
config.packages.aux.a = {
|
||||||
|
versions = {
|
||||||
|
"latest" =
|
||||||
|
{ config }:
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
meta = {
|
||||||
|
platforms = [ "i686-linux" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
name = "${config.pname}-${config.version}";
|
||||||
|
|
||||||
|
pname = "a";
|
||||||
|
version = "1.0.0";
|
||||||
|
|
||||||
|
builder = builders.basic;
|
||||||
|
|
||||||
|
deps.build.host = {
|
||||||
|
inherit (packages.aux) b;
|
||||||
|
};
|
||||||
|
|
||||||
|
phases = {
|
||||||
|
install = ''
|
||||||
|
echo "a with b: ${config.deps.build.host.b.package.system}" > $out
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
38
tidepool/src/packages/aux/b.nix
Normal file
38
tidepool/src/packages/aux/b.nix
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
{ config }:
|
||||||
|
let
|
||||||
|
inherit (config) lib builders packages;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
config.packages.aux.b = {
|
||||||
|
versions = {
|
||||||
|
"latest" =
|
||||||
|
{ config }:
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
custom = lib.options.create { type = lib.types.bool; };
|
||||||
|
};
|
||||||
|
|
||||||
|
config = {
|
||||||
|
meta = {
|
||||||
|
platforms = [ "i686-linux" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
name = "${config.pname}-${config.version}";
|
||||||
|
|
||||||
|
custom = true;
|
||||||
|
|
||||||
|
pname = "b";
|
||||||
|
version = "1.0.0";
|
||||||
|
|
||||||
|
builder = builders.basic;
|
||||||
|
|
||||||
|
phases = {
|
||||||
|
install = ''
|
||||||
|
echo "b" > $out
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,27 +1,29 @@
|
||||||
{
|
{ config }:
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
config,
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
doubles = lib'.systems.doubles.all;
|
inherit (config) lib;
|
||||||
|
|
||||||
|
doubles = lib.systems.doubles.all;
|
||||||
|
|
||||||
packages = builtins.removeAttrs config.packages [ "cross" ];
|
packages = builtins.removeAttrs config.packages [ "cross" ];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
includes = [ ./foundation ];
|
includes = [
|
||||||
|
./foundation
|
||||||
|
./aux/a.nix
|
||||||
|
./aux/b.nix
|
||||||
|
];
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
packages = lib.options.create {
|
packages = lib.options.create {
|
||||||
description = "The package set.";
|
description = "The package set.";
|
||||||
type = lib.types.submodule {
|
type = lib.types.submodule {
|
||||||
freeform = lib.types.attrs.of (lib.types.submodule { freeform = lib'.types.alias; });
|
freeform = lib.types.packages;
|
||||||
|
|
||||||
options.cross = lib.attrs.generate doubles (
|
options.cross = lib.attrs.generate doubles (
|
||||||
system:
|
system:
|
||||||
lib.options.create {
|
lib.options.create {
|
||||||
description = "The cross-compiled package set for the ${system} target.";
|
description = "The cross-compiled package set for the ${system} target.";
|
||||||
type = lib'.types.packages;
|
type = lib.types.packages;
|
||||||
default = { };
|
default = { };
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
@ -49,38 +51,49 @@ in
|
||||||
let
|
let
|
||||||
setHost =
|
setHost =
|
||||||
package:
|
package:
|
||||||
if package != { } then
|
package
|
||||||
(package.extend (
|
// {
|
||||||
{ config }:
|
__modules__ = package.__modules__ ++ [
|
||||||
{
|
{
|
||||||
config = {
|
config.platform = {
|
||||||
platform = {
|
host = lib.modules.override 5 system;
|
||||||
host = lib.modules.overrides.force system;
|
target = lib.modules.override 5 system;
|
||||||
target = lib.modules.overrides.default system;
|
|
||||||
};
|
|
||||||
|
|
||||||
deps = {
|
|
||||||
build = {
|
|
||||||
only = setHost package.deps.build.only;
|
|
||||||
build = setHost package.deps.build.build;
|
|
||||||
host = setHost package.deps.build.host;
|
|
||||||
target = setHost package.deps.build.target;
|
|
||||||
};
|
|
||||||
host = {
|
|
||||||
only = setHost package.deps.host.only;
|
|
||||||
host = setHost package.deps.host.host;
|
|
||||||
target = setHost package.deps.host.target;
|
|
||||||
};
|
|
||||||
target = {
|
|
||||||
only = setHost package.deps.target.only;
|
|
||||||
target = setHost package.deps.target.target;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
)).config
|
];
|
||||||
else
|
};
|
||||||
package;
|
# if package != {}
|
||||||
|
# then
|
||||||
|
# (package.extend (
|
||||||
|
# {config}: {
|
||||||
|
# config = {
|
||||||
|
# platform = {
|
||||||
|
# host = lib.modules.overrides.force system;
|
||||||
|
# target = lib.modules.overrides.default system;
|
||||||
|
# };
|
||||||
|
|
||||||
|
# deps = {
|
||||||
|
# build = {
|
||||||
|
# only = setHost package.deps.build.only;
|
||||||
|
# build = setHost package.deps.build.build;
|
||||||
|
# host = setHost package.deps.build.host;
|
||||||
|
# target = setHost package.deps.build.target;
|
||||||
|
# };
|
||||||
|
# host = {
|
||||||
|
# only = setHost package.deps.host.only;
|
||||||
|
# host = setHost package.deps.host.host;
|
||||||
|
# target = setHost package.deps.host.target;
|
||||||
|
# };
|
||||||
|
# target = {
|
||||||
|
# only = setHost package.deps.target.only;
|
||||||
|
# target = setHost package.deps.target.target;
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# }
|
||||||
|
# ))
|
||||||
|
# .config
|
||||||
|
# else package;
|
||||||
|
|
||||||
updated = alias // {
|
updated = alias // {
|
||||||
versions = builtins.mapAttrs (version: package: setHost package) alias.versions;
|
versions = builtins.mapAttrs (version: package: setHost package) alias.versions;
|
||||||
|
|
|
@ -11,13 +11,14 @@ let
|
||||||
# These are the upstream foundational packages exported from the Aux Foundation project.
|
# These are the upstream foundational packages exported from the Aux Foundation project.
|
||||||
|
|
||||||
foundation
|
foundation
|
||||||
|
packages
|
||||||
;
|
;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config.packages.foundation.binutils = {
|
config.packages.foundation.binutils = {
|
||||||
versions = {
|
versions = {
|
||||||
"latest" =
|
"latest" =
|
||||||
{ config, meta }:
|
{ config }:
|
||||||
{
|
{
|
||||||
options = {
|
options = {
|
||||||
src = lib.options.create {
|
src = lib.options.create {
|
||||||
|
@ -36,9 +37,17 @@ in
|
||||||
|
|
||||||
builder = builders.basic;
|
builder = builders.basic;
|
||||||
|
|
||||||
|
deps = {
|
||||||
|
build = {
|
||||||
|
host = {
|
||||||
|
inherit (packages.foundation) gcc;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
env = {
|
env = {
|
||||||
PATH = lib.paths.bin [
|
PATH = lib.paths.bin [
|
||||||
foundation.stage2-gcc
|
# foundation.stage2-gcc
|
||||||
foundation.stage2-binutils
|
foundation.stage2-binutils
|
||||||
foundation.stage2-gnumake
|
foundation.stage2-gnumake
|
||||||
foundation.stage2-gnupatch
|
foundation.stage2-gnupatch
|
||||||
|
@ -86,24 +95,24 @@ in
|
||||||
];
|
];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
unpack = lib.dag.entry.before [ "patch" ] ''
|
unpack = ''
|
||||||
tar xf ${config.src}
|
tar xf ${config.src}
|
||||||
cd binutils-${config.version}
|
cd binutils-${config.version}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
patch = lib.dag.entry.between [ "configure" ] [ "unpack" ] ''
|
patch = ''
|
||||||
${lib.strings.concatMapSep "\n" (file: "patch -Np1 -i ${file}") patches}
|
${lib.strings.concatMapSep "\n" (file: "patch -Np1 -i ${file}") patches}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
configure = lib.dag.entry.between [ "build" ] [ "patch" ] ''
|
configure = ''
|
||||||
bash ./configure ${builtins.concatStringsSep " " configureFlags}
|
bash ./configure ${builtins.concatStringsSep " " configureFlags}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
build = lib.dag.entry.between [ "install" ] [ "configure" ] ''
|
build = ''
|
||||||
make -j $NIX_BUILD_CORES
|
make -j $NIX_BUILD_CORES
|
||||||
'';
|
'';
|
||||||
|
|
||||||
install = lib.dag.entry.after [ "build" ] ''
|
install = ''
|
||||||
make -j $NIX_BUILD_CORES install-strip
|
make -j $NIX_BUILD_CORES install-strip
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
./gcc
|
./gcc
|
||||||
./binutils
|
./binutils
|
||||||
./linux-headers
|
./linux-headers
|
||||||
|
./glibc
|
||||||
|
# ./xz
|
||||||
];
|
];
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
|
|
|
@ -1,16 +1,13 @@
|
||||||
{
|
{ config, options }:
|
||||||
lib,
|
|
||||||
lib',
|
|
||||||
config,
|
|
||||||
options,
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
inherit (config)
|
inherit (config)
|
||||||
|
lib
|
||||||
mirrors
|
mirrors
|
||||||
builders
|
builders
|
||||||
# These are the upstream foundational packages exported from the Aux Foundation project.
|
# These are the upstream foundational packages exported from the Aux Foundation project.
|
||||||
|
|
||||||
foundation
|
foundation
|
||||||
|
packages
|
||||||
;
|
;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
@ -91,51 +88,30 @@ in
|
||||||
builder = builders.basic;
|
builder = builders.basic;
|
||||||
|
|
||||||
env = {
|
env = {
|
||||||
PATH =
|
PATH = lib.paths.bin [
|
||||||
let
|
foundation.stage2-gcc
|
||||||
gcc =
|
foundation.stage2-binutils
|
||||||
if
|
foundation.stage2-gnumake
|
||||||
config.platform.build.triple == config.platform.host.triple
|
foundation.stage2-gnused
|
||||||
# If we're on the same system then we can use the existing GCC instance.
|
foundation.stage2-gnugrep
|
||||||
then
|
foundation.stage2-gawk
|
||||||
foundation.stage2-gcc
|
foundation.stage2-diffutils
|
||||||
# Otherwise we are going to need a cross-compiler.
|
foundation.stage2-findutils
|
||||||
else
|
foundation.stage2-gnutar
|
||||||
# TODO: Create a gcc-cross package.
|
foundation.stage2-gzip
|
||||||
(meta.extend (args: {
|
foundation.stage2-bzip2
|
||||||
config = {
|
foundation.stage1-xz
|
||||||
platform = {
|
];
|
||||||
build = config.platform.build.triple;
|
|
||||||
host = config.platform.build.triple;
|
|
||||||
target = lib.modules.override.force config.platform.host.triple;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
})).config.package;
|
|
||||||
in
|
|
||||||
lib.paths.bin [
|
|
||||||
foundation.stage2-gcc
|
|
||||||
foundation.stage2-binutils
|
|
||||||
foundation.stage2-gnumake
|
|
||||||
foundation.stage2-gnused
|
|
||||||
foundation.stage2-gnugrep
|
|
||||||
foundation.stage2-gawk
|
|
||||||
foundation.stage2-diffutils
|
|
||||||
foundation.stage2-findutils
|
|
||||||
foundation.stage2-gnutar
|
|
||||||
foundation.stage2-gzip
|
|
||||||
foundation.stage2-bzip2
|
|
||||||
foundation.stage1-xz
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
phases =
|
phases =
|
||||||
let
|
let
|
||||||
host = lib'.systems.withBuildInfo config.platform.host;
|
host = lib.systems.withBuildInfo config.platform.host;
|
||||||
|
|
||||||
mbits = if host.system.cpu.family == "x86" then if host.is64bit then "-m64" else "-m32" else "";
|
mbits = if host.system.cpu.family == "x86" then if host.is64bit then "-m64" else "-m32" else "";
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
unpack = lib.dag.entry.before [ "patch" ] ''
|
unpack = ''
|
||||||
# Unpack
|
# Unpack
|
||||||
tar xf ${config.src}
|
tar xf ${config.src}
|
||||||
tar xf ${config.gmp.src}
|
tar xf ${config.gmp.src}
|
||||||
|
@ -150,17 +126,15 @@ in
|
||||||
ln -s ../isl-${config.isl.version} isl
|
ln -s ../isl-${config.isl.version} isl
|
||||||
'';
|
'';
|
||||||
|
|
||||||
patch = lib.dag.entry.between [ "configure" ] [ "unpack" ] ''
|
patch = ''
|
||||||
# Patch
|
# Patch
|
||||||
# force musl even if host triple is gnu
|
# force musl even if host triple is gnu
|
||||||
sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host
|
sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host
|
||||||
'';
|
'';
|
||||||
|
|
||||||
configure = lib.dag.entry.between [ "build" ] [ "patch" ] ''
|
configure = ''
|
||||||
# Configure
|
# Configure
|
||||||
export CC="gcc -Wl,-dynamic-linker -march=${
|
export CC="gcc -Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
||||||
host.gcc.arch or host.system.cpu.family
|
|
||||||
} ${mbits} -Wl,${foundation.stage1-musl}/lib/libc.so"
|
|
||||||
export CXX="g++ -Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
export CXX="g++ -Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
||||||
export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${foundation.stage1-musl}/lib/libc.so"
|
||||||
export LIBRARY_PATH="${foundation.stage1-musl}/lib"
|
export LIBRARY_PATH="${foundation.stage1-musl}/lib"
|
||||||
|
@ -182,12 +156,12 @@ in
|
||||||
CXXFLAGS=-static
|
CXXFLAGS=-static
|
||||||
'';
|
'';
|
||||||
|
|
||||||
build = lib.dag.entry.between [ "install" ] [ "configure" ] ''
|
build = ''
|
||||||
# Build
|
# Build
|
||||||
make -j $NIX_BUILD_CORES
|
make -j $NIX_BUILD_CORES
|
||||||
'';
|
'';
|
||||||
|
|
||||||
install = lib.dag.entry.after [ "build" ] ''
|
install = ''
|
||||||
# Install
|
# Install
|
||||||
make -j $NIX_BUILD_CORES install-strip
|
make -j $NIX_BUILD_CORES install-strip
|
||||||
'';
|
'';
|
||||||
|
|
|
@ -54,20 +54,16 @@ in
|
||||||
};
|
};
|
||||||
|
|
||||||
phases = {
|
phases = {
|
||||||
unpack = lib.dag.entry.before [ "patch" ] ''
|
unpack = ''
|
||||||
tar xf ${config.src}
|
tar xf ${config.src}
|
||||||
cd linux-${config.version}
|
cd linux-${config.version}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
patch = lib.dag.entry.between [ "configure" ] [ "unpack" ] '''';
|
build = ''
|
||||||
|
|
||||||
configure = lib.dag.entry.between [ "build" ] [ "patch" ] '''';
|
|
||||||
|
|
||||||
build = lib.dag.entry.between [ "install" ] [ "configure" ] ''
|
|
||||||
make -j $NIX_BUILD_CORES CC=musl-gcc HOSTCC=musl-gcc ARCH=${config.platform.host.linux.arch} headers
|
make -j $NIX_BUILD_CORES CC=musl-gcc HOSTCC=musl-gcc ARCH=${config.platform.host.linux.arch} headers
|
||||||
'';
|
'';
|
||||||
|
|
||||||
install = lib.dag.entry.after [ "build" ] ''
|
install = ''
|
||||||
find usr/include -name '.*' -exec rm {} +
|
find usr/include -name '.*' -exec rm {} +
|
||||||
mkdir -p $out
|
mkdir -p $out
|
||||||
cp -rv usr/include $out/
|
cp -rv usr/include $out/
|
||||||
|
|
Loading…
Reference in a new issue