speckit-constitution
Scannednpx machina-cli add skill dceoy/speckit-agent-skills/speckit-constitution --openclawSpec Kit Constitution Skill
When to Use
- Initial project setup or when governance principles need updates.
Inputs
- User-provided principles or amendments.
- Existing
.specify/memory/constitution.mdand templates.
If the request is missing or ambiguous, ask focused questions before proceeding.
Workflow
You are updating the project constitution at .specify/memory/constitution.md. 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.
Follow this execution flow:
-
Load the existing constitution template at
.specify/memory/constitution.md.- 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
.specify/templates/plan-template.mdand ensure any "Constitution Check" or rules align with updated principles. - Read
.specify/templates/spec-template.mdfor scope/requirements alignment—update if constitution adds/removes mandatory sections or constraints. - Read
.specify/templates/tasks-template.mdand ensure task categorization reflects new or removed principle-driven task types (e.g., observability, versioning, testing discipline). - Review runtime prompts/agents for outdated references and align with updated principles:
.claude/commands/speckit.*.md.codex/prompts/speckit.*.md.gemini/commands/speckit.*.toml.github/prompts/speckit.*.prompt.md.github/agents/speckit.*.agent.mdskills/speckit-*/SKILL.md
- Read any runtime guidance docs (e.g.,
README.md,docs/quickstart.md, or agent-specific guidance files if present). Update references to principles changed.
- Read
-
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
.specify/memory/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 .specify/memory/constitution.md file.
Outputs
- Updated
.specify/memory/constitution.md(with Sync Impact Report comment) - Any updated templates or runtime guidance files required to stay consistent with the constitution
Next Steps
After updating the constitution:
- Specify new features with speckit-specify.
Source
git clone https://github.com/dceoy/speckit-agent-skills/blob/main/skills/speckit-constitution/SKILL.mdView on GitHub Overview
This skill updates the project constitution stored at .specify/memory/constitution.md using user-provided principles or amendments. It fills placeholder tokens like [PROJECT_NAME] and [PRINCIPLE_X_NAME], increments CONSTITUTION_VERSION per semantic rules, and propagates changes to dependent templates and runtime artifacts to keep governance aligned.
How This Skill Works
The skill loads the existing constitution.md, identifies placeholders of the form [ALL_CAPS_IDENTIFIER], and gathers values from user input or repo context (including RATIFICATION_DATE and LAST_AMENDED_DATE). It fills placeholders precisely, increments CONSTITUTION_VERSION according to semantic versioning, and propagates amendments across dependent Artifacts and templates, producing a Sync Impact Report to document changes.
When to Use It
- Initial project setup or governance principles updates.
- Amending or adding governance principles.
- Re-syncing dependent templates after constitution changes.
- Preparing governance reviews or audits.
- When placeholders or versioning must be synchronized across artifacts.
Quick Start
- Step 1: Load the existing constitution at .specify/memory/constitution.md and scan for [ALL_CAPS_IDENTIFIER] placeholders.
- Step 2: Gather concrete values from user input or repo context (including RATIFICATION_DATE, LAST_AMENDED_DATE) and determine CONSTITUTION_VERSION increment.
- Step 3: Replace all placeholders with concrete text, propagate updates to dependent templates and prompts, and generate a Sync Impact Report.
Best Practices
- Load the existing constitution.md first and identify all [ALL_CAPS_IDENTIFIER] placeholders.
- Follow semantic versioning: MAJOR for removals/redefinitions, MINOR for new sections, PATCH for wording/clarifications.
- Collect concrete values from user input or repo context and fill every placeholder.
- Propagate amendments to dependent artifacts and runtime prompts as part of the sync.
- Generate and attach a Sync Impact Report with version changes and template updates.
Example Use Cases
- Add a new principle on data privacy and update all related placeholders across .specify/memory/constitution.md and plan-template.md.
- Rename a principle to 'Data Ownership' and update titles and references in templates.
- Amend RATIFICATION_DATE after a governance vote and set LAST_AMENDED_DATE to today; bump version accordingly.
- Remove an obsolete principle and ensure dependent specs and tasks templates no longer require it.
- Sync changes to runtime prompts and docs across .specify/templates, README, and GitHub prompt files.