Skip to content

Commit cc88913

Browse files
hyperpolymathclaude
andcommitted
chore: add UX infrastructure (quickstart, doctor, setup)
Added by ux-rollout.jl batch script. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
1 parent dea46e4 commit cc88913

7 files changed

Lines changed: 335 additions & 0 deletions

File tree

Justfile

Lines changed: 112 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -459,3 +459,115 @@ build-riscv:
459459
# Run panic-attacker pre-commit scan
460460
assail:
461461
@command -v panic-attack >/dev/null 2>&1 && panic-attack assail . || echo "panic-attack not found — install from https://github.com/hyperpolymath/panic-attacker"
462+
463+
# ═══════════════════════════════════════════════════════════════════════════════
464+
# ONBOARDING & DIAGNOSTICS
465+
# ═══════════════════════════════════════════════════════════════════════════════
466+
467+
# Check all required toolchain dependencies and report health
468+
doctor:
469+
#!/usr/bin/env bash
470+
echo "═══════════════════════════════════════════════════"
471+
echo " Docmatrix Doctor — Toolchain Health Check"
472+
echo "═══════════════════════════════════════════════════"
473+
echo ""
474+
PASS=0; FAIL=0; WARN=0
475+
check() {
476+
local name="$1" cmd="$2" min="$3"
477+
if command -v "$cmd" >/dev/null 2>&1; then
478+
VER=$("$cmd" --version 2>&1 | head -1)
479+
echo " [OK] $name — $VER"
480+
PASS=$((PASS + 1))
481+
else
482+
echo " [FAIL] $name — not found (need $min+)"
483+
FAIL=$((FAIL + 1))
484+
fi
485+
}
486+
check "just" just "1.25"
487+
check "git" git "2.40"
488+
check "Rust (cargo)" cargo "1.80"
489+
check "Zig" zig "0.13"
490+
# Optional tools
491+
if command -v panic-attack >/dev/null 2>&1; then
492+
echo " [OK] panic-attack — available"
493+
PASS=$((PASS + 1))
494+
else
495+
echo " [WARN] panic-attack — not found (pre-commit scanner)"
496+
WARN=$((WARN + 1))
497+
fi
498+
echo ""
499+
echo " Result: $PASS passed, $FAIL failed, $WARN warnings"
500+
if [ "$FAIL" -gt 0 ]; then
501+
echo " Run 'just heal' to attempt automatic repair."
502+
exit 1
503+
fi
504+
echo " All required tools present."
505+
506+
# Attempt to automatically install missing tools
507+
heal:
508+
#!/usr/bin/env bash
509+
echo "═══════════════════════════════════════════════════"
510+
echo " Docmatrix Heal — Automatic Tool Installation"
511+
echo "═══════════════════════════════════════════════════"
512+
echo ""
513+
if ! command -v cargo >/dev/null 2>&1; then
514+
echo "Installing Rust via rustup..."
515+
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
516+
source "$HOME/.cargo/env"
517+
fi
518+
if ! command -v just >/dev/null 2>&1; then
519+
echo "Installing just..."
520+
cargo install just 2>/dev/null || echo "Install just from https://just.systems"
521+
fi
522+
echo ""
523+
echo "Heal complete. Run 'just doctor' to verify."
524+
525+
# Guided tour of the project structure and key concepts
526+
tour:
527+
#!/usr/bin/env bash
528+
echo "═══════════════════════════════════════════════════"
529+
echo " Docmatrix — Guided Tour"
530+
echo "═══════════════════════════════════════════════════"
531+
echo ""
532+
echo '// SPDX-License-Identifier: MPL-2.0-or-later'
533+
echo ""
534+
echo "Key directories:"
535+
echo " src/ Source code"
536+
echo " ffi/ Foreign function interface (Zig)"
537+
echo " src/abi/ Idris2 ABI definitions"
538+
echo " docs/ Documentation"
539+
echo " .github/workflows/ CI/CD workflows"
540+
echo " contractiles/ Must/Trust/Dust contracts"
541+
echo " .machine_readable/ Machine-readable metadata"
542+
echo " container/ Container configuration"
543+
echo " examples/ Usage examples"
544+
echo ""
545+
echo "Quick commands:"
546+
echo " just doctor Check toolchain health"
547+
echo " just heal Fix missing tools"
548+
echo " just help-me Common workflows"
549+
echo " just default List all recipes"
550+
echo ""
551+
echo "Read more: README.adoc, EXPLAINME.adoc"
552+
553+
# Show help for common workflows
554+
help-me:
555+
#!/usr/bin/env bash
556+
echo "═══════════════════════════════════════════════════"
557+
echo " Docmatrix — Common Workflows"
558+
echo "═══════════════════════════════════════════════════"
559+
echo ""
560+
echo "FIRST TIME SETUP:"
561+
echo " just doctor Check toolchain"
562+
echo " just heal Fix missing tools"
563+
echo ""
564+
echo "DEVELOPMENT:"
565+
echo " cargo build Build the project"
566+
echo " cargo test Run tests"
567+
echo ""
568+
echo "PRE-COMMIT:"
569+
echo " just assail Run panic-attacker scan"
570+
echo ""
571+
echo "LEARN:"
572+
echo " just tour Guided project tour"
573+
echo " just default List all recipes"

QUICKSTART-DEV.adoc

Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
= Docmatrix — Developer Quickstart
2+
:toc: preamble
3+
4+
Clone, build, test, contribute.
5+
6+
== Prerequisites
7+
8+
* Git 2.40+
9+
* just (command runner)
10+
* See `just doctor` output for language-specific requirements
11+
12+
== Setup
13+
14+
[source,bash]
15+
----
16+
git clone https://github.com/hyperpolymath/docmatrix
17+
cd docmatrix
18+
just doctor # verify toolchain
19+
just heal # auto-install missing tools
20+
----
21+
22+
== Development Workflow
23+
24+
[source,bash]
25+
----
26+
just tour # understand the codebase
27+
just help-me # see available commands
28+
----
29+
30+
== Before Committing
31+
32+
[source,bash]
33+
----
34+
just assail # run panic-attacker security scan
35+
----
36+
37+
== Contributing
38+
39+
See link:CONTRIBUTING.md[CONTRIBUTING.md] for guidelines.

QUICKSTART-MAINTAINER.adoc

Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
= Docmatrix — Maintainer Quickstart
2+
:toc: preamble
3+
4+
Packaging, deployment, and release management.
5+
6+
== Prerequisites
7+
8+
* Git 2.40+
9+
* just (command runner)
10+
* Familiarity with the project (run `just tour` first)
11+
12+
== CI/CD
13+
14+
This project uses GitHub Actions. Workflows are in `.github/workflows/`.
15+
16+
Key workflows:
17+
18+
* `hypatia-scan.yml` — Neurosymbolic security scanning
19+
* `codeql.yml` — Code analysis
20+
* `scorecard.yml` — OpenSSF Scorecard
21+
* `mirror.yml` — GitLab/Bitbucket mirroring
22+
23+
== Releasing
24+
25+
1. Update version in project config
26+
2. Update CHANGELOG.md
27+
3. Tag: `git tag -s v<VERSION>`
28+
4. Push: `git push origin main --tags`
29+
30+
== Container Build (if applicable)
31+
32+
[source,bash]
33+
----
34+
podman build -f Containerfile -t docmatrix:latest .
35+
----
36+
37+
== Mirrors
38+
39+
This repo is mirrored to GitLab and Bitbucket (hyperpolymath accounts)
40+
via the `mirror.yml` workflow.

QUICKSTART-USER.adoc

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
= Docmatrix — User Quickstart
2+
:toc: preamble
3+
4+
Get up and running in 60 seconds.
5+
6+
== Prerequisites
7+
8+
* Git 2.40+
9+
* just (command runner) — https://just.systems
10+
11+
== Install
12+
13+
[source,bash]
14+
----
15+
git clone https://github.com/hyperpolymath/docmatrix
16+
cd docmatrix
17+
just doctor # check toolchain
18+
just heal # auto-install missing tools
19+
----
20+
21+
== First Run
22+
23+
[source,bash]
24+
----
25+
just tour # guided project tour
26+
just help-me # see common workflows
27+
----
28+
29+
== Get Help
30+
31+
* `just help-me` — common workflows
32+
* `just doctor` — diagnose toolchain issues
33+
* https://github.com/hyperpolymath/docmatrix/issues — report bugs
Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
# SPDX-License-Identifier: PMPL-1.0-or-later
2+
# Intentfile (A2ML Canonical)
3+
# Copyright (c) 2026 Jonathan D.A. Jewell (hyperpolymath)
4+
5+
@abstract:
6+
Declared intent and purpose for Docmatrix.
7+
@end
8+
9+
## Purpose
10+
11+
Docmatrix — // SPDX-License-Identifier: MPL-2.0-or-later
12+
13+
## Anti-Purpose
14+
15+
This project is NOT:
16+
- A fork or wrapper around another tool
17+
- A monorepo (unless explicitly structured as one)
18+
19+
## If In Doubt
20+
21+
If you are unsure whether a change is in scope, ask.
22+
Sensitive areas: ABI definitions, license headers, CI workflows.

contractiles/trust/Trustfile.a2ml

Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
# SPDX-License-Identifier: PMPL-1.0-or-later
2+
# Trustfile (A2ML Canonical)
3+
# Copyright (c) 2026 Jonathan D.A. Jewell (hyperpolymath)
4+
5+
@abstract:
6+
Trust and provenance verification for Docmatrix.
7+
Maximal trust by default — LLM may read, build, test, lint, format.
8+
@end
9+
10+
@trust-level: maximal
11+
@trust-boundary: repo
12+
@trust-actions: [read, build, test, lint, format]
13+
@trust-deny: [delete-branch, force-push, modify-ci-secrets, publish]
14+
15+
## Integrity
16+
17+
### license-content
18+
- description: LICENSE contains expected SPDX identifier
19+
- run: grep -q 'SPDX\|License\|MIT\|Apache\|PMPL\|MPL' LICENSE
20+
- severity: critical
21+
22+
### no-secrets-committed
23+
- description: No .env or credential files in repo
24+
- run: test ! -f .env && test ! -f credentials.json && test ! -f .env.local
25+
- severity: critical

setup.sh

Lines changed: 64 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
#!/usr/bin/env bash
2+
# SPDX-License-Identifier: PMPL-1.0-or-later
3+
# Copyright (c) 2026 Jonathan D.A. Jewell (hyperpolymath)
4+
#
5+
# Docmatrix — Universal Setup Script
6+
# Detects platform and shell, installs just, then hands off to Justfile.
7+
8+
set -euo pipefail
9+
10+
echo "═══════════════════════════════════════════════════"
11+
echo " Docmatrix — Setup"
12+
echo "═══════════════════════════════════════════════════"
13+
echo ""
14+
15+
# Platform detection
16+
OS="$(uname -s)"
17+
ARCH="$(uname -m)"
18+
echo "Platform: $OS $ARCH"
19+
20+
# Shell detection
21+
CURRENT_SHELL="$(basename "$SHELL" 2>/dev/null || echo "unknown")"
22+
echo "Shell: $CURRENT_SHELL"
23+
echo ""
24+
25+
# Check for just
26+
if ! command -v just >/dev/null 2>&1; then
27+
echo "just (command runner) is required but not installed."
28+
echo ""
29+
case "$OS" in
30+
Linux)
31+
if command -v cargo >/dev/null 2>&1; then
32+
echo "Installing just via cargo..."
33+
cargo install just
34+
elif command -v brew >/dev/null 2>&1; then
35+
echo "Installing just via Homebrew..."
36+
brew install just
37+
else
38+
echo "Install just from: https://just.systems/man/en/installation.html"
39+
exit 1
40+
fi
41+
;;
42+
Darwin)
43+
if command -v brew >/dev/null 2>&1; then
44+
echo "Installing just via Homebrew..."
45+
brew install just
46+
else
47+
echo "Install Homebrew first: https://brew.sh"
48+
echo "Then: brew install just"
49+
exit 1
50+
fi
51+
;;
52+
*)
53+
echo "Install just from: https://just.systems/man/en/installation.html"
54+
exit 1
55+
;;
56+
esac
57+
echo ""
58+
fi
59+
60+
echo "Running diagnostics..."
61+
just doctor
62+
63+
echo ""
64+
echo "Setup complete. Run 'just help-me' for common workflows."

0 commit comments

Comments
 (0)