@clawplays/ospec-cli 0.1.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 (191) hide show
  1. package/.ospec/templates/hooks/post-merge +8 -0
  2. package/.ospec/templates/hooks/pre-commit +8 -0
  3. package/LICENSE +21 -0
  4. package/README.md +549 -0
  5. package/README.zh-CN.md +549 -0
  6. package/assets/for-ai/en-US/ai-guide.md +98 -0
  7. package/assets/for-ai/en-US/execution-protocol.md +64 -0
  8. package/assets/for-ai/zh-CN/ai-guide.md +102 -0
  9. package/assets/for-ai/zh-CN/execution-protocol.md +68 -0
  10. package/assets/git-hooks/post-merge +12 -0
  11. package/assets/git-hooks/pre-commit +12 -0
  12. package/assets/global-skills/claude/ospec-change/SKILL.md +116 -0
  13. package/assets/global-skills/codex/ospec-change/SKILL.md +117 -0
  14. package/assets/global-skills/codex/ospec-change/agents/openai.yaml +7 -0
  15. package/assets/global-skills/codex/ospec-change/skill.yaml +19 -0
  16. package/assets/project-conventions/en-US/development-guide.md +32 -0
  17. package/assets/project-conventions/en-US/naming-conventions.md +51 -0
  18. package/assets/project-conventions/en-US/skill-conventions.md +40 -0
  19. package/assets/project-conventions/en-US/workflow-conventions.md +70 -0
  20. package/assets/project-conventions/zh-CN/development-guide.md +32 -0
  21. package/assets/project-conventions/zh-CN/naming-conventions.md +51 -0
  22. package/assets/project-conventions/zh-CN/skill-conventions.md +40 -0
  23. package/assets/project-conventions/zh-CN/workflow-conventions.md +74 -0
  24. package/dist/adapters/codex-stitch-adapter.js +420 -0
  25. package/dist/adapters/gemini-stitch-adapter.js +408 -0
  26. package/dist/adapters/playwright-checkpoint-adapter.js +2260 -0
  27. package/dist/advanced/BatchOperations.d.ts +36 -0
  28. package/dist/advanced/BatchOperations.js +159 -0
  29. package/dist/advanced/CachingLayer.d.ts +66 -0
  30. package/dist/advanced/CachingLayer.js +136 -0
  31. package/dist/advanced/FeatureUpdater.d.ts +46 -0
  32. package/dist/advanced/FeatureUpdater.js +151 -0
  33. package/dist/advanced/PerformanceMonitor.d.ts +52 -0
  34. package/dist/advanced/PerformanceMonitor.js +129 -0
  35. package/dist/advanced/StatePersistence.d.ts +61 -0
  36. package/dist/advanced/StatePersistence.js +168 -0
  37. package/dist/advanced/index.d.ts +14 -0
  38. package/dist/advanced/index.js +22 -0
  39. package/dist/cli/commands/config.d.ts +5 -0
  40. package/dist/cli/commands/config.js +6 -0
  41. package/dist/cli/commands/feature.d.ts +5 -0
  42. package/dist/cli/commands/feature.js +6 -0
  43. package/dist/cli/commands/index.d.ts +5 -0
  44. package/dist/cli/commands/index.js +6 -0
  45. package/dist/cli/commands/project.d.ts +5 -0
  46. package/dist/cli/commands/project.js +6 -0
  47. package/dist/cli/commands/validate.d.ts +5 -0
  48. package/dist/cli/commands/validate.js +6 -0
  49. package/dist/cli/index.d.ts +5 -0
  50. package/dist/cli/index.js +6 -0
  51. package/dist/cli.d.ts +3 -0
  52. package/dist/cli.js +1007 -0
  53. package/dist/commands/ArchiveCommand.d.ts +14 -0
  54. package/dist/commands/ArchiveCommand.js +241 -0
  55. package/dist/commands/BaseCommand.d.ts +33 -0
  56. package/dist/commands/BaseCommand.js +46 -0
  57. package/dist/commands/BatchCommand.d.ts +5 -0
  58. package/dist/commands/BatchCommand.js +42 -0
  59. package/dist/commands/ChangesCommand.d.ts +3 -0
  60. package/dist/commands/ChangesCommand.js +71 -0
  61. package/dist/commands/DocsCommand.d.ts +5 -0
  62. package/dist/commands/DocsCommand.js +118 -0
  63. package/dist/commands/FinalizeCommand.d.ts +3 -0
  64. package/dist/commands/FinalizeCommand.js +24 -0
  65. package/dist/commands/IndexCommand.d.ts +5 -0
  66. package/dist/commands/IndexCommand.js +57 -0
  67. package/dist/commands/InitCommand.d.ts +5 -0
  68. package/dist/commands/InitCommand.js +65 -0
  69. package/dist/commands/NewCommand.d.ts +11 -0
  70. package/dist/commands/NewCommand.js +262 -0
  71. package/dist/commands/PluginsCommand.d.ts +58 -0
  72. package/dist/commands/PluginsCommand.js +2491 -0
  73. package/dist/commands/ProgressCommand.d.ts +5 -0
  74. package/dist/commands/ProgressCommand.js +103 -0
  75. package/dist/commands/QueueCommand.d.ts +10 -0
  76. package/dist/commands/QueueCommand.js +147 -0
  77. package/dist/commands/RunCommand.d.ts +13 -0
  78. package/dist/commands/RunCommand.js +200 -0
  79. package/dist/commands/SkillCommand.d.ts +31 -0
  80. package/dist/commands/SkillCommand.js +1216 -0
  81. package/dist/commands/SkillsCommand.d.ts +5 -0
  82. package/dist/commands/SkillsCommand.js +68 -0
  83. package/dist/commands/StatusCommand.d.ts +6 -0
  84. package/dist/commands/StatusCommand.js +140 -0
  85. package/dist/commands/UpdateCommand.d.ts +8 -0
  86. package/dist/commands/UpdateCommand.js +251 -0
  87. package/dist/commands/VerifyCommand.d.ts +5 -0
  88. package/dist/commands/VerifyCommand.js +278 -0
  89. package/dist/commands/WorkflowCommand.d.ts +12 -0
  90. package/dist/commands/WorkflowCommand.js +150 -0
  91. package/dist/commands/index.d.ts +43 -0
  92. package/dist/commands/index.js +85 -0
  93. package/dist/core/constants.d.ts +41 -0
  94. package/dist/core/constants.js +73 -0
  95. package/dist/core/errors.d.ts +36 -0
  96. package/dist/core/errors.js +72 -0
  97. package/dist/core/index.d.ts +7 -0
  98. package/dist/core/index.js +23 -0
  99. package/dist/core/types.d.ts +369 -0
  100. package/dist/core/types.js +3 -0
  101. package/dist/index.d.ts +11 -0
  102. package/dist/index.js +27 -0
  103. package/dist/presets/ProjectPresets.d.ts +41 -0
  104. package/dist/presets/ProjectPresets.js +190 -0
  105. package/dist/scaffolds/ProjectScaffoldPresets.d.ts +20 -0
  106. package/dist/scaffolds/ProjectScaffoldPresets.js +151 -0
  107. package/dist/services/ConfigManager.d.ts +14 -0
  108. package/dist/services/ConfigManager.js +386 -0
  109. package/dist/services/FeatureManager.d.ts +5 -0
  110. package/dist/services/FeatureManager.js +6 -0
  111. package/dist/services/FileService.d.ts +21 -0
  112. package/dist/services/FileService.js +152 -0
  113. package/dist/services/IndexBuilder.d.ts +12 -0
  114. package/dist/services/IndexBuilder.js +130 -0
  115. package/dist/services/Logger.d.ts +20 -0
  116. package/dist/services/Logger.js +48 -0
  117. package/dist/services/ProjectAssetRegistry.d.ts +12 -0
  118. package/dist/services/ProjectAssetRegistry.js +96 -0
  119. package/dist/services/ProjectAssetService.d.ts +49 -0
  120. package/dist/services/ProjectAssetService.js +223 -0
  121. package/dist/services/ProjectScaffoldCommandService.d.ts +73 -0
  122. package/dist/services/ProjectScaffoldCommandService.js +159 -0
  123. package/dist/services/ProjectScaffoldService.d.ts +44 -0
  124. package/dist/services/ProjectScaffoldService.js +507 -0
  125. package/dist/services/ProjectService.d.ts +209 -0
  126. package/dist/services/ProjectService.js +13239 -0
  127. package/dist/services/QueueService.d.ts +17 -0
  128. package/dist/services/QueueService.js +142 -0
  129. package/dist/services/RunService.d.ts +40 -0
  130. package/dist/services/RunService.js +420 -0
  131. package/dist/services/SkillParser.d.ts +30 -0
  132. package/dist/services/SkillParser.js +88 -0
  133. package/dist/services/StateManager.d.ts +16 -0
  134. package/dist/services/StateManager.js +127 -0
  135. package/dist/services/TemplateEngine.d.ts +43 -0
  136. package/dist/services/TemplateEngine.js +119 -0
  137. package/dist/services/TemplateGenerator.d.ts +40 -0
  138. package/dist/services/TemplateGenerator.js +273 -0
  139. package/dist/services/ValidationService.d.ts +19 -0
  140. package/dist/services/ValidationService.js +44 -0
  141. package/dist/services/Validator.d.ts +5 -0
  142. package/dist/services/Validator.js +6 -0
  143. package/dist/services/index.d.ts +52 -0
  144. package/dist/services/index.js +91 -0
  145. package/dist/services/templates/ExecutionTemplateBuilder.d.ts +12 -0
  146. package/dist/services/templates/ExecutionTemplateBuilder.js +300 -0
  147. package/dist/services/templates/ProjectTemplateBuilder.d.ts +38 -0
  148. package/dist/services/templates/ProjectTemplateBuilder.js +1897 -0
  149. package/dist/services/templates/TemplateBuilderBase.d.ts +19 -0
  150. package/dist/services/templates/TemplateBuilderBase.js +60 -0
  151. package/dist/services/templates/TemplateInputFactory.d.ts +16 -0
  152. package/dist/services/templates/TemplateInputFactory.js +298 -0
  153. package/dist/services/templates/templateTypes.d.ts +90 -0
  154. package/dist/services/templates/templateTypes.js +3 -0
  155. package/dist/tools/build-index.js +632 -0
  156. package/dist/utils/DateUtils.d.ts +18 -0
  157. package/dist/utils/DateUtils.js +40 -0
  158. package/dist/utils/PathUtils.d.ts +9 -0
  159. package/dist/utils/PathUtils.js +66 -0
  160. package/dist/utils/StringUtils.d.ts +26 -0
  161. package/dist/utils/StringUtils.js +47 -0
  162. package/dist/utils/helpers.d.ts +5 -0
  163. package/dist/utils/helpers.js +6 -0
  164. package/dist/utils/index.d.ts +7 -0
  165. package/dist/utils/index.js +23 -0
  166. package/dist/utils/logger.d.ts +5 -0
  167. package/dist/utils/logger.js +6 -0
  168. package/dist/utils/path.d.ts +5 -0
  169. package/dist/utils/path.js +6 -0
  170. package/dist/utils/subcommandHelp.d.ts +11 -0
  171. package/dist/utils/subcommandHelp.js +119 -0
  172. package/dist/workflow/ArchiveGate.d.ts +30 -0
  173. package/dist/workflow/ArchiveGate.js +93 -0
  174. package/dist/workflow/ConfigurableWorkflow.d.ts +89 -0
  175. package/dist/workflow/ConfigurableWorkflow.js +186 -0
  176. package/dist/workflow/HookSystem.d.ts +38 -0
  177. package/dist/workflow/HookSystem.js +66 -0
  178. package/dist/workflow/IndexRegenerator.d.ts +49 -0
  179. package/dist/workflow/IndexRegenerator.js +147 -0
  180. package/dist/workflow/PluginWorkflowComposer.d.ts +138 -0
  181. package/dist/workflow/PluginWorkflowComposer.js +239 -0
  182. package/dist/workflow/SkillUpdateEngine.d.ts +26 -0
  183. package/dist/workflow/SkillUpdateEngine.js +113 -0
  184. package/dist/workflow/VerificationSystem.d.ts +24 -0
  185. package/dist/workflow/VerificationSystem.js +116 -0
  186. package/dist/workflow/WorkflowEngine.d.ts +15 -0
  187. package/dist/workflow/WorkflowEngine.js +57 -0
  188. package/dist/workflow/index.d.ts +19 -0
  189. package/dist/workflow/index.js +32 -0
  190. package/package.json +78 -0
  191. package/scripts/postinstall.js +43 -0
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+ /**
3
+ * SKILL 解析服务
4
+ */
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.skillParser = exports.SkillParser = void 0;
10
+ const gray_matter_1 = __importDefault(require("gray-matter"));
11
+ class SkillParser {
12
+ normalizeLineEndings(content) {
13
+ return String(content || '').replace(/\r\n?/g, '\n');
14
+ }
15
+ /**
16
+ * 解析 SKILL.md 的前置信息和内容
17
+ */
18
+ parseFrontmatter(content) {
19
+ const normalizedContent = this.normalizeLineEndings(content);
20
+ const { data, content: body } = (0, gray_matter_1.default)(normalizedContent);
21
+ const tags = Array.isArray(data.tags)
22
+ ? data.tags.map(tag => String(tag).trim()).filter(Boolean)
23
+ : typeof data.tags === 'string'
24
+ ? data.tags.split(',').map(tag => tag.trim()).filter(Boolean)
25
+ : [];
26
+ const title = typeof data.title === 'string' && data.title.trim().length > 0
27
+ ? data.title.trim()
28
+ : this.extractDocumentTitle(body);
29
+ const name = typeof data.name === 'string' && data.name.trim().length > 0
30
+ ? data.name.trim()
31
+ : title || 'Unknown';
32
+ return {
33
+ data: {
34
+ name,
35
+ title: title || undefined,
36
+ tags,
37
+ },
38
+ content: body,
39
+ };
40
+ }
41
+ /**
42
+ * 提取 Markdown 中的标题结构
43
+ */
44
+ extractSections(content) {
45
+ const sections = {};
46
+ const headingRegex = /^(#{1,6})\s+(.+?)$/gm;
47
+ const matches = [];
48
+ let match;
49
+ while ((match = headingRegex.exec(content)) !== null) {
50
+ matches.push({
51
+ level: match[1].length,
52
+ title: match[2].trim(),
53
+ start: match.index,
54
+ headerEnd: match.index + match[0].length,
55
+ });
56
+ }
57
+ for (let index = 0; index < matches.length; index += 1) {
58
+ const current = matches[index];
59
+ const next = matches[index + 1];
60
+ sections[current.title] = {
61
+ level: current.level,
62
+ title: current.title,
63
+ start: current.start,
64
+ end: next ? next.start : content.length,
65
+ };
66
+ }
67
+ return sections;
68
+ }
69
+ /**
70
+ * 完整解析 SKILL.md 文件
71
+ */
72
+ parseSkillFile(content) {
73
+ const { data, content: body } = this.parseFrontmatter(this.normalizeLineEndings(content));
74
+ const sections = this.extractSections(body);
75
+ return {
76
+ frontmatter: data,
77
+ sections,
78
+ content: body,
79
+ };
80
+ }
81
+ extractDocumentTitle(content) {
82
+ const titleMatch = content.match(/^#\s+(.+)$/m);
83
+ return titleMatch?.[1]?.trim() || null;
84
+ }
85
+ }
86
+ exports.SkillParser = SkillParser;
87
+ exports.skillParser = new SkillParser();
88
+ //# sourceMappingURL=SkillParser.js.map
@@ -0,0 +1,16 @@
1
+ import { FeatureState, FeatureStatus, ProjectMode } from '../core/types';
2
+ import { FileService } from './FileService';
3
+ export declare class StateManager {
4
+ private fileService;
5
+ constructor(fileService: FileService);
6
+ readState(featurePath: string): Promise<FeatureState>;
7
+ writeState(featurePath: string, state: FeatureState): Promise<void>;
8
+ validateTransition(currentStatus: FeatureStatus, targetStatus: FeatureStatus): boolean;
9
+ transitionStatus(featurePath: string, targetStatus: FeatureStatus): Promise<void>;
10
+ createInitialState(feature: string, affects: string[], mode?: ProjectMode, options?: {
11
+ queued?: boolean;
12
+ source?: string;
13
+ }): FeatureState;
14
+ }
15
+ export declare function createStateManager(fileService: FileService): StateManager;
16
+ //# sourceMappingURL=StateManager.d.ts.map
@@ -0,0 +1,127 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.StateManager = void 0;
37
+ exports.createStateManager = createStateManager;
38
+ const path = __importStar(require("path"));
39
+ const constants_1 = require("../core/constants");
40
+ const errors_1 = require("../core/errors");
41
+ class StateManager {
42
+ constructor(fileService) {
43
+ this.fileService = fileService;
44
+ }
45
+ async readState(featurePath) {
46
+ const statePath = path.join(featurePath, constants_1.FILE_NAMES.STATE);
47
+ try {
48
+ return await this.fileService.readJSON(statePath);
49
+ }
50
+ catch {
51
+ throw new errors_1.FeatureNotFoundError(featurePath);
52
+ }
53
+ }
54
+ async writeState(featurePath, state) {
55
+ const statePath = path.join(featurePath, constants_1.FILE_NAMES.STATE);
56
+ state.last_updated = new Date().toISOString();
57
+ await this.fileService.writeJSON(statePath, state);
58
+ }
59
+ validateTransition(currentStatus, targetStatus) {
60
+ const allowedTransitions = constants_1.STATE_TRANSITIONS[currentStatus];
61
+ return Boolean(allowedTransitions && allowedTransitions.includes(targetStatus));
62
+ }
63
+ async transitionStatus(featurePath, targetStatus) {
64
+ const state = await this.readState(featurePath);
65
+ const currentStatus = state.status;
66
+ if (!this.validateTransition(currentStatus, targetStatus)) {
67
+ throw new errors_1.InvalidStateTransitionError(currentStatus, targetStatus);
68
+ }
69
+ state.status = targetStatus;
70
+ state.current_step = targetStatus;
71
+ await this.writeState(featurePath, state);
72
+ }
73
+ createInitialState(feature, affects, mode = 'standard', options = {}) {
74
+ const now = new Date().toISOString();
75
+ if (options.queued) {
76
+ return {
77
+ version: '1.0',
78
+ feature,
79
+ mode,
80
+ status: 'queued',
81
+ current_step: 'queued',
82
+ affects,
83
+ completed: [],
84
+ pending: [
85
+ 'proposal_complete',
86
+ 'tasks_complete',
87
+ 'implementation_complete',
88
+ 'skill_updated',
89
+ 'index_regenerated',
90
+ 'tests_passed',
91
+ 'verification_passed',
92
+ 'archived',
93
+ ],
94
+ blocked_by: ['awaiting_activation'],
95
+ queued_at: now,
96
+ queue_source: options.source ?? 'queue',
97
+ last_updated: now,
98
+ };
99
+ }
100
+ return {
101
+ version: '1.0',
102
+ feature,
103
+ mode,
104
+ status: 'draft',
105
+ current_step: 'write_proposal',
106
+ affects,
107
+ completed: [],
108
+ pending: [
109
+ 'proposal_complete',
110
+ 'tasks_complete',
111
+ 'implementation_complete',
112
+ 'skill_updated',
113
+ 'index_regenerated',
114
+ 'tests_passed',
115
+ 'verification_passed',
116
+ 'archived',
117
+ ],
118
+ blocked_by: ['missing_proposal'],
119
+ last_updated: now,
120
+ };
121
+ }
122
+ }
123
+ exports.StateManager = StateManager;
124
+ function createStateManager(fileService) {
125
+ return new StateManager(fileService);
126
+ }
127
+ //# sourceMappingURL=StateManager.js.map
@@ -0,0 +1,43 @@
1
+ import { ProjectMode } from '../core/types';
2
+ export type { BootstrapFieldKey, BootstrapFieldSource, FeatureProjectContext, FeatureProjectReference, FeatureTemplateInput, NormalizedFeatureTemplateInput, NormalizedProjectBootstrapInput, PlannedProjectFile, ProjectBootstrapInput, TemplateDocumentLanguage, } from './templates/templateTypes';
3
+ import { FeatureTemplateInput, NormalizedFeatureTemplateInput, NormalizedProjectBootstrapInput, ProjectBootstrapInput } from './templates/templateTypes';
4
+ export declare class TemplateEngine {
5
+ private readonly inputFactory;
6
+ private readonly executionBuilder;
7
+ private readonly projectBuilder;
8
+ render(template: string, context: Record<string, unknown>): string;
9
+ parseSkillMetadata(content: string): {
10
+ title: string | null;
11
+ tags: string[];
12
+ };
13
+ normalizeFeatureTemplateInput(input: string | FeatureTemplateInput): NormalizedFeatureTemplateInput;
14
+ normalizeProjectBootstrapInput(input: ProjectBootstrapInput | undefined, fallbackName: string, mode: ProjectMode, inferredDefaults?: Partial<ProjectBootstrapInput>, presetDefaults?: Partial<ProjectBootstrapInput>): NormalizedProjectBootstrapInput;
15
+ generateProposalTemplate(input: string | FeatureTemplateInput): string;
16
+ generateTasksTemplate(input: string | FeatureTemplateInput): string;
17
+ generateVerificationTemplate(input: string | FeatureTemplateInput): string;
18
+ generateReviewTemplate(input: string | FeatureTemplateInput): string;
19
+ generateProjectReadmeTemplate(fallbackName: string, mode: ProjectMode, input?: ProjectBootstrapInput): string;
20
+ generateRootSkillTemplate(fallbackName: string, mode: ProjectMode, input?: ProjectBootstrapInput): string;
21
+ generateDocsSkillTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
22
+ generateSrcSkillTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
23
+ generateCoreSkillTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
24
+ generateTestsSkillTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
25
+ generateProjectOverviewTemplate(fallbackName: string, mode: ProjectMode, input?: ProjectBootstrapInput): string;
26
+ generateTechStackTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
27
+ generateArchitectureTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
28
+ generateModuleMapTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
29
+ generateApiOverviewTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
30
+ generateDesignDocsTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
31
+ generatePlanningDocsTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
32
+ generateApiDocsTemplate(fallbackName: string, input?: ProjectBootstrapInput): string;
33
+ generateModuleSkillTemplate(fallbackName: string, moduleName: string, input?: ProjectBootstrapInput, moduleSlug?: string): string;
34
+ generateApiAreaDocTemplate(fallbackName: string, apiAreaName: string, input?: ProjectBootstrapInput): string;
35
+ generateModuleApiDocTemplate(fallbackName: string, moduleName: string, input?: ProjectBootstrapInput, moduleSlug?: string): string;
36
+ generateDesignDocTemplate(fallbackName: string, docName: string, input?: ProjectBootstrapInput): string;
37
+ generatePlanningDocTemplate(fallbackName: string, docName: string, input?: ProjectBootstrapInput): string;
38
+ generateAiGuideTemplate(input?: ProjectBootstrapInput): string;
39
+ generateExecutionProtocolTemplate(input?: ProjectBootstrapInput): string;
40
+ generateBuildIndexScriptTemplate(): string;
41
+ }
42
+ export declare const templateEngine: TemplateEngine;
43
+ //# sourceMappingURL=TemplateEngine.d.ts.map
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.templateEngine = exports.TemplateEngine = void 0;
4
+ const ExecutionTemplateBuilder_1 = require("./templates/ExecutionTemplateBuilder");
5
+ const ProjectTemplateBuilder_1 = require("./templates/ProjectTemplateBuilder");
6
+ const TemplateInputFactory_1 = require("./templates/TemplateInputFactory");
7
+ class TemplateEngine {
8
+ constructor() {
9
+ this.inputFactory = new TemplateInputFactory_1.TemplateInputFactory();
10
+ this.executionBuilder = new ExecutionTemplateBuilder_1.ExecutionTemplateBuilder(this.inputFactory);
11
+ this.projectBuilder = new ProjectTemplateBuilder_1.ProjectTemplateBuilder(this.inputFactory);
12
+ }
13
+ render(template, context) {
14
+ return template.replace(/\{\{(\w+)\}\}/g, (match, key) => {
15
+ return context[key] !== undefined ? String(context[key]) : match;
16
+ });
17
+ }
18
+ parseSkillMetadata(content) {
19
+ const titleMatch = content.match(/^#\s+(.+)$/m);
20
+ const tagsMatch = content.match(/^tags:\s*\[(.*)\]\s*$/m);
21
+ const tags = tagsMatch?.[1]
22
+ ? tagsMatch[1]
23
+ .split(',')
24
+ .map(tag => tag.trim())
25
+ .filter(Boolean)
26
+ : [];
27
+ return {
28
+ title: titleMatch?.[1]?.trim() || null,
29
+ tags,
30
+ };
31
+ }
32
+ normalizeFeatureTemplateInput(input) {
33
+ return this.inputFactory.normalizeFeatureTemplateInput(input);
34
+ }
35
+ normalizeProjectBootstrapInput(input, fallbackName, mode, inferredDefaults, presetDefaults) {
36
+ return this.inputFactory.normalizeProjectBootstrapInput(input, fallbackName, mode, inferredDefaults, presetDefaults);
37
+ }
38
+ generateProposalTemplate(input) {
39
+ return this.executionBuilder.generateProposalTemplate(input);
40
+ }
41
+ generateTasksTemplate(input) {
42
+ return this.executionBuilder.generateTasksTemplate(input);
43
+ }
44
+ generateVerificationTemplate(input) {
45
+ return this.executionBuilder.generateVerificationTemplate(input);
46
+ }
47
+ generateReviewTemplate(input) {
48
+ return this.executionBuilder.generateReviewTemplate(input);
49
+ }
50
+ generateProjectReadmeTemplate(fallbackName, mode, input) {
51
+ return this.projectBuilder.generateProjectReadmeTemplate(fallbackName, mode, input);
52
+ }
53
+ generateRootSkillTemplate(fallbackName, mode, input) {
54
+ return this.projectBuilder.generateRootSkillTemplate(fallbackName, mode, input);
55
+ }
56
+ generateDocsSkillTemplate(fallbackName, input) {
57
+ return this.projectBuilder.generateDocsSkillTemplate(fallbackName, input);
58
+ }
59
+ generateSrcSkillTemplate(fallbackName, input) {
60
+ return this.projectBuilder.generateSrcSkillTemplate(fallbackName, input);
61
+ }
62
+ generateCoreSkillTemplate(fallbackName, input) {
63
+ return this.projectBuilder.generateCoreSkillTemplate(fallbackName, input);
64
+ }
65
+ generateTestsSkillTemplate(fallbackName, input) {
66
+ return this.projectBuilder.generateTestsSkillTemplate(fallbackName, input);
67
+ }
68
+ generateProjectOverviewTemplate(fallbackName, mode, input) {
69
+ return this.projectBuilder.generateProjectOverviewTemplate(fallbackName, mode, input);
70
+ }
71
+ generateTechStackTemplate(fallbackName, input) {
72
+ return this.projectBuilder.generateTechStackTemplate(fallbackName, input);
73
+ }
74
+ generateArchitectureTemplate(fallbackName, input) {
75
+ return this.projectBuilder.generateArchitectureTemplate(fallbackName, input);
76
+ }
77
+ generateModuleMapTemplate(fallbackName, input) {
78
+ return this.projectBuilder.generateModuleMapTemplate(fallbackName, input);
79
+ }
80
+ generateApiOverviewTemplate(fallbackName, input) {
81
+ return this.projectBuilder.generateApiOverviewTemplate(fallbackName, input);
82
+ }
83
+ generateDesignDocsTemplate(fallbackName, input) {
84
+ return this.projectBuilder.generateDesignDocsTemplate(fallbackName, input);
85
+ }
86
+ generatePlanningDocsTemplate(fallbackName, input) {
87
+ return this.projectBuilder.generatePlanningDocsTemplate(fallbackName, input);
88
+ }
89
+ generateApiDocsTemplate(fallbackName, input) {
90
+ return this.projectBuilder.generateApiDocsTemplate(fallbackName, input);
91
+ }
92
+ generateModuleSkillTemplate(fallbackName, moduleName, input, moduleSlug) {
93
+ return this.projectBuilder.generateModuleSkillTemplate(fallbackName, moduleName, input, moduleSlug);
94
+ }
95
+ generateApiAreaDocTemplate(fallbackName, apiAreaName, input) {
96
+ return this.projectBuilder.generateApiAreaDocTemplate(fallbackName, apiAreaName, input);
97
+ }
98
+ generateModuleApiDocTemplate(fallbackName, moduleName, input, moduleSlug) {
99
+ return this.projectBuilder.generateModuleApiDocTemplate(fallbackName, moduleName, input, moduleSlug);
100
+ }
101
+ generateDesignDocTemplate(fallbackName, docName, input) {
102
+ return this.projectBuilder.generateDesignDocTemplate(fallbackName, docName, input);
103
+ }
104
+ generatePlanningDocTemplate(fallbackName, docName, input) {
105
+ return this.projectBuilder.generatePlanningDocTemplate(fallbackName, docName, input);
106
+ }
107
+ generateAiGuideTemplate(input) {
108
+ return this.projectBuilder.generateAiGuideTemplate(input);
109
+ }
110
+ generateExecutionProtocolTemplate(input) {
111
+ return this.projectBuilder.generateExecutionProtocolTemplate(input);
112
+ }
113
+ generateBuildIndexScriptTemplate() {
114
+ return this.projectBuilder.generateBuildIndexScriptTemplate();
115
+ }
116
+ }
117
+ exports.TemplateEngine = TemplateEngine;
118
+ exports.templateEngine = new TemplateEngine();
119
+ //# sourceMappingURL=TemplateEngine.js.map
@@ -0,0 +1,40 @@
1
+ /**
2
+ * 模板生成服务
3
+ * 负责生成 proposal.md、tasks.md、verification.md 等模板文件
4
+ */
5
+ import { FeatureState } from '../core/types';
6
+ export declare class TemplateGenerator {
7
+ /**
8
+ * 生成 proposal.md 模板
9
+ */
10
+ static generateProposalTemplate(featureName: string, affects?: string[]): string;
11
+ /**
12
+ * 生成 tasks.md 模板
13
+ */
14
+ static generateTasksTemplate(featureName: string, coreRequiredSteps?: string[], optionalSteps?: string[]): string;
15
+ /**
16
+ * 生成 verification.md 模板
17
+ */
18
+ static generateVerificationTemplate(featureName: string, optionalSteps?: string[]): string;
19
+ /**
20
+ * 生成 state.json 内容
21
+ */
22
+ static generateStateJson(featureName: string, affects?: string[], mode?: 'lite' | 'standard' | 'full'): FeatureState;
23
+ /**
24
+ * 创建 feature 目录和文件
25
+ */
26
+ static createFeatureDirectory(projectRoot: string, featureName: string, affects?: string[], coreRequiredSteps?: string[], optionalSteps?: string[]): Promise<void>;
27
+ /**
28
+ * 生成项目初始化文件
29
+ */
30
+ static initializeProject(projectRoot: string, mode?: 'lite' | 'standard' | 'full'): Promise<void>;
31
+ /**
32
+ * 生成 AI 指南
33
+ */
34
+ private static generateAiGuide;
35
+ /**
36
+ * 生成执行协议
37
+ */
38
+ private static generateExecutionProtocol;
39
+ }
40
+ //# sourceMappingURL=TemplateGenerator.d.ts.map