Thank you for your interest in contributing! We follow a "Dual-Track" architecture where human-readable documentation lives in the root and machine-readable policies live in .machine_readable/.
We welcome contributions in many forms:
- Code: Improving the core stack or extensions
- Documentation: Enhancing docs or AI manifests
- Testing: Adding property-based tests or formal proofs
- Bug reports: Filing clear, reproducible issues
quicer (the QUIC transport library used by Burble's server) builds msquic from
source. This requires several system packages that are not pre-installed on a
vanilla developer machine. Install them before running just test or mix deps.get.
sudo apt-get update
sudo apt-get install -y cmake perl build-essential libssl-devsudo dnf install -y cmake perl-FindBin make gcc openssl-develapk add --no-cache cmake perl make gcc musl-dev openssl-dev| Prerequisite | Debian 12 / Ubuntu 24.04 | Fedora 40 | Wolfi |
|---|---|---|---|
| Perl + FindBin | perl (core) |
perl-FindBin |
perl |
| CMake ≥ 3.20 | cmake |
cmake |
cmake |
| C compiler + Make | build-essential |
make + gcc |
make + gcc + musl-dev |
| OpenSSL headers | libssl-dev |
openssl-devel |
openssl-dev |
| Erlang/OTP 27 | via setup-beam / kerl |
same | same |
Run the guard scripts to confirm all prerequisites are present before spending
time on a full mix deps.get:
just guard-quicer-prereqs # checks perl, cmake, make/ninja
just guard-msquic # checks msquic is at the required tag (v2.3.8)If either guard fails, it will print which package is missing.
just doctor also reports whether cmake, perl, and make are on PATH.
- Read the AI Manifest: Start with
0-AI-MANIFEST.a2ml(if present) to understand the repository structure. - Install system prerequisites: Follow the "Building from source" section above for your distro.
- Environment: Use
nix developordirenv allowto set up your tools. - Task Runner: Use
justto see available commands (just --list).
docs/short-description # Documentation
test/what-added # Test additions
feat/short-description # New features
fix/issue-number-description # Bug fixes
refactor/what-changed # Code improvements
security/what-fixed # Security fixes
We follow Conventional Commits:
<type>(<scope>): <description>
[optional body]
[optional footer]
Types: feat, fix, docs, test, refactor, ci, chore, security
Before reporting:
- Search existing issues
- Check if it's already fixed in
main
When reporting, include:
- Clear, descriptive title
- Environment details (OS, versions, toolchain)
- Steps to reproduce
- Expected vs actual behaviour
All contributors are expected to adhere to our Code of Conduct.
By contributing, you agree that your contributions will be licensed under the same license as the project (see LICENSE).