diff --git a/README.md b/README.md index fa48a86..40f3cee 100644 --- a/README.md +++ b/README.md @@ -8,6 +8,8 @@ An effort to allow organizations to focus on product scenarios rather than writing undifferentiated code with the help of Spec-Driven Development.

+[![Release](https://github.com/github/spec-kit/actions/workflows/release.yml/badge.svg)](https://github.com/github/spec-kit/actions/workflows/release.yml) + --- ## Table of Contents @@ -205,7 +207,7 @@ At this stage, your project folder contents should resemble the following: │ ├── setup-plan.sh │ └── update-claude-md.sh ├── specs -│ └── 002-create-taskify +│ └── 001-create-taskify │ └── spec.md └── templates ├── CLAUDE-template.md @@ -258,7 +260,7 @@ The output of this step will include a number of implementation detail documents │ ├── setup-plan.sh │ └── update-claude-md.sh ├── specs -│ └── 002-create-taskify +│ └── 001-create-taskify │ ├── contracts │ │ ├── api-spec.json │ │ └── signalr-spec.md @@ -346,7 +348,7 @@ Once the implementation step is done, ask Claude Code to try to run the applicat If you're having issues with Git authentication on Linux, you can install Git Credential Manager: ```bash -#!/bin/bash +#!/usr/bin/env bash set -e echo "Downloading Git Credential Manager v2.6.1..." wget https://github.com/git-ecosystem/git-credential-manager/releases/download/v2.6.1/gcm-linux_amd64.2.6.1.deb @@ -361,6 +363,7 @@ rm gcm-linux_amd64.2.6.1.deb ## Maintainers - Den Delimarsky ([@localden](https://github.com/localden)) +- John Lam ([@jflam](https://github.com/jflam)) ## Support diff --git a/scripts/check-task-prerequisites.sh b/scripts/check-task-prerequisites.sh old mode 100644 new mode 100755 index 87fca37..b692fcd --- a/scripts/check-task-prerequisites.sh +++ b/scripts/check-task-prerequisites.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Check that implementation plan exists and find optional design documents # Usage: ./check-task-prerequisites.sh [--json] diff --git a/scripts/common.sh b/scripts/common.sh old mode 100644 new mode 100755 index d636491..310ce4e --- a/scripts/common.sh +++ b/scripts/common.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Common functions and variables for all scripts # Get repository root diff --git a/scripts/create-new-feature.sh b/scripts/create-new-feature.sh old mode 100644 new mode 100755 index 69ea3c4..3cd43b9 --- a/scripts/create-new-feature.sh +++ b/scripts/create-new-feature.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Create a new feature with branch, directory structure, and template # Usage: ./create-new-feature.sh "feature description" # ./create-new-feature.sh --json "feature description" diff --git a/scripts/get-feature-paths.sh b/scripts/get-feature-paths.sh old mode 100644 new mode 100755 index bfe5087..b1e1fbc --- a/scripts/get-feature-paths.sh +++ b/scripts/get-feature-paths.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Get paths for current feature branch without creating anything # Used by commands that need to find existing feature files diff --git a/scripts/setup-plan.sh b/scripts/setup-plan.sh old mode 100644 new mode 100755 index 28bd056..ea0e023 --- a/scripts/setup-plan.sh +++ b/scripts/setup-plan.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Setup implementation plan structure for current branch # Returns paths needed for implementation plan generation # Usage: ./setup-plan.sh [--json] diff --git a/scripts/update-agent-context.sh b/scripts/update-agent-context.sh old mode 100644 new mode 100755 index 51fa640..21b77aa --- a/scripts/update-agent-context.sh +++ b/scripts/update-agent-context.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash # Incrementally update agent context files based on new feature plan # Supports: CLAUDE.md, GEMINI.md, and .github/copilot-instructions.md # O(1) operation - only reads current context file and new plan.md diff --git a/spec-driven.md b/spec-driven.md index 0a79a35..d9b8d99 100644 --- a/spec-driven.md +++ b/spec-driven.md @@ -2,7 +2,7 @@ ## The Power Inversion -For decades, code has been king. Specifications served code—they were the scaffolding we built and then discarded once the "real work" of coding began. We wrote PRDs to guide development, created design docs to inform implementation, drew diagrams to visualize architecture. But these were always subordinate to the code itself. Code was truth. Everything else was, at best, good intentions. Code was the source of truth, as it mvoed forward, and spec's rarely kept pace. As the asset (code) and the implementation are one, it's not easy to have a parallel implementation without trying to build from the code. +For decades, code has been king. Specifications served code—they were the scaffolding we built and then discarded once the "real work" of coding began. We wrote PRDs to guide development, created design docs to inform implementation, drew diagrams to visualize architecture. But these were always subordinate to the code itself. Code was truth. Everything else was, at best, good intentions. Code was the source of truth, as it moved forward, and spec's rarely kept pace. As the asset (code) and the implementation are one, it's not easy to have a parallel implementation without trying to build from the code. Spec-Driven Development (SDD) inverts this power structure. Specifications don't serve code—code serves specifications. The (Product Requirements Document-Specification) PRD isn't a guide for implementation; it's the source that generates implementation. Technical plans aren't documents that inform coding; they're precise definitions that produce code. This isn't an incremental improvement to how we build software. It's a fundamental rethinking of what drives development. @@ -34,13 +34,13 @@ The feedback loop extends beyond initial development. Production metrics and inc Three trends make SDD not just possible but necessary: -First, AI capabilities have reached a threshold where natural language specifications can reliably generate working code. This isn't about replacing developers—it's about amplifying their effectiveness by automating the mechanical translation from specification to implementation. It can amplify exploration and creativity, it can support "start-over" easily, it supports addition substraction and critical thinking. +First, AI capabilities have reached a threshold where natural language specifications can reliably generate working code. This isn't about replacing developers—it's about amplifying their effectiveness by automating the mechanical translation from specification to implementation. It can amplify exploration and creativity, it can support "start-over" easily, it supports addition subtraction and critical thinking. -Second, software complexity continues to grow exponentially. Modern systems integrate dozens of services, frameworks, and dependencies. Keeping all these pieces aligned with original intent through manual processes becomes increasingly difficult. SDD provides systematic alignment through specification-driven generation. Frameworks may eviolve to provide AI-first support, not human-first support, or architect around reusable components. +Second, software complexity continues to grow exponentially. Modern systems integrate dozens of services, frameworks, and dependencies. Keeping all these pieces aligned with original intent through manual processes becomes increasingly difficult. SDD provides systematic alignment through specification-driven generation. Frameworks may evolve to provide AI-first support, not human-first support, or architect around reusable components. Third, the pace of change accelerates. Requirements change far more rapidly today than ever before. Pivoting is no longer exceptional—it's expected. Modern product development demands rapid iteration based on user feedback, market conditions, and competitive pressures. Traditional development treats these changes as disruptions. Each pivot requires manually propagating changes through documentation, design, and code. The result is either slow, careful updates that limit velocity, or fast, reckless changes that accumulate technical debt. -SDD can support what-if/simulation experiments, "If we need to re-implement of change the application to promote a business need to sell more T-shirts, how would we implement and experiment for that?". +SDD can support what-if/simulation experiments, "If we need to re-implement or change the application to promote a business need to sell more T-shirts, how would we implement and experiment for that?". SDD transforms requirement changes from obstacles into normal workflow. When specifications drive implementation, pivots become systematic regenerations rather than manual rewrites. Change a core requirement in the PRD, and affected implementation plans update automatically. Modify a user story, and corresponding API endpoints regenerate. This isn't just about initial development—it's about maintaining engineering velocity through inevitable changes. @@ -256,7 +256,7 @@ The constitution defines nine articles that shape every aspect of the developmen #### Article I: Library-First Principle Every feature must begin as a standalone library—no exceptions. This forces modular design from the start: ``` -Every feature in Specify2 MUST begin its existence as a standalone library. +Every feature in Specify MUST begin its existence as a standalone library. No feature shall be implemented directly within application code without first being abstracted into a reusable library component. ``` diff --git a/src/specify_cli/__init__.py b/src/specify_cli/__init__.py index 0710362..aa3cf3c 100644 --- a/src/specify_cli/__init__.py +++ b/src/specify_cli/__init__.py @@ -15,7 +15,7 @@ Specify CLI - Setup tool for Specify projects Usage: uvx specify-cli.py init uvx specify-cli.py init --here - + Or install globally: uv tool install --from specify-cli.py specify-cli specify init @@ -813,12 +813,12 @@ def init( if selected_ai == "claude": steps_lines.append(f"{step_num}. Open in Visual Studio Code and start using / commands with Claude Code") steps_lines.append(" - Type / in any file to see available commands") - steps_lines.append(" - Use /spec to create specifications") + steps_lines.append(" - Use /specify to create specifications") steps_lines.append(" - Use /plan to create implementation plans") steps_lines.append(" - Use /tasks to generate tasks") elif selected_ai == "gemini": steps_lines.append(f"{step_num}. Use / commands with Gemini CLI") - steps_lines.append(" - Run gemini /spec to create specifications") + steps_lines.append(" - Run gemini /specify to create specifications") steps_lines.append(" - Run gemini /plan to create implementation plans") steps_lines.append(" - See GEMINI.md for all available commands") elif selected_ai == "copilot": @@ -868,4 +868,4 @@ def main(): if __name__ == "__main__": - main() \ No newline at end of file + main() diff --git a/templates/commands/plan.md b/templates/commands/plan.md index 94e1cb6..c0e4a9e 100644 --- a/templates/commands/plan.md +++ b/templates/commands/plan.md @@ -19,7 +19,7 @@ Given the implementation details provided as an argument, do this: 3. Read the constitution at `/memory/constitution.md` to understand constitutional requirements. 4. Execute the implementation plan template: - - Load `/templates/implementation-plan-template.md` (already copied to IMPL_PLAN path) + - Load `/templates/plan-template.md` (already copied to IMPL_PLAN path) - Set Input path to FEATURE_SPEC - Run the Execution Flow (main) function steps 1-10 - The template is self-contained and executable