git clone https://github.com/hyperpolymath/docmatrix.git cd docmatrix
nix develop
toolbox create docmatrix-dev toolbox enter docmatrix-dev
just check # or: cargo check / mix compile / etc. just test # Run test suite
### Repository Structure
docmatrix/ βββ src/ # Source code (Perimeter 1-2) βββ lib/ # Library code (Perimeter 1-2) βββ extensions/ # Extensions (Perimeter 2) βββ plugins/ # Plugins (Perimeter 2) βββ tools/ # Tooling (Perimeter 2) βββ docs/ # Documentation (Perimeter 3) β βββ architecture/ # ADRs, specs (Perimeter 2) β βββ proposals/ # RFCs (Perimeter 3) βββ examples/ # Examples (Perimeter 3) βββ spec/ # Spec tests (Perimeter 3) βββ tests/ # Test suite (Perimeter 2-3) βββ .well-known/ # Protocol files (Perimeter 1-3) βββ .github/ # GitHub config (Perimeter 1) β βββ ISSUE_TEMPLATE/ β βββ workflows/ βββ CHANGELOG.md βββ CODE_OF_CONDUCT.md βββ CONTRIBUTING.md # This file βββ GOVERNANCE.md βββ LICENSE βββ MAINTAINERS.md βββ README.adoc βββ SECURITY.md βββ flake.nix # Nix flake (Perimeter 1) βββ justfile # Task runner (Perimeter 1)
---
## How to Contribute
### Reporting Bugs
**Before reporting**:
1. Search existing issues
2. Check if it's already fixed in `main`
3. Determine which perimeter the bug affects
**When reporting**:
Use the [bug report template](.github/ISSUE_TEMPLATE/bug_report.md) and include:
- Clear, descriptive title
- Environment details (OS, versions, toolchain)
- Steps to reproduce
- Expected vs actual behaviour
- Logs, screenshots, or minimal reproduction
### Suggesting Features
**Before suggesting**:
1. Check the [roadmap](ROADMAP.md) if available
2. Search existing issues and discussions
3. Consider which perimeter the feature belongs to
**When suggesting**:
Use the [feature request template](.github/ISSUE_TEMPLATE/feature_request.md) and include:
- Problem statement (what pain point does this solve?)
- Proposed solution
- Alternatives considered
- Which perimeter this affects
### Your First Contribution
Look for issues labelled:
- [`good first issue`](https://github.com/hyperpolymath/docmatrix/labels/good%20first%20issue) β Simple Perimeter 3 tasks
- [`help wanted`](https://github.com/hyperpolymath/docmatrix/labels/help%20wanted) β Community help needed
- [`documentation`](https://github.com/hyperpolymath/docmatrix/labels/documentation) β Docs improvements
- [`perimeter-3`](https://github.com/hyperpolymath/docmatrix/labels/perimeter-3) β Community sandbox scope
---
## Development Workflow
### Branch Naming
docs/short-description # Documentation (P3) test/what-added # Test additions (P3) feat/short-description # New features (P2) fix/issue-number-description # Bug fixes (P2) refactor/what-changed # Code improvements (P2) security/what-fixed # Security fixes (P1-2)
### Commit Messages
We follow [Conventional Commits](https://www.conventionalcommits.org/):
():
[optional body]
[optional footer]