Next-generation Nix CI system for clowns
  • Rust 69.7%
  • Nix 20.2%
  • HTML 6.3%
  • PLpgSQL 2%
  • CSS 1.8%
Find a file
NotAShelf 44d1ee1d6b
queue-runner: semaphore-based worker pool with atomic build claiming
Signed-off-by: NotAShelf <raf@notashelf.dev>
Change-Id: Ie3a8d343c3705200f0cac566227db54f6a6a6964
2026-02-02 01:15:07 +03:00
crates queue-runner: semaphore-based worker pool with atomic build claiming 2026-02-02 01:15:07 +03:00
docs docs: highlight Hydra's core issues 2026-02-02 01:15:03 +03:00
.envrc nix: initial tooling setup 2026-02-02 01:14:58 +03:00
.gitignore initial commit 2026-02-02 01:14:56 +03:00
Cargo.lock common: initial database handling 2026-02-02 01:15:01 +03:00
Cargo.toml common: initial database handling 2026-02-02 01:15:01 +03:00
flake.lock nix: initial tooling setup 2026-02-02 01:14:58 +03:00
flake.nix nix: build migrate-cli crate 2026-02-02 01:15:04 +03:00
README.md docs: add very basic README 2026-02-02 01:14:57 +03:00

FC

FC is a modern, Rust-based continuous integration system designed to replace Hydra for our systems. Heavily work in progress.

Architecture

  • server: Web API and UI (Axum)
  • evaluator: Git polling and Nix evaluation
  • queue-runner: Build dispatch and execution
  • common: Shared types and utilities

Development

nix develop
cargo build

Components

Server

Web API server providing REST endpoints for project management, jobsets, and build status.

Evaluator

Periodically polls Git repositories and evaluates Nix expressions to create builds.

Queue Runner

Processes build queue and executes Nix builds on available machines.