Compare commits
1 commit
11d467fecd
...
577ef6e478
Author | SHA1 | Date | |
---|---|---|---|
577ef6e478 |
6 changed files with 31 additions and 57 deletions
1
.nix-version
Normal file
1
.nix-version
Normal file
|
@ -0,0 +1 @@
|
||||||
|
unstable
|
14
README.md
14
README.md
|
@ -1,8 +1,5 @@
|
||||||
# nix-eval-jobs
|
# nix-eval-jobs
|
||||||
|
|
||||||
> [!NOTE]
|
|
||||||
> This is a fork of nix-eval-jobs that works with Lix.
|
|
||||||
|
|
||||||
This project evaluates nix attribute sets in parallel with streamable json
|
This project evaluates nix attribute sets in parallel with streamable json
|
||||||
output. This is useful for time and memory intensive evaluations such as NixOS
|
output. This is useful for time and memory intensive evaluations such as NixOS
|
||||||
machines, i.e. in a CI context. The evaluation is done with a controllable
|
machines, i.e. in a CI context. The evaluation is done with a controllable
|
||||||
|
@ -92,12 +89,11 @@ we collect example ci configuration for various CIs.
|
||||||
|
|
||||||
## Organisation of this repository
|
## Organisation of this repository
|
||||||
|
|
||||||
`main` follows Lix HEAD, and is updated alongside the Lix NixOS module. When we
|
On the `main` branch we target nixUnstable. When a release of nix happens, we
|
||||||
release we will make a `release-2.90` etc branch, which receives backports.
|
fork for a release branch i.e. `release-2.8` and change the nix version in
|
||||||
|
`.nix-version`. Changes and improvements made in `main` also may be backported
|
||||||
The version of nix-eval-jobs follows the major version of Lix and minor
|
to these release branches. At the time of writing we only intent to support the
|
||||||
versions of nix-eval-jobs are released as necessary when changes are made in
|
latest release branch.
|
||||||
n-e-j itself.
|
|
||||||
|
|
||||||
## Projects using nix-eval-jobs
|
## Projects using nix-eval-jobs
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ let
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
pname = "nix-eval-jobs";
|
pname = "nix-eval-jobs";
|
||||||
version = "2.90.0-unstable";
|
version = "2.19.0";
|
||||||
src = if srcDir == null then filterMesonBuild ./. else srcDir;
|
src = if srcDir == null then filterMesonBuild ./. else srcDir;
|
||||||
buildInputs = with pkgs; [
|
buildInputs = with pkgs; [
|
||||||
nlohmann_json
|
nlohmann_json
|
||||||
|
|
51
flake.lock
51
flake.lock
|
@ -23,11 +23,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1717285511,
|
"lastModified": 1701473968,
|
||||||
"narHash": "sha256-iKzJcpdXih14qYVcZ9QC9XuZYnPc6T8YImb6dX166kw=",
|
"narHash": "sha256-YcVE5emp1qQ8ieHUnxt1wCZCC3ZfAS+SRRWZ2TMda7E=",
|
||||||
"owner": "hercules-ci",
|
"owner": "hercules-ci",
|
||||||
"repo": "flake-parts",
|
"repo": "flake-parts",
|
||||||
"rev": "2a55567fcf15b1b1c7ed712a2c6fadaec7412ea8",
|
"rev": "34fed993f1674c8d06d58b37ce1e0fe5eebcb9f5",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -39,7 +39,6 @@
|
||||||
"lix": {
|
"lix": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-compat": "flake-compat",
|
"flake-compat": "flake-compat",
|
||||||
"nix2container": "nix2container",
|
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
],
|
],
|
||||||
|
@ -47,11 +46,11 @@
|
||||||
"pre-commit-hooks": "pre-commit-hooks"
|
"pre-commit-hooks": "pre-commit-hooks"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1718228457,
|
"lastModified": 1717081103,
|
||||||
"narHash": "sha256-vGumESUGu/jo2Lm5bha/xBsJKVlb1wuclXlL9xudRp4=",
|
"narHash": "sha256-4hrY8lIK6boX0xe6LN+OFpsmOAITl0Iam17FC8Kjslk=",
|
||||||
"ref": "refs/heads/main",
|
"ref": "refs/heads/main",
|
||||||
"rev": "f46194faa2fc9c78250702c8eb7a4b756e0bd944",
|
"rev": "c161687b5fa6e7604e99ee5df2e73388952baafb",
|
||||||
"revCount": 15757,
|
"revCount": 15698,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git@git.lix.systems/lix-project/lix"
|
"url": "https://git@git.lix.systems/lix-project/lix"
|
||||||
},
|
},
|
||||||
|
@ -67,11 +66,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1703863825,
|
"lastModified": 1701208414,
|
||||||
"narHash": "sha256-rXwqjtwiGKJheXB43ybM8NwWB8rO2dSRrEqes0S7F5Y=",
|
"narHash": "sha256-xrQ0FyhwTZK6BwKhahIkUVZhMNk21IEI1nUcWSONtpo=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "nix-github-actions",
|
"repo": "nix-github-actions",
|
||||||
"rev": "5163432afc817cf8bd1f031418d1869e4c9d5547",
|
"rev": "93e39cc1a087d65bcf7a132e75a650c44dd2b734",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -80,34 +79,18 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nix2container": {
|
|
||||||
"flake": false,
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1712990762,
|
|
||||||
"narHash": "sha256-hO9W3w7NcnYeX8u8cleHiSpK2YJo7ecarFTUlbybl7k=",
|
|
||||||
"owner": "nlewo",
|
|
||||||
"repo": "nix2container",
|
|
||||||
"rev": "20aad300c925639d5d6cbe30013c8357ce9f2a2e",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "nlewo",
|
|
||||||
"repo": "nix2container",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1718132686,
|
"lastModified": 1703134684,
|
||||||
"narHash": "sha256-JRinkq+FeAkYnrrK8+Bh+jtLHJBN5jDzSimk1ye00EE=",
|
"narHash": "sha256-SQmng1EnBFLzS7WSRyPM9HgmZP2kLJcPAz+Ug/nug6o=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "96b3dae4f8753c1f5ce0d06b57fe250fb5d9b0e0",
|
"rev": "d6863cbcbbb80e71cecfc03356db1cda38919523",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"ref": "nixos-23.11-small",
|
"ref": "nixpkgs-unstable",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
|
@ -160,11 +143,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1718139168,
|
"lastModified": 1702979157,
|
||||||
"narHash": "sha256-1TZQcdETNdJMcfwwoshVeCjwWfrPtkSQ8y8wFX3it7k=",
|
"narHash": "sha256-RnFBbLbpqtn4AoJGXKevQMCGhra4h6G2MPcuTSZZQ+g=",
|
||||||
"owner": "numtide",
|
"owner": "numtide",
|
||||||
"repo": "treefmt-nix",
|
"repo": "treefmt-nix",
|
||||||
"rev": "1cb529bffa880746a1d0ec4e0f5076876af931f1",
|
"rev": "2961375283668d867e64129c22af532de8e77734",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
description = "Hydra's builtin hydra-eval-jobs as a standalone";
|
description = "Hydra's builtin hydra-eval-jobs as a standalone";
|
||||||
|
|
||||||
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.11-small";
|
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
||||||
inputs.flake-parts.url = "github:hercules-ci/flake-parts";
|
inputs.flake-parts.url = "github:hercules-ci/flake-parts";
|
||||||
inputs.flake-parts.inputs.nixpkgs-lib.follows = "nixpkgs";
|
inputs.flake-parts.inputs.nixpkgs-lib.follows = "nixpkgs";
|
||||||
inputs.treefmt-nix.url = "github:numtide/treefmt-nix";
|
inputs.treefmt-nix.url = "github:numtide/treefmt-nix";
|
||||||
|
@ -17,6 +17,7 @@
|
||||||
let
|
let
|
||||||
inherit (inputs.nixpkgs) lib;
|
inherit (inputs.nixpkgs) lib;
|
||||||
inherit (inputs) self;
|
inherit (inputs) self;
|
||||||
|
nixVersion = lib.fileContents ./.nix-version;
|
||||||
in
|
in
|
||||||
flake-parts.lib.mkFlake { inherit inputs; }
|
flake-parts.lib.mkFlake { inherit inputs; }
|
||||||
{
|
{
|
||||||
|
|
|
@ -105,31 +105,26 @@ struct Proc {
|
||||||
// threads we launch here. It turns out, running the evaluator under an anemic stack of
|
// threads we launch here. It turns out, running the evaluator under an anemic stack of
|
||||||
// 0.5MiB has it overflow way too quickly. Hence, we have our own custom Thread struct.
|
// 0.5MiB has it overflow way too quickly. Hence, we have our own custom Thread struct.
|
||||||
struct Thread {
|
struct Thread {
|
||||||
|
std::function<void(void)> func;
|
||||||
pthread_t thread;
|
pthread_t thread;
|
||||||
|
|
||||||
Thread(const Thread &) = delete;
|
Thread(std::function<void(void)> f) : func(f) {
|
||||||
Thread(Thread &&) noexcept = default;
|
|
||||||
|
|
||||||
Thread(std::function<void(void)> f) {
|
|
||||||
int s;
|
int s;
|
||||||
pthread_attr_t attr;
|
pthread_attr_t attr;
|
||||||
|
|
||||||
auto func = std::make_unique<std::function<void(void)>>(std::move(f));
|
|
||||||
|
|
||||||
if ((s = pthread_attr_init(&attr)) != 0) {
|
if ((s = pthread_attr_init(&attr)) != 0) {
|
||||||
throw SysError(s, "calling pthread_attr_init");
|
throw SysError(s, "calling pthread_attr_init");
|
||||||
}
|
}
|
||||||
if ((s = pthread_attr_setstacksize(&attr, 64 * 1024 * 1024)) != 0) {
|
if ((s = pthread_attr_setstacksize(&attr, 64 * 1024 * 1024)) != 0) {
|
||||||
throw SysError(s, "calling pthread_attr_setstacksize");
|
throw SysError(s, "calling pthread_attr_setstacksize");
|
||||||
}
|
}
|
||||||
if ((s = pthread_create(&thread, &attr, Thread::init, func.release())) != 0) {
|
if ((s = pthread_create(&thread, &attr, Thread::init, static_cast<void *>(this))) != 0) {
|
||||||
throw SysError(s, "calling pthread_launch");
|
throw SysError(s, "calling pthread_launch");
|
||||||
}
|
}
|
||||||
if ((s = pthread_attr_destroy(&attr)) != 0) {
|
if ((s = pthread_attr_destroy(&attr)) != 0) {
|
||||||
throw SysError(s, "calling pthread_attr_destroy");
|
throw SysError(s, "calling pthread_attr_destroy");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void join() {
|
void join() {
|
||||||
int s;
|
int s;
|
||||||
s = pthread_join(thread, nullptr);
|
s = pthread_join(thread, nullptr);
|
||||||
|
@ -139,10 +134,8 @@ struct Thread {
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
static void *init(void *ptr) {
|
static void *init(void *ptr) {
|
||||||
std::unique_ptr<std::function<void(void)>> func;
|
Thread *thread = static_cast<Thread *>(ptr);
|
||||||
func.reset(static_cast<std::function<void(void)> *>(ptr));
|
thread->func();
|
||||||
|
|
||||||
(*func)();
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue