forge-workflow 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/.claude/commands/dev.md +314 -0
  2. package/.claude/commands/plan.md +389 -0
  3. package/.claude/commands/premerge.md +179 -0
  4. package/.claude/commands/research.md +42 -0
  5. package/.claude/commands/review.md +442 -0
  6. package/.claude/commands/rollback.md +721 -0
  7. package/.claude/commands/ship.md +134 -0
  8. package/.claude/commands/sonarcloud.md +152 -0
  9. package/.claude/commands/status.md +77 -0
  10. package/.claude/commands/validate.md +237 -0
  11. package/.claude/commands/verify.md +221 -0
  12. package/.claude/rules/greptile-review-process.md +285 -0
  13. package/.claude/rules/workflow.md +105 -0
  14. package/.claude/scripts/greptile-resolve.sh +526 -0
  15. package/.claude/scripts/load-env.sh +32 -0
  16. package/.forge/hooks/check-tdd.js +240 -0
  17. package/.github/PLUGIN_TEMPLATE.json +32 -0
  18. package/.mcp.json.example +12 -0
  19. package/AGENTS.md +169 -0
  20. package/CLAUDE.md +99 -0
  21. package/LICENSE +21 -0
  22. package/README.md +414 -0
  23. package/bin/forge-cmd.js +313 -0
  24. package/bin/forge-validate.js +303 -0
  25. package/bin/forge.js +4228 -0
  26. package/docs/AGENT_INSTALL_PROMPT.md +342 -0
  27. package/docs/ENHANCED_ONBOARDING.md +602 -0
  28. package/docs/EXAMPLES.md +482 -0
  29. package/docs/GREPTILE_SETUP.md +400 -0
  30. package/docs/MANUAL_REVIEW_GUIDE.md +106 -0
  31. package/docs/ROADMAP.md +359 -0
  32. package/docs/SETUP.md +632 -0
  33. package/docs/TOOLCHAIN.md +849 -0
  34. package/docs/VALIDATION.md +363 -0
  35. package/docs/WORKFLOW.md +400 -0
  36. package/docs/planning/PROGRESS.md +396 -0
  37. package/docs/plans/.gitkeep +0 -0
  38. package/docs/plans/2026-02-27-forge-test-suite-v2-decisions.md +21 -0
  39. package/docs/plans/2026-02-27-forge-test-suite-v2-design.md +362 -0
  40. package/docs/plans/2026-02-27-forge-test-suite-v2-tasks.md +343 -0
  41. package/docs/plans/2026-03-02-superpowers-gaps-decisions.md +26 -0
  42. package/docs/plans/2026-03-02-superpowers-gaps-design.md +239 -0
  43. package/docs/plans/2026-03-02-superpowers-gaps-tasks.md +260 -0
  44. package/docs/plans/2026-03-04-agent-command-parity-design.md +163 -0
  45. package/docs/plans/2026-03-04-verify-worktree-cleanup-decisions.md +7 -0
  46. package/docs/plans/2026-03-04-verify-worktree-cleanup-design.md +165 -0
  47. package/docs/plans/2026-03-05-forge-uto-decisions.md +6 -0
  48. package/docs/plans/2026-03-05-forge-uto-design.md +116 -0
  49. package/docs/plans/2026-03-05-forge-uto-tasks.md +244 -0
  50. package/docs/plans/2026-03-10-command-creator-and-eval-decisions.md +52 -0
  51. package/docs/plans/2026-03-10-command-creator-and-eval-design.md +350 -0
  52. package/docs/plans/2026-03-10-command-creator-and-eval-tasks.md +426 -0
  53. package/docs/plans/2026-03-10-stale-workflow-refs-decisions.md +8 -0
  54. package/docs/plans/2026-03-10-stale-workflow-refs-design.md +80 -0
  55. package/docs/plans/2026-03-10-stale-workflow-refs-tasks.md +90 -0
  56. package/docs/plans/2026-03-14-beads-plan-context-decisions.md +9 -0
  57. package/docs/plans/2026-03-14-beads-plan-context-design.md +171 -0
  58. package/docs/plans/2026-03-14-beads-plan-context-tasks.md +160 -0
  59. package/docs/plans/2026-03-14-skill-eval-loop-decisions.md +33 -0
  60. package/docs/plans/2026-03-14-skill-eval-loop-design.md +118 -0
  61. package/docs/plans/2026-03-14-skill-eval-loop-results.md +78 -0
  62. package/docs/plans/2026-03-14-skill-eval-loop-tasks.md +160 -0
  63. package/docs/plans/2026-03-15-agent-command-parity-v2-decisions.md +11 -0
  64. package/docs/plans/2026-03-15-agent-command-parity-v2-design.md +145 -0
  65. package/docs/plans/2026-03-15-agent-command-parity-v2-tasks.md +211 -0
  66. package/docs/research/TEMPLATE.md +292 -0
  67. package/docs/research/advanced-testing.md +297 -0
  68. package/docs/research/agent-permissions.md +167 -0
  69. package/docs/research/dependency-chain.md +328 -0
  70. package/docs/research/forge-workflow-v2.md +550 -0
  71. package/docs/research/plugin-architecture.md +772 -0
  72. package/docs/research/pr4-cli-automation.md +326 -0
  73. package/docs/research/premerge-verify-restructure.md +205 -0
  74. package/docs/research/skills-restructure.md +508 -0
  75. package/docs/research/sonarcloud-perfection-plan.md +166 -0
  76. package/docs/research/sonarcloud-quality-gate.md +184 -0
  77. package/docs/research/superpowers-integration.md +403 -0
  78. package/docs/research/superpowers.md +319 -0
  79. package/docs/research/test-environment.md +519 -0
  80. package/install.sh +1062 -0
  81. package/lefthook.yml +39 -0
  82. package/lib/agents/README.md +198 -0
  83. package/lib/agents/claude.plugin.json +28 -0
  84. package/lib/agents/cline.plugin.json +22 -0
  85. package/lib/agents/codex.plugin.json +19 -0
  86. package/lib/agents/copilot.plugin.json +24 -0
  87. package/lib/agents/cursor.plugin.json +25 -0
  88. package/lib/agents/kilocode.plugin.json +22 -0
  89. package/lib/agents/opencode.plugin.json +20 -0
  90. package/lib/agents/roo.plugin.json +23 -0
  91. package/lib/agents-config.js +2112 -0
  92. package/lib/commands/dev.js +513 -0
  93. package/lib/commands/plan.js +696 -0
  94. package/lib/commands/recommend.js +119 -0
  95. package/lib/commands/ship.js +377 -0
  96. package/lib/commands/status.js +378 -0
  97. package/lib/commands/validate.js +602 -0
  98. package/lib/context-merge.js +359 -0
  99. package/lib/plugin-catalog.js +360 -0
  100. package/lib/plugin-manager.js +166 -0
  101. package/lib/plugin-recommender.js +141 -0
  102. package/lib/project-discovery.js +491 -0
  103. package/lib/setup.js +118 -0
  104. package/lib/workflow-profiles.js +203 -0
  105. package/package.json +115 -0
package/lefthook.yml ADDED
@@ -0,0 +1,39 @@
1
+ # Lefthook Git Hooks Configuration
2
+ # TDD Enforcement for Forge Workflow
3
+ #
4
+ # To skip hooks in emergencies:
5
+ # git commit --no-verify (skip pre-commit)
6
+ # LEFTHOOK=0 git push (skip pre-push)
7
+
8
+ commit-msg:
9
+ commands:
10
+ commitlint:
11
+ run: node scripts/commitlint.js {1}
12
+ tags: commitlint
13
+
14
+ pre-commit:
15
+ commands:
16
+ tdd-check:
17
+ run: node .forge/hooks/check-tdd.js
18
+ stage_fixed: false
19
+ tags: tdd
20
+ glob: "*.{js,ts,jsx,tsx,py,go,java,rb}"
21
+
22
+ pre-push:
23
+ commands:
24
+ # 1. Block direct push to main/master (dual-layer protection)
25
+ # Uses Node.js for cross-platform compatibility (Windows, macOS, Linux)
26
+ branch-protection:
27
+ run: node scripts/branch-protection.js
28
+ tags: protection
29
+
30
+ # 2. ESLint check (strict mode: blocks on errors and warnings)
31
+ # Uses Node.js script for cross-platform compatibility
32
+ lint:
33
+ run: node scripts/lint.js
34
+ tags: lint
35
+
36
+ # 3. Test suite (cross-platform Node.js script detects package manager)
37
+ tests:
38
+ run: node scripts/test.js
39
+ tags: tests
@@ -0,0 +1,198 @@
1
+ # Agent Plugins
2
+
3
+ This directory contains plugin definitions for all supported AI coding agents.
4
+
5
+ ## Plugin Architecture
6
+
7
+ Each agent is defined by a JSON file following the plugin schema. This allows:
8
+ - **Discoverability**: New agents can be added without modifying core code
9
+ - **Community contributions**: Anyone can add support for new agents
10
+ - **Backwards compatibility**: Existing functionality remains unchanged
11
+ - **Maintainability**: Agent configurations are separated from business logic
12
+
13
+ ## Plugin Schema
14
+
15
+ Each plugin file must follow this structure:
16
+
17
+ ```json
18
+ {
19
+ "id": "agent-id", // REQUIRED: Unique identifier (lowercase, alphanumeric, hyphens)
20
+ "name": "Agent Name", // REQUIRED: Human-readable name
21
+ "version": "1.0.0", // REQUIRED: Semantic version (x.y.z)
22
+ "description": "...", // OPTIONAL: Brief description
23
+ "homepage": "https://...", // OPTIONAL: Agent's homepage URL
24
+ "capabilities": { // OPTIONAL: Agent capabilities
25
+ "commands": true, // Supports commands
26
+ "skills": true, // Supports skills
27
+ "hooks": false // Supports git hooks
28
+ },
29
+ "directories": { // REQUIRED: Directory structure (at least one)
30
+ "commands": ".your-agent/commands",
31
+ "rules": ".your-agent/rules",
32
+ "skills": ".your-agent/skills/forge-workflow",
33
+ "scripts": ".your-agent/scripts"
34
+ },
35
+ "files": { // OPTIONAL: Important file paths
36
+ "rootConfig": "YOUR-AGENT.md",
37
+ "skillDefinition": ".your-agent/skills/forge-workflow/SKILL.md"
38
+ },
39
+ "setup": { // OPTIONAL: Setup instructions
40
+ "copyCommands": true,
41
+ "copyRules": true,
42
+ "createSkill": true,
43
+ "customSetup": "agent-name",
44
+ "needsConversion": false
45
+ }
46
+ }
47
+ ```
48
+
49
+ ### Required Fields
50
+
51
+ - **id**: Unique identifier for the agent (must match filename without `.plugin.json`)
52
+ - **name**: Display name shown to users
53
+ - **version**: Semantic version number (major.minor.patch)
54
+ - **directories**: Object with at least one directory path
55
+
56
+ ### Optional Fields
57
+
58
+ - **description**: Short description of the agent
59
+ - **homepage**: URL to agent's official website
60
+ - **capabilities**: Object defining what the agent supports
61
+ - **files**: Important configuration file paths
62
+ - **setup**: Installation and setup instructions
63
+
64
+ ## Supported Agents
65
+
66
+ Currently supported AI coding agents:
67
+
68
+ | Agent | ID | Description |
69
+ |-------|----|-----------|
70
+ | Claude Code | `claude` | Anthropic's CLI agent |
71
+ | Cursor | `cursor` | AI-first code editor |
72
+ | Kilo Code | `kilocode` | VS Code extension |
73
+ | GitHub Copilot | `copilot` | GitHub's AI assistant |
74
+ | OpenCode | `opencode` | Open-source agent |
75
+ | Cline | `cline` | VS Code agent extension |
76
+ | Roo Code | `roo` | Cline fork with modes |
77
+
78
+ ## Adding a New Agent
79
+
80
+ To add support for a new AI coding agent:
81
+
82
+ 1. **Create plugin file**: `lib/agents/your-agent.plugin.json`
83
+ 2. **Follow schema**: Use the template below or copy an existing plugin
84
+ 3. **Validate**: Run tests to ensure your plugin is valid
85
+ 4. **Test**: Run `bunx forge setup --agents your-agent` to verify
86
+ 5. **Submit PR**: Contribute back to the community!
87
+
88
+ ### Plugin Template
89
+
90
+ See `.github/PLUGIN_TEMPLATE.json` for a ready-to-use template.
91
+
92
+ ```json
93
+ {
94
+ "id": "your-agent",
95
+ "name": "Your Agent Name",
96
+ "version": "1.0.0",
97
+ "description": "Brief description of your agent",
98
+ "homepage": "https://your-agent.example.com",
99
+ "capabilities": {
100
+ "commands": true,
101
+ "skills": true,
102
+ "hooks": false
103
+ },
104
+ "directories": {
105
+ "rules": ".your-agent/rules",
106
+ "skills": ".your-agent/skills/forge-workflow"
107
+ },
108
+ "files": {
109
+ "rootConfig": ".your-agent-rules"
110
+ },
111
+ "setup": {
112
+ "createSkill": true
113
+ }
114
+ }
115
+ ```
116
+
117
+ ## Validation
118
+
119
+ The PluginManager automatically validates all plugins on load:
120
+
121
+ - **Schema validation**: Required fields must be present
122
+ - **Type checking**: Fields must have correct types
123
+ - **Unique IDs**: No duplicate plugin IDs allowed
124
+ - **JSON syntax**: Files must be valid JSON
125
+
126
+ Run tests to validate your plugin:
127
+
128
+ ```bash
129
+ bun test test/plugins/
130
+ ```
131
+
132
+ ## Community Contributions
133
+
134
+ We welcome community contributions for new AI coding agents!
135
+
136
+ **Before submitting:**
137
+ 1. Ensure your plugin passes all validation tests
138
+ 2. Test the agent setup with `bunx forge setup --agents your-agent`
139
+ 3. Document any special setup requirements
140
+ 4. Follow the existing plugin structure
141
+
142
+ **PR Guidelines:**
143
+ - One plugin per PR
144
+ - Include plugin JSON file only (no code changes needed)
145
+ - Update this README with agent information
146
+ - Test that all existing tests still pass
147
+
148
+ ## Technical Details
149
+
150
+ ### Plugin Loading
151
+
152
+ The `PluginManager` class (`lib/plugin-manager.js`) handles:
153
+ - Auto-discovery of `.plugin.json` files in this directory
154
+ - Schema validation for each plugin
155
+ - Conversion to internal AGENTS format (backwards compatibility)
156
+ - Error handling for invalid plugins
157
+
158
+ ### Backwards Compatibility
159
+
160
+ Plugins are automatically converted to the legacy AGENTS object structure:
161
+
162
+ ```javascript
163
+ {
164
+ name: plugin.name,
165
+ description: plugin.description,
166
+ dirs: Object.values(plugin.directories),
167
+ hasCommands: plugin.capabilities?.commands,
168
+ hasSkill: plugin.capabilities?.skills,
169
+ // ... other fields
170
+ }
171
+ ```
172
+
173
+ This ensures existing code continues to work without modifications.
174
+
175
+ ## Troubleshooting
176
+
177
+ ### Plugin Not Loading
178
+
179
+ If your plugin isn't appearing in `bunx forge setup`:
180
+
181
+ 1. **Check filename**: Must end with `.plugin.json`
182
+ 2. **Validate JSON**: Ensure file is valid JSON (no trailing commas, quotes correct)
183
+ 3. **Check required fields**: id, name, version, directories must be present
184
+ 4. **Run tests**: `bun test test/plugins/` will show specific errors
185
+ 5. **Check logs**: Any loading errors will be displayed
186
+
187
+ ### Schema Validation Errors
188
+
189
+ Common validation errors:
190
+
191
+ - `missing required field "id"`: Add the id field
192
+ - `"directories" must be an object`: Ensure directories is an object, not array
193
+ - `"version" must be a string`: Version must be in "x.y.z" format
194
+ - `Plugin with ID "x" already exists`: Choose a unique ID
195
+
196
+ ## License
197
+
198
+ All plugin definitions in this directory are MIT licensed, same as the Forge project.
@@ -0,0 +1,28 @@
1
+ {
2
+ "id": "claude",
3
+ "name": "Claude Code",
4
+ "version": "1.0.0",
5
+ "description": "Anthropic's CLI agent",
6
+ "homepage": "https://claude.ai/code",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": true
11
+ },
12
+ "directories": {
13
+ "commands": ".claude/commands",
14
+ "rules": ".claude/rules",
15
+ "skills": ".claude/skills/forge-workflow",
16
+ "scripts": ".claude/scripts"
17
+ },
18
+ "files": {
19
+ "rootConfig": "CLAUDE.md",
20
+ "skillDefinition": ".claude/skills/forge-workflow/SKILL.md"
21
+ },
22
+ "setup": {
23
+ "copyCommands": true,
24
+ "copyRules": true,
25
+ "copyScripts": true,
26
+ "createSkill": true
27
+ }
28
+ }
@@ -0,0 +1,22 @@
1
+ {
2
+ "id": "cline",
3
+ "name": "Cline",
4
+ "version": "1.0.0",
5
+ "description": "VS Code agent extension",
6
+ "homepage": "https://github.com/cline/cline",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "workflows": ".clinerules/workflows",
14
+ "skills": ".cline/skills/forge-workflow"
15
+ },
16
+ "files": {
17
+ "rootConfig": ".clinerules"
18
+ },
19
+ "setup": {
20
+ "createSkill": true
21
+ }
22
+ }
@@ -0,0 +1,19 @@
1
+ {
2
+ "id": "codex",
3
+ "name": "OpenAI Codex CLI",
4
+ "version": "1.0.0",
5
+ "description": "OpenAI's terminal coding agent",
6
+ "homepage": "https://github.com/openai/codex",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": false,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "skills": ".codex/skills"
14
+ },
15
+ "setup": {
16
+ "copyRules": false,
17
+ "createSkill": false
18
+ }
19
+ }
@@ -0,0 +1,24 @@
1
+ {
2
+ "id": "copilot",
3
+ "name": "GitHub Copilot",
4
+ "version": "1.0.0",
5
+ "description": "GitHub's AI assistant",
6
+ "homepage": "https://github.com/features/copilot",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "prompts": ".github/prompts",
14
+ "instructions": ".github/instructions",
15
+ "skills": ".github/skills/forge-workflow"
16
+ },
17
+ "files": {
18
+ "rootConfig": ".github/copilot-instructions.md"
19
+ },
20
+ "setup": {
21
+ "needsConversion": true,
22
+ "promptFormat": true
23
+ }
24
+ }
@@ -0,0 +1,25 @@
1
+ {
2
+ "id": "cursor",
3
+ "name": "Cursor",
4
+ "version": "1.0.0",
5
+ "description": "AI-first code editor",
6
+ "homepage": "https://cursor.sh",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "commands": ".cursor/commands",
14
+ "rules": ".cursor/rules",
15
+ "skills": ".cursor/skills/forge-workflow"
16
+ },
17
+ "files": {
18
+ "rootConfig": ".cursorrules"
19
+ },
20
+ "setup": {
21
+ "copyRules": true,
22
+ "createSkill": true,
23
+ "customSetup": "cursor"
24
+ }
25
+ }
@@ -0,0 +1,22 @@
1
+ {
2
+ "id": "kilocode",
3
+ "name": "Kilo Code",
4
+ "version": "1.0.0",
5
+ "description": "VS Code extension",
6
+ "homepage": "https://marketplace.visualstudio.com/items?itemName=kilo-code",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "workflows": ".kilocode/workflows",
14
+ "rules": ".kilocode/rules",
15
+ "skills": ".kilocode/skills/forge-workflow"
16
+ },
17
+ "setup": {
18
+ "copyRules": true,
19
+ "createSkill": true,
20
+ "needsConversion": true
21
+ }
22
+ }
@@ -0,0 +1,20 @@
1
+ {
2
+ "id": "opencode",
3
+ "name": "OpenCode",
4
+ "version": "1.0.0",
5
+ "description": "Open-source agent",
6
+ "homepage": "https://opencode.ai",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "commands": ".opencode/commands",
14
+ "skills": ".opencode/skills/forge-workflow"
15
+ },
16
+ "setup": {
17
+ "copyCommands": true,
18
+ "createSkill": true
19
+ }
20
+ }
@@ -0,0 +1,23 @@
1
+ {
2
+ "id": "roo",
3
+ "name": "Roo Code",
4
+ "version": "1.0.0",
5
+ "description": "Cline fork with modes",
6
+ "homepage": "https://github.com/roocode/roo",
7
+ "capabilities": {
8
+ "commands": true,
9
+ "skills": true,
10
+ "hooks": false
11
+ },
12
+ "directories": {
13
+ "commands": ".roo/commands",
14
+ "skills": ".roo/skills/forge-workflow"
15
+ },
16
+ "files": {
17
+ "rootConfig": ".clinerules"
18
+ },
19
+ "setup": {
20
+ "copyCommands": true,
21
+ "needsConversion": true
22
+ }
23
+ }