One-shot, anti-slop
A layered framework for AI-assisted development with consistent standards and workflows.
Deft is a SKILL.md that makes AI coding significantly more effective by providing consistent, hierarchical standards. Instead of repeating the same instructions in every AI session, you define your preferences once—from general coding style to project-specific rules—and AI agents follow them. The result: higher quality code, reproducible workflows, and AI that gets better over time by learning from your patterns.
Key benefits: No more "AI forgot my preferences", no more inconsistent code style across AI sessions, no more re-explaining your stack every time.
Don't have preferences yet? No problem—Deft ships with professional-grade defaults for Python, Go, TypeScript, C++, and common workflows. Use it out of the box and customize later.
Platform compatibility: If you're on a platform that doesn't yet support SKILL.md, just add a line to your AGENTS.md that says "See deft/main.md".
Context-efficient: Deft keeps AI context windows lean through RFC 2119-based notation (!, ~, ≉, ⊗) and lazy-loading—AI only reads the files relevant to the current task, not everything at once.
📍 Roadmap: See ROADMAP.md for the development timeline, open issues, and planned work.
AGENTS.md is great for vibe-coding—loose guidance, good enough for quick work:
"Make it clean, I like tests, use TypeScript."
Deft is for when you want virtuoso results: precise standards, reproducible workflows, and AI that improves over time.
| Vibe (AGENTS.md) | Virtuoso (Deft) |
|---|---|
| All rules in one file | Modular—load only what's relevant |
| Gets bloated across languages/tools | Scales cleanly (python.md stays focused) |
| Same context loaded every session | Lazy-loading saves tokens |
| Preferences mixed with standards | Clear separation (user.md vs language files) |
| No evolution mechanism | Meta files capture learnings automatically |
| Starts fresh each project | Portable across projects |
When to use which:
- Your AGENTS.md is under 200 lines and you work in one language? Vibe is fine.
- It's growing unwieldy, you're repeating yourself, or you want consistent quality across projects? Deft pays off.
Same instrument, different mastery.
Deft is a structured approach to working with AI coding assistants that provides:
- Consistent coding standards across languages and projects
- Reproducible workflows via task-based automation
- Self-improving guidelines that evolve with your team
- Hierarchical rule precedence from general to project-specific
- Lazy loading - only read files relevant to current task (see REFERENCES.md)
Deft uses compact notation for requirements:
- ! = MUST (required, mandatory)
- ~ = SHOULD (recommended, strong preference)
- ≉ = SHOULD NOT (discouraged, avoid unless justified)
- ⊗ = MUST NOT (forbidden, never do this)
This notation appears in technical standard files (python.md, go.md, etc.) for scanability. Based on RFC 2119.
Deft uses a layered architecture where more specific rules override general ones:
flowchart TD
subgraph precedence ["Rule Precedence (top = highest)"]
direction TB
U["👤 USER.md<br/><i>Personal preferences</i>"]
P["📁 PROJECT.md<br/><i>Project-specific rules</i>"]
L["🐍 python.md / go.md / etc.<br/><i>Language standards</i>"]
T["🔧 taskfile.md<br/><i>Tool guidelines</i>"]
M["🤖 main.md<br/><i>General AI behavior</i>"]
S["📋 specification.md<br/><i>Project requirements</i>"]
end
U --> P
P --> L
L --> T
T --> M
M --> S
style U fill:#4ade80,stroke:#166534,color:#000
style P fill:#60a5fa,stroke:#1e40af,color:#000
style L fill:#facc15,stroke:#a16207,color:#000
style T fill:#fb923c,stroke:#c2410c,color:#000
style M fill:#c084fc,stroke:#7c3aed,color:#000
style S fill:#94a3b8,stroke:#475569,color:#000
deft/
├── README.md # This file
├── CHANGELOG.md # Release history
├── LICENSE.md # MIT License
├── PROJECT.md # Project-level configuration
├── REFERENCES.md # Lazy-loading reference system
├── ROADMAP.md # Development timeline
├── SKILL.md # Entry point for AI agents
├── main.md # Entry point - general AI guidelines
├── commands.md # Available commands
├── Taskfile.yml # Task automation
├── run.bat # Windows task runner shim
│
├── cmd/ # Go installer source
│ └── deft-install/ # Cross-platform installer wizard
│
├── coding/ # Coding standards
│ ├── coding.md # General coding guidelines
│ └── testing.md # Testing standards
│
├── context/ # Context management strategies
│ ├── context.md # Overview
│ ├── deterministic-split.md
│ ├── examples.md
│ ├── fractal-summaries.md
│ ├── long-horizon.md
│ ├── spec-deltas.md
│ ├── tool-design.md
│ └── working-memory.md
│
├── contracts/ # Interface contracts
│ └── boundary-maps.md # Produces/consumes between slices
│
├── core/ # Core framework files
│ ├── glossary.md # Terminology definitions
│ ├── project.md # Project template
│ ├── ralph.md # Ralph loop concept
│ ├── user.md # Legacy; now ~/.config/deft/USER.md or %APPDATA%\deft\USER.md
│ └── versioning.md # Versioning guidelines
│
├── deployments/ # Platform-specific deployment guidance
│ ├── README.md # Deployment overview
│ ├── agentuity/ # Agentuity platform
│ ├── aws/ # AWS (Lambda, ECS, App Runner, EB)
│ ├── azure/ # Azure (App Service, Functions, AKS, Container Apps)
│ ├── cloudflare/ # Cloudflare Workers/Pages
│ ├── cloud-gov/ # cloud.gov (FedRAMP)
│ ├── fly-io/ # Fly.io
│ ├── google/ # GCP (Cloud Run, Functions, App Engine, GKE)
│ ├── netlify/ # Netlify
│ └── vercel/ # Vercel
│
├── docs/ # Documentation & articles
│ ├── ai-coding-trust-paradox.md
│ └── claude-code-integration.md
│
├── history/ # Plan archives and change logs
│ ├── archive/
│ └── changes/
│
├── interfaces/ # Interface types
│ ├── cli.md # Command-line interfaces
│ ├── rest.md # REST APIs
│ ├── tui.md # Terminal UIs
│ └── web.md # Web UIs
│
├── languages/ # Language-specific standards
│ ├── python.md, go.md, typescript.md, javascript.md
│ ├── cpp.md, c.md, csharp.md, rust.md, zig.md
│ ├── java.md, kotlin.md, swift.md, dart.md
│ ├── elixir.md, julia.md, r.md, sql.md
│ ├── delphi.md, visual-basic.md, vhdl.md
│ ├── 6502-DASM.md # 6502 Assembly (DASM)
│ ├── markdown.md, mermaid.md
│ └── commands.md # Language command reference
│
├── meta/ # Meta/process files
│ ├── code-field.md # Coding mindset
│ ├── ideas.md # Future directions
│ ├── lessons.md # Learnings
│ ├── morals.md # Ethical guidelines
│ ├── SOUL.md # Core philosophy
│ └── suggestions.md # Improvements
│
├── platforms/ # Platform-specific standards
│ ├── 2600.md # Atari 2600
│ └── unity.md # Unity engine
│
├── resilience/ # Session continuity & recovery
│ ├── continue-here.md # Interruption recovery protocol
│ └── context-pruning.md # Fresh context per task
│
├── scm/ # Source control management
│ ├── changelog.md # Changelog conventions
│ ├── git.md # Git conventions
│ └── github.md # GitHub workflows
│
├── skills/ # Agent skills (SKILL.md format)
│ ├── deft-build/ # Build/setup skill
│ └── deft-setup/ # Interactive setup skill
│
├── specs/ # Per-feature specifications
│ ├── testbed/ # QA testbed Phase 1 spec
│ └── strategy-chaining/ # Strategy chaining feature spec
│
├── strategies/ # Development strategies
│ ├── README.md # Strategy overview
│ ├── brownfield.md # Existing codebase work
│ ├── default.md # Default strategy
│ ├── discuss.md # Discussion mode
│ ├── interview.md # Interview-driven development
│ ├── map.md # Codebase mapping
│ ├── research.md # Research mode
│ ├── speckit.md # Specification toolkit
│ └── yolo.md # Rapid prototyping
│
├── swarm/ # Multi-agent coordination
│ └── swarm.md # Swarm guidelines
│
├── taskfiles/ # Reusable Taskfile includes
│ └── deployments.yml # Deployment tasks
│
├── templates/ # Templates and examples
│ ├── make-spec.md # Spec generation guide
│ ├── make-spec-example.md
│ └── specification.md # Project spec template
│
├── tests/ # Test fixtures and snapshots
│ ├── content/snapshots/ # Content validation baselines
│ └── fixtures/ # Mock configs
│
├── tools/ # Tooling and workflow
│ ├── RWLDL.md # Read-Write-List-Delete-Link pattern
│ ├── taskfile.md # Task automation
│ └── telemetry.md # Observability
│
├── vbrief/ # vBRIEF session format
│ ├── vbrief.md # Specification
│ └── schemas/ # JSON schemas
│
└── verification/ # Agent work verification
├── verification.md # 4-tier verification ladder
├── integration.md # Integration testing
├── plan-checking.md # Plan validation
└── uat.md # User acceptance testing
main.md - Entry point, general AI guidelines
SKILL.md - Entry point for AI agent skill loading
coding/coding.md - Software development standards
coding/testing.md - Testing standards
core/project.md - Project-specific template
USER.md - Your personal preferences (highest precedence) — ~/.config/deft/USER.md (Unix/macOS) or %APPDATA%\deft\USER.md (Windows)
languages/ contains standards for 20+ languages including:
python.md - Python (≥85% coverage, mypy strict, ruff/black)
go.md - Go (≥85% coverage, Testify)
typescript.md / javascript.md - TS/JS (strict mode, Vitest)
cpp.md / c.md / csharp.md - C family
rust.md / zig.md - Systems languages
java.md / kotlin.md / swift.md / dart.md - Mobile/JVM
elixir.md / julia.md / r.md / sql.md - Specialized
markdown.md / mermaid.md - Documentation formats
Plus: delphi, visual-basic, vhdl, 6502-DASM
interfaces/cli.md - Command-line interface patterns
interfaces/rest.md - REST API design
interfaces/tui.md - Terminal UI (Textual, ink)
interfaces/web.md - Web UI (React, Tailwind)
platforms/2600.md - Atari 2600 development
platforms/unity.md - Unity engine standards
tools/taskfile.md - Task automation best practices
tools/telemetry.md - Logging, tracing, metrics
tools/RWLDL.md - Read-Write-List-Delete-Link pattern
scm/git.md - Commit conventions, safety
scm/github.md - GitHub workflows
scm/changelog.md - Changelog conventions
swarm/swarm.md - Multi-agent coordination patterns
strategies/ - Development approach strategies:
default.md / brownfield.md / interview.md / discuss.md / map.md / research.md / speckit.md / yolo.md
context/context.md - Context management overview
context/fractal-summaries.md / working-memory.md / long-horizon.md / deterministic-split.md / spec-deltas.md / tool-design.md / examples.md
verification/verification.md - 4-tier verification ladder, must-haves, stub detection
verification/integration.md - Integration testing standards
verification/plan-checking.md - Plan validation
verification/uat.md - Auto-generated user acceptance test scripts
resilience/continue-here.md - Interruption recovery protocol (vBRIEF-based)
resilience/context-pruning.md - Fresh context per task, eliminating context rot
vbrief/vbrief.md - Session format specification
vbrief/schemas/ - JSON validation schemas
contracts/boundary-maps.md - Explicit produces/consumes declarations between slices
deployments/ - Deployment guides for 9 platforms:
agentuity, aws, azure, cloudflare, cloud-gov, fly-io, google, netlify, vercel
skills/deft-build/ - Build/setup skill
skills/deft-setup/ - Interactive setup wizard skill
templates/make-spec.md - Specification generation
templates/specification.md - Project spec template
meta/code-field.md - Coding mindset and philosophy
meta/SOUL.md - Core philosophy
meta/morals.md - Ethical guidelines
meta/lessons.md - Codified learnings (AI-updatable)
meta/ideas.md - Future directions
meta/suggestions.md - Improvement suggestions
Download the installer for your platform from GitHub Releases, run it, and follow the prompts.
Windows:
- Download
install-windows-amd64.exe(orinstall-windows-arm64.exefor Surface / Copilot+ PCs) - Run the downloaded file — Windows SmartScreen may warn about an unrecognised publisher; click "More info" → "Run anyway" (code signing is planned for a future release)
macOS:
- Download
install-macos-universal— works on all Macs (Intel and Apple Silicon) - Make it executable and run:
chmod +x install-macos-universal && ./install-macos-universal - If macOS Gatekeeper blocks the file: right-click → Open, or run
xattr -d com.apple.quarantine install-macos-universalfirst (code signing is planned for a future release)
Linux:
- Download
install-linux-amd64(orinstall-linux-arm64for Raspberry Pi / ARM cloud) - Make it executable and run:
chmod +x install-linux-amd64 && ./install-linux-amd64
The installer guides you through choosing a project directory, installs git if needed, clones deft, wires it into AGENTS.md, and creates your user config directory.
Manual clone (no installer): If you clone deft directly via git clone, add See deft/main.md to your project's AGENTS.md (create it if it doesn't exist) so your AI agent discovers the framework.
Building from source (developers only): requires Go 1.22+ — go run ./cmd/deft-install/
Manual clone (CLI users): if you already have git and prefer to skip the installer, clone deft directly into your project:
cd your-project
git clone https://github.com/deftai/directive.git deftThen create an AGENTS.md in your project root (or append to an existing one):
See deft/main.md
Skills: deft/SKILL.md, deft/skills/deft-setup/SKILL.md, deft/skills/deft-build/SKILL.mdOn your next AI session the agent automatically invokes the deft-setup skill to walk you through creating your USER.md preferences interactively.
User config location:
- Unix / macOS:
~/.config/deft/USER.md - Windows:
%APPDATA%\deft\USER.md - Override: set
DEFT_USER_PATHenvironment variable
To set up via CLI instead:
deft/run bootstrap # Interactive setup for user.md and project.mddeft/run bootstrap will guide you through creating a SPECIFICATION.md, or create one anytime:
deft/run spec # AI-assisted specification interviewOther commands:
deft/run reset # Reset config files
deft/run validate # Check deft configuration
deft/run doctor # Check system dependenciesAsk your AI to build the product/project from SPECIFICATION.md and away you go:
Read SPECIFICATION.md and implement the project following deft/main.md standards.
Rules cascade with precedence:
- USER.md (highest) - your personal overrides (
~/.config/deft/USER.mdon Unix/macOS,%APPDATA%\deft\USER.mdon Windows) - project.md - project-specific rules
- Language files (python.md, go.md) - language standards
- Tool files (taskfile.md) - tool guidelines
- main.md - general AI behavior
- specification.md (lowest) - requirements
The deft process evolves over time:
flowchart TD
subgraph evolution ["Continuous Evolution"]
DEV["🛠️ Development<br/><i>Daily coding</i>"]
LEARN["📚 lessons.md<br/><i>Patterns discovered</i>"]
IDEAS["💡 ideas.md<br/><i>Future directions</i>"]
SUGGEST["📝 suggestions.md<br/><i>Improvements</i>"]
USER["👤 user.md<br/><i>Preferences</i>"]
STANDARDS["📖 Language/Tool files<br/><i>Evolving standards</i>"]
end
DEV -->|"AI discovers"| LEARN
DEV -->|"AI notes"| IDEAS
DEV -->|"AI suggests"| SUGGEST
LEARN -->|"Promote"| STANDARDS
IDEAS -->|"Review"| STANDARDS
SUGGEST -->|"Accept"| USER
STANDARDS -->|"Inform"| DEV
USER -->|"Guide"| DEV
style DEV fill:#f0abfc,stroke:#a855f7,color:#000
style LEARN fill:#fde68a,stroke:#d97706,color:#000
style IDEAS fill:#a5f3fc,stroke:#06b6d4,color:#000
style SUGGEST fill:#fecaca,stroke:#ef4444,color:#000
style USER fill:#86efac,stroke:#22c55e,color:#000
style STANDARDS fill:#c7d2fe,stroke:#6366f1,color:#000
- AI updates
lessons.mdwhen learning better patterns - AI notes ideas in
ideas.mdfor future consideration - AI suggests improvements in
suggestions.md - You update your USER.md (
~/.config/deft/USER.mdon Unix/macOS,%APPDATA%\deft\USER.mdon Windows) with new preferences - You update language/tool files as standards evolve
Why Taskfile?
Deft uses Taskfile as the universal task runner for several reasons:
- Makefiles are outdated: Make syntax is arcane, portability is poor, and tabs vs spaces causes constant friction
- Polyglot simplicity: When working across Python (make/invoke/poetry scripts), Go (make/mage), Node (npm scripts/gulp), etc., each ecosystem has different conventions. Taskfile provides one consistent interface
- Better than script sprawl: A
/scriptsdirectory with dozens of bash files becomes chaotic—hard to discover, hard to document, hard to compose. Taskfile provides discoverability (task --list), documentation (desc), and composition (deps) - Modern features: Built-in file watching, incremental builds via checksums, proper error handling, variable templating, and cross-platform support
Usage:
task --list # See available tasks
task check # Pre-commit checks
task test:coverage # Run coverage
task dev # Start dev environmentDeft embraces TDD as the default development approach:
flowchart LR
subgraph cycle ["TDD Cycle"]
R["🔴 RED<br/>Write failing test"]
G["🟢 GREEN<br/>Make it pass"]
B["🔵 REFACTOR<br/>Improve code"]
end
R -->|"Minimal code"| G
G -->|"Clean up"| B
B -->|"Next feature"| R
style R fill:#fca5a5,stroke:#dc2626,color:#000
style G fill:#86efac,stroke:#16a34a,color:#000
style B fill:#93c5fd,stroke:#2563eb,color:#000
- Write the test first: Define expected behavior before implementation
- Watch it fail: Confirm the test fails for the right reason
- Implement: Write minimal code to make the test pass
- Refactor: Improve code quality while keeping tests green
- Repeat: Build features incrementally with confidence
Benefits:
- Tests become specifications of behavior
- Better API design (you use the API before implementing it)
- High coverage naturally (≥85% is easy when tests come first)
- Refactoring confidence
- Living documentation
In Practice:
task test # Run tests in watch mode during development
task test:coverage # Verify ≥75% coverage
task check # Pre-commit: all quality checks including tests- ≥85% test coverage (overall + per-module)
- Always run
task checkbefore commits - Run linting, formatting, type checking
- Never claim checks passed without running them
Before writing any code, deft uses an AI-assisted specification process:
flowchart LR
subgraph sdd ["Spec-Driven Development"]
I["💡 Idea<br/><i>Initial concept</i>"]
Q["❓ Interview<br/><i>AI asks questions</i>"]
S["📋 SPECIFICATION.md<br/><i>Complete plan</i>"]
D["👥 Development<br/><i>Parallel agents</i>"]
end
I -->|"make-spec.md"| Q
Q -->|"Clarify ambiguity"| S
S -->|"Independent tasks"| D
style I fill:#fef08a,stroke:#ca8a04,color:#000
style Q fill:#c4b5fd,stroke:#7c3aed,color:#000
style S fill:#6ee7b7,stroke:#059669,color:#000
style D fill:#7dd3fc,stroke:#0284c7,color:#000
The Process:
-
Start with make-spec.md: A prompt template for creating specifications
I want to build **\_\_\_\_** that has the following features: 1. Feature A 2. Feature B 3. Feature C
-
AI Interview: The AI (Claude or similar) asks focused, non-trivial questions to clarify:
- Missing decisions and edge cases
- Implementation details and architecture
- UX considerations and constraints
- Dependencies and tradeoffs
Each question includes numbered options and an "other" choice for custom responses.
-
Generate SPECIFICATION.md: Once ambiguity is minimized, the AI produces a comprehensive spec with:
- Clear phases, subphases, and tasks
- Dependency mappings (what blocks what)
- Parallel work opportunities
- No code—just the complete plan
-
Multi-Agent Development: The spec enables multiple AI coding agents to work in parallel on independent tasks
Why SDD?
- Clarity before coding: Catch design issues early
- Parallelization: Clear dependencies enable concurrent work
- Scope management: Complete spec prevents scope creep
- Onboarding: New contributors/agents understand the full picture
- AI-friendly: Structured specs help AI agents stay aligned
Example: See templates/make-spec.md for the interview process template
- Use Conventional Commits for all commits
- Use hyphens in filenames, not underscores
- Keep secrets in
secrets/directory - Keep docs in
docs/, not project root
- Never force-push without permission
- Assume production impact unless stated
- Prefer small, reversible changes
- Call out risks explicitly
flowchart TB
subgraph NewProject ["🆕 New Python Project"]
direction TB
NP1["AI reads main.md"] --> NP2["AI reads python.md"]
NP2 --> NP3["AI reads taskfile.md"]
NP3 --> NP4["Setup: pytest, ruff, black, mypy"]
NP4 --> NP5["Configure: ≥85% coverage"]
NP5 --> NP6["You customize: project.md"]
end
subgraph ExistingGo ["📂 Existing Go Project"]
direction TB
EG1["AI reads user.md"] --> EG2["AI reads project.md"]
EG2 --> EG3["AI reads go.md"]
EG3 --> EG4["AI runs task check"]
EG4 --> EG5["AI makes changes"]
end
subgraph Review ["🔍 Code Review"]
direction TB
CR1["AI reads quality standards"] --> CR2["task quality"]
CR2 --> CR3["task test:coverage"]
CR3 --> CR4["Check commits"]
CR4 --> CR5["Update suggestions.md"]
end
sequenceDiagram
participant AI
participant Files as Deft Files
participant Project
AI->>Files: Read main.md
AI->>Files: Read python.md
AI->>Files: Read taskfile.md
AI->>Project: Setup pytest, ruff, black, mypy
AI->>Project: Configure ≥85% coverage
AI->>Project: Create Taskfile.yml
Note over AI,Project: You customize project.md
- AI reads:
main.md→python.md→taskfile.md - AI sets up: pytest, ruff, black, mypy, Taskfile
- AI configures: ≥85% coverage, PEP standards
- You customize:
project.mdwith project specifics
sequenceDiagram
participant AI
participant Files as Deft Files
participant Code
AI->>Files: Read USER.md (your overrides)
AI->>Files: Read PROJECT.md
AI->>Files: Read go.md
AI->>Files: Read main.md
AI->>Code: Run task check
AI->>Code: Apply changes
Note over AI,Code: Respects your USER.md preferences
- AI reads:
USER.md→PROJECT.md→go.md→main.md - AI follows: go.dev/doc/comment, Testify patterns
- AI runs:
task checkbefore suggesting changes - AI respects: your USER.md overrides
sequenceDiagram
participant AI
participant Standards as Language File
participant Tasks as Taskfile
participant Meta as suggestions.md
AI->>Standards: Reference quality standards
AI->>Tasks: Run task quality
AI->>Tasks: Run task test:coverage
AI->>AI: Check Conventional Commits
AI->>Meta: Log improvements
- AI references quality standards from language file
- AI runs
task qualityandtask test:coverage - AI checks Conventional Commits compliance
- AI suggests improvements → adds to
suggestions.md
As you use deft, AI maintains three meta files that help the framework evolve:
## 2026-01-15: Testify suite setup
When using Testify in Go, always define `suite.Suite` struct with
dependencies as fields, not package-level vars. Discovered during
auth-service refactor—package vars caused test pollution.
## 2026-01-20: CLI flag defaults
For CLI tools, default to human-readable output, use `--json` flag
for machine output. Users expect pretty by default.- [ ] Add `deft/run upgrade` command to pull latest deft without
losing local user.md/project.md customizations
- [ ] Consider `deft/interfaces/grpc.md` for protobuf/gRPC patterns
- [ ] Explore integration with cursor rules format## auth-service
- The retry logic in `client.go` should use exponential backoff
(currently linear)—see coding.md resilience patterns
## api-gateway
- Consider splitting routes.go (850 lines) into domain-specific
route files per coding.md file size guidelinesReview these periodically and promote good ideas to main guidelines
The GitHub Actions workflow (.github/workflows/release.yml) builds installers for all 6 platform targets, creates a macOS universal binary, runs smoke tests on real hardware, and publishes a GitHub Release.
Every build is tested on its native platform (including macos-latest and ubuntu-24.04-arm):
--version— binary executes and reports version--help— flag parsing and usage output render correctly--debug— correct OS and architecture detection (e.g.OS=darwin ARCH=arm64)- Wizard startup — binary initializes and prints the welcome banner
--branch <name>— branch flag is accepted without error- macOS universal binary contains both
x86_64andarm64architectures
The workflow triggers on version tags (v*.*.*). To run a full build and smoke test without publishing a real release, push a disposable test tag from any branch:
# Tag the current HEAD
git tag v0.0.0-test.1
git push origin v0.0.0-test.1
# Monitor the workflow run
gh run list --workflow=release.yml -R deftai/directive
gh run watch <RUN_ID> -R deftai/directive
# Clean up after verifying
gh release delete v0.0.0-test.1 -R deftai/directive --yes
git push origin --delete v0.0.0-test.1
git tag -d v0.0.0-test.1The workflow also includes a workflow_dispatch trigger for manual runs without publishing:
gh workflow run release.yml --ref <branch> -R deftai/directiveManual runs skip the release job automatically (guarded by if: startsWith(github.ref, 'refs/tags/v')).
- Merge the feature branch PR into
master - Tag
masterwith a semantic version:git checkout master git pull origin master git tag v1.2.3 git push origin v1.2.3
- The workflow runs automatically: build → universal-macos → smoke-test → release
- Verify the published release at https://github.com/deftai/directive/releases
- Each release includes:
install-windows-amd64.exe,install-windows-arm64.exe,install-macos-universal,install-linux-amd64,install-linux-arm64
Note: Binaries are not yet code-signed. macOS users may need to bypass Gatekeeper (see Getting Started). Windows users may see a SmartScreen warning. Code signing is planned for a future release.
Deft embodies:
- Correctness over convenience: Optimize for long-term quality
- Standards over flexibility: Consistent patterns across projects
- Evolution over perfection: Continuously improve through learning
- Clarity over cleverness: Direct, explicit, maintainable code
Next Steps: Read main.md for comprehensive AI guidelines, then download the installer for your platform to get started.
Copyright © 2025-2026 Jonathan "visionik" Taylor — https://deft.md
Licensed under the MIT License