Skip to content

Commit 6398ec1

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 edf54b8 commit 6398ec1

File tree

8 files changed

+364
-0
lines changed

8 files changed

+364
-0
lines changed

Justfile

Lines changed: 99 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -907,3 +907,102 @@ maint-assault:
907907
# Run panic-attacker pre-commit scan
908908
assail:
909909
@command -v panic-attack >/dev/null 2>&1 && panic-attack assail . || echo "panic-attack not found — install from https://github.com/hyperpolymath/panic-attacker"
910+
911+
# ═══════════════════════════════════════════════════════════════════════════════
912+
# ONBOARDING & DIAGNOSTICS
913+
# ═══════════════════════════════════════════════════════════════════════════════
914+
915+
# Check all required toolchain dependencies and report health
916+
doctor:
917+
#!/usr/bin/env bash
918+
echo "═══════════════════════════════════════════════════"
919+
echo " A2Ml Pre Commit Doctor — Toolchain Health Check"
920+
echo "═══════════════════════════════════════════════════"
921+
echo ""
922+
PASS=0; FAIL=0; WARN=0
923+
check() {
924+
local name="$1" cmd="$2" min="$3"
925+
if command -v "$cmd" >/dev/null 2>&1; then
926+
VER=$("$cmd" --version 2>&1 | head -1)
927+
echo " [OK] $name — $VER"
928+
PASS=$((PASS + 1))
929+
else
930+
echo " [FAIL] $name — not found (need $min+)"
931+
FAIL=$((FAIL + 1))
932+
fi
933+
}
934+
check "just" just "1.25"
935+
check "git" git "2.40"
936+
# Optional tools
937+
if command -v panic-attack >/dev/null 2>&1; then
938+
echo " [OK] panic-attack — available"
939+
PASS=$((PASS + 1))
940+
else
941+
echo " [WARN] panic-attack — not found (pre-commit scanner)"
942+
WARN=$((WARN + 1))
943+
fi
944+
echo ""
945+
echo " Result: $PASS passed, $FAIL failed, $WARN warnings"
946+
if [ "$FAIL" -gt 0 ]; then
947+
echo " Run 'just heal' to attempt automatic repair."
948+
exit 1
949+
fi
950+
echo " All required tools present."
951+
952+
# Attempt to automatically install missing tools
953+
heal:
954+
#!/usr/bin/env bash
955+
echo "═══════════════════════════════════════════════════"
956+
echo " A2Ml Pre Commit Heal — Automatic Tool Installation"
957+
echo "═══════════════════════════════════════════════════"
958+
echo ""
959+
if ! command -v just >/dev/null 2>&1; then
960+
echo "Installing just..."
961+
cargo install just 2>/dev/null || echo "Install just from https://just.systems"
962+
fi
963+
echo ""
964+
echo "Heal complete. Run 'just doctor' to verify."
965+
966+
# Guided tour of the project structure and key concepts
967+
tour:
968+
#!/usr/bin/env bash
969+
echo "═══════════════════════════════════════════════════"
970+
echo " A2Ml Pre Commit — Guided Tour"
971+
echo "═══════════════════════════════════════════════════"
972+
echo ""
973+
echo '**Pre-commit hook for validating A2ML manifest files.**'
974+
echo ""
975+
echo "Key directories:"
976+
echo " src/ Source code"
977+
echo " docs/ Documentation"
978+
echo " tests/ Test suite"
979+
echo " .github/workflows/ CI/CD workflows"
980+
echo " .machine_readable/ Machine-readable metadata"
981+
echo " container/ Container configuration"
982+
echo " examples/ Usage examples"
983+
echo ""
984+
echo "Quick commands:"
985+
echo " just doctor Check toolchain health"
986+
echo " just heal Fix missing tools"
987+
echo " just help-me Common workflows"
988+
echo " just default List all recipes"
989+
echo ""
990+
echo "Read more: README.adoc, EXPLAINME.adoc"
991+
992+
# Show help for common workflows
993+
help-me:
994+
#!/usr/bin/env bash
995+
echo "═══════════════════════════════════════════════════"
996+
echo " A2Ml Pre Commit — Common Workflows"
997+
echo "═══════════════════════════════════════════════════"
998+
echo ""
999+
echo "FIRST TIME SETUP:"
1000+
echo " just doctor Check toolchain"
1001+
echo " just heal Fix missing tools"
1002+
echo ""
1003+
echo "PRE-COMMIT:"
1004+
echo " just assail Run panic-attacker scan"
1005+
echo ""
1006+
echo "LEARN:"
1007+
echo " just tour Guided project tour"
1008+
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+
= A2Ml Pre Commit — 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/a2ml-pre-commit
17+
cd a2ml-pre-commit
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+
= A2Ml Pre Commit — 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 a2ml-pre-commit: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+
= A2Ml Pre Commit — 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/a2ml-pre-commit
16+
cd a2ml-pre-commit
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/a2ml-pre-commit/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 A2Ml Pre Commit.
7+
@end
8+
9+
## Purpose
10+
11+
A2Ml Pre Commit — **Pre-commit hook for validating A2ML manifest files.**
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/must/Mustfile.a2ml

Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
# SPDX-License-Identifier: PMPL-1.0-or-later
2+
# Mustfile (A2ML Canonical)
3+
# Copyright (c) 2026 Jonathan D.A. Jewell (hyperpolymath)
4+
5+
@abstract:
6+
Physical State contract for A2Ml Pre Commit. Baseline UX Manifesto invariants
7+
that MUST hold at all times.
8+
@end
9+
10+
@requires:
11+
- section: Core-Files
12+
- section: Banned
13+
@end
14+
15+
## Core-Files
16+
17+
### license-present
18+
- description: LICENSE file must exist
19+
- run: test -f LICENSE
20+
- severity: critical
21+
22+
### readme-present
23+
- description: README must exist
24+
- run: test -f README.adoc || test -f README.md
25+
- severity: critical
26+
27+
## Banned
28+
29+
### no-hardcoded-paths
30+
- description: No hardcoded developer paths
31+
- run: "! grep -rn '/home/hyper\|/mnt/eclipse' --include='*.rs' --include='*.res' --include='*.ex' --include='*.gleam' --include='*.zig' --include='*.sh' . 2>/dev/null | grep -v '.git/' | grep -v 'ux-rollout.jl' | head -1"
32+
- severity: critical
33+
34+
### no-dockerfiles
35+
- description: No Dockerfiles (use Containerfile)
36+
- run: test ! -f Dockerfile
37+
- severity: warning
38+
39+
### no-makefiles
40+
- description: No Makefiles (use Justfile)
41+
- run: test ! -f Makefile
42+
- severity: warning

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 A2Ml Pre Commit.
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+
# A2Ml Pre Commit — 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 " A2Ml Pre Commit — 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)