bb-constitution
User Input
$ARGUMENTS
You MUST consider the user input before proceeding (if not empty).
Outline
You are updating the project constitution at constitution.md (located in the project root or docs/ directory). This file is a TEMPLATE containing placeholder tokens in square brackets (e.g. [PROJECT_NAME], [PRINCIPLE_1_NAME]). Your job is to (a) collect/derive concrete values, (b) fill the template precisely, and (c) propagate any amendments across dependent artifacts.
Note: If constitution.md does not exist yet, create it using the template structure defined below.
Constitution Template Structure
When creating a new constitution, use this structure:
# [PROJECT_NAME] Constitution
## Core Principles
### [PRINCIPLE_1_NAME]
[PRINCIPLE_1_DESCRIPTION]
### [PRINCIPLE_2_NAME]
[PRINCIPLE_2_DESCRIPTION]
### [PRINCIPLE_3_NAME]
[PRINCIPLE_3_DESCRIPTION]
### [PRINCIPLE_4_NAME]
[PRINCIPLE_4_DESCRIPTION]
### [PRINCIPLE_5_NAME]
[PRINCIPLE_5_DESCRIPTION]
## [SECTION_2_NAME]
[SECTION_2_CONTENT]
## [SECTION_3_NAME]
[SECTION_3_CONTENT]
## Governance
[GOVERNANCE_RULES]
**Version**: [CONSTITUTION_VERSION] | **Ratified**: [RATIFICATION_DATE] | **Last Amended**: [LAST_AMENDED_DATE]
- Core Principles: Each principle gets a succinct name and a description capturing non-negotiable rules with explicit rationale.
- Additional Sections: Use for constraints, security requirements, performance standards, development workflow, review process, quality gates, etc.
- Governance: Amendment procedure, versioning policy, compliance review expectations.
- The number of principles is flexible -- add or remove as needed based on user input.
Follow this execution flow:
-
Load the existing constitution at
constitution.md(check project root, thendocs/directory).- Identify every placeholder token of the form
[ALL_CAPS_IDENTIFIER]. IMPORTANT: The user might require less or more principles than the ones used in the template. If a number is specified, respect that - follow the general template. You will update the doc accordingly.
- Identify every placeholder token of the form
-
Collect/derive values for placeholders:
- If user input (conversation) supplies a value, use it.
- Otherwise infer from existing repo context (README, docs, prior constitution versions if embedded).
- For governance dates:
RATIFICATION_DATEis the original adoption date (if unknown ask or mark TODO),LAST_AMENDED_DATEis today if changes are made, otherwise keep previous. CONSTITUTION_VERSIONmust increment according to semantic versioning rules:- MAJOR: Backward incompatible governance/principle removals or redefinitions.
- MINOR: New principle/section added or materially expanded guidance.
- PATCH: Clarifications, wording, typo fixes, non-semantic refinements.
- If version bump type ambiguous, propose reasoning before finalizing.
-
Draft the updated constitution content:
- Replace every placeholder with concrete text (no bracketed tokens left except intentionally retained template slots that the project has chosen not to define yet -- explicitly justify any left).
- Preserve heading hierarchy and comments can be removed once replaced unless they still add clarifying guidance.
- Ensure each Principle section: succinct name line, paragraph (or bullet list) capturing non-negotiable rules, explicit rationale if not obvious.
- Ensure Governance section lists amendment procedure, versioning policy, and compliance review expectations.
-
Consistency propagation checklist (convert prior checklist into active validations):
- Read plan template and ensure any "Constitution Check" or rules align with updated principles.
- Read spec template for scope/requirements alignment -- update if constitution adds/removes mandatory sections or constraints.
- Read tasks template and ensure task categorization reflects new or removed principle-driven task types (e.g., observability, versioning, testing discipline).
- Read each command/skill template to verify no outdated references remain when generic guidance is required.
- Read any runtime guidance docs (e.g.,
README.md,docs/quickstart.md, or agent-specific guidance files if present). Update references to principles changed.
-
Produce a Sync Impact Report (prepend as an HTML comment at top of the constitution file after update):
- Version change: old -> new
- List of modified principles (old title -> new title if renamed)
- Added sections
- Removed sections
- Templates requiring updates (updated / pending) with file paths
- Follow-up TODOs if any placeholders intentionally deferred.
-
Validation before final output:
- No remaining unexplained bracket tokens.
- Version line matches report.
- Dates ISO format YYYY-MM-DD.
- Principles are declarative, testable, and free of vague language ("should" -> replace with MUST/SHOULD rationale where appropriate).
-
Write the completed constitution back to
constitution.md(overwrite). -
Output a final summary to the user with:
- New version and bump rationale.
- Any files flagged for manual follow-up.
- Suggested commit message (e.g.,
docs: amend constitution to vX.Y.Z (principle additions + governance update)).
Formatting & Style Requirements:
- Use Markdown headings exactly as in the template (do not demote/promote levels).
- Wrap long rationale lines to keep readability (<100 chars ideally) but do not hard enforce with awkward breaks.
- Keep a single blank line between sections.
- Avoid trailing whitespace.
If the user supplies partial updates (e.g., only one principle revision), still perform validation and version decision steps.
If critical info missing (e.g., ratification date truly unknown), insert TODO(<FIELD_NAME>): explanation and include in the Sync Impact Report under deferred items.
Do not create a new template; always operate on the existing constitution.md file.
More from buildbetter-app/bb-skills
trust-but-verify
Use when a feature branch has been implemented and you need to verify the UI/UX and functionality match the original plan before merging
11bb-analyze
Perform a non-destructive cross-artifact consistency and quality analysis across spec.md, plan.md, and tasks.md after task generation.
11bb-review
Run a BuildBetter-first UX/usability and/or code review for the current feature.
10bb-plan
Execute the implementation planning workflow using the plan template to generate design artifacts.
9bb-tasks
Generate an actionable, dependency-ordered tasks.md for the feature based on available design artifacts.
9bb-checklist
Generate a custom checklist for the current feature based on user requirements.
9