@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.
- package/.ospec/templates/hooks/post-merge +8 -0
- package/.ospec/templates/hooks/pre-commit +8 -0
- package/LICENSE +21 -0
- package/README.md +549 -0
- package/README.zh-CN.md +549 -0
- package/assets/for-ai/en-US/ai-guide.md +98 -0
- package/assets/for-ai/en-US/execution-protocol.md +64 -0
- package/assets/for-ai/zh-CN/ai-guide.md +102 -0
- package/assets/for-ai/zh-CN/execution-protocol.md +68 -0
- package/assets/git-hooks/post-merge +12 -0
- package/assets/git-hooks/pre-commit +12 -0
- package/assets/global-skills/claude/ospec-change/SKILL.md +116 -0
- package/assets/global-skills/codex/ospec-change/SKILL.md +117 -0
- package/assets/global-skills/codex/ospec-change/agents/openai.yaml +7 -0
- package/assets/global-skills/codex/ospec-change/skill.yaml +19 -0
- package/assets/project-conventions/en-US/development-guide.md +32 -0
- package/assets/project-conventions/en-US/naming-conventions.md +51 -0
- package/assets/project-conventions/en-US/skill-conventions.md +40 -0
- package/assets/project-conventions/en-US/workflow-conventions.md +70 -0
- package/assets/project-conventions/zh-CN/development-guide.md +32 -0
- package/assets/project-conventions/zh-CN/naming-conventions.md +51 -0
- package/assets/project-conventions/zh-CN/skill-conventions.md +40 -0
- package/assets/project-conventions/zh-CN/workflow-conventions.md +74 -0
- package/dist/adapters/codex-stitch-adapter.js +420 -0
- package/dist/adapters/gemini-stitch-adapter.js +408 -0
- package/dist/adapters/playwright-checkpoint-adapter.js +2260 -0
- package/dist/advanced/BatchOperations.d.ts +36 -0
- package/dist/advanced/BatchOperations.js +159 -0
- package/dist/advanced/CachingLayer.d.ts +66 -0
- package/dist/advanced/CachingLayer.js +136 -0
- package/dist/advanced/FeatureUpdater.d.ts +46 -0
- package/dist/advanced/FeatureUpdater.js +151 -0
- package/dist/advanced/PerformanceMonitor.d.ts +52 -0
- package/dist/advanced/PerformanceMonitor.js +129 -0
- package/dist/advanced/StatePersistence.d.ts +61 -0
- package/dist/advanced/StatePersistence.js +168 -0
- package/dist/advanced/index.d.ts +14 -0
- package/dist/advanced/index.js +22 -0
- package/dist/cli/commands/config.d.ts +5 -0
- package/dist/cli/commands/config.js +6 -0
- package/dist/cli/commands/feature.d.ts +5 -0
- package/dist/cli/commands/feature.js +6 -0
- package/dist/cli/commands/index.d.ts +5 -0
- package/dist/cli/commands/index.js +6 -0
- package/dist/cli/commands/project.d.ts +5 -0
- package/dist/cli/commands/project.js +6 -0
- package/dist/cli/commands/validate.d.ts +5 -0
- package/dist/cli/commands/validate.js +6 -0
- package/dist/cli/index.d.ts +5 -0
- package/dist/cli/index.js +6 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.js +1007 -0
- package/dist/commands/ArchiveCommand.d.ts +14 -0
- package/dist/commands/ArchiveCommand.js +241 -0
- package/dist/commands/BaseCommand.d.ts +33 -0
- package/dist/commands/BaseCommand.js +46 -0
- package/dist/commands/BatchCommand.d.ts +5 -0
- package/dist/commands/BatchCommand.js +42 -0
- package/dist/commands/ChangesCommand.d.ts +3 -0
- package/dist/commands/ChangesCommand.js +71 -0
- package/dist/commands/DocsCommand.d.ts +5 -0
- package/dist/commands/DocsCommand.js +118 -0
- package/dist/commands/FinalizeCommand.d.ts +3 -0
- package/dist/commands/FinalizeCommand.js +24 -0
- package/dist/commands/IndexCommand.d.ts +5 -0
- package/dist/commands/IndexCommand.js +57 -0
- package/dist/commands/InitCommand.d.ts +5 -0
- package/dist/commands/InitCommand.js +65 -0
- package/dist/commands/NewCommand.d.ts +11 -0
- package/dist/commands/NewCommand.js +262 -0
- package/dist/commands/PluginsCommand.d.ts +58 -0
- package/dist/commands/PluginsCommand.js +2491 -0
- package/dist/commands/ProgressCommand.d.ts +5 -0
- package/dist/commands/ProgressCommand.js +103 -0
- package/dist/commands/QueueCommand.d.ts +10 -0
- package/dist/commands/QueueCommand.js +147 -0
- package/dist/commands/RunCommand.d.ts +13 -0
- package/dist/commands/RunCommand.js +200 -0
- package/dist/commands/SkillCommand.d.ts +31 -0
- package/dist/commands/SkillCommand.js +1216 -0
- package/dist/commands/SkillsCommand.d.ts +5 -0
- package/dist/commands/SkillsCommand.js +68 -0
- package/dist/commands/StatusCommand.d.ts +6 -0
- package/dist/commands/StatusCommand.js +140 -0
- package/dist/commands/UpdateCommand.d.ts +8 -0
- package/dist/commands/UpdateCommand.js +251 -0
- package/dist/commands/VerifyCommand.d.ts +5 -0
- package/dist/commands/VerifyCommand.js +278 -0
- package/dist/commands/WorkflowCommand.d.ts +12 -0
- package/dist/commands/WorkflowCommand.js +150 -0
- package/dist/commands/index.d.ts +43 -0
- package/dist/commands/index.js +85 -0
- package/dist/core/constants.d.ts +41 -0
- package/dist/core/constants.js +73 -0
- package/dist/core/errors.d.ts +36 -0
- package/dist/core/errors.js +72 -0
- package/dist/core/index.d.ts +7 -0
- package/dist/core/index.js +23 -0
- package/dist/core/types.d.ts +369 -0
- package/dist/core/types.js +3 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.js +27 -0
- package/dist/presets/ProjectPresets.d.ts +41 -0
- package/dist/presets/ProjectPresets.js +190 -0
- package/dist/scaffolds/ProjectScaffoldPresets.d.ts +20 -0
- package/dist/scaffolds/ProjectScaffoldPresets.js +151 -0
- package/dist/services/ConfigManager.d.ts +14 -0
- package/dist/services/ConfigManager.js +386 -0
- package/dist/services/FeatureManager.d.ts +5 -0
- package/dist/services/FeatureManager.js +6 -0
- package/dist/services/FileService.d.ts +21 -0
- package/dist/services/FileService.js +152 -0
- package/dist/services/IndexBuilder.d.ts +12 -0
- package/dist/services/IndexBuilder.js +130 -0
- package/dist/services/Logger.d.ts +20 -0
- package/dist/services/Logger.js +48 -0
- package/dist/services/ProjectAssetRegistry.d.ts +12 -0
- package/dist/services/ProjectAssetRegistry.js +96 -0
- package/dist/services/ProjectAssetService.d.ts +49 -0
- package/dist/services/ProjectAssetService.js +223 -0
- package/dist/services/ProjectScaffoldCommandService.d.ts +73 -0
- package/dist/services/ProjectScaffoldCommandService.js +159 -0
- package/dist/services/ProjectScaffoldService.d.ts +44 -0
- package/dist/services/ProjectScaffoldService.js +507 -0
- package/dist/services/ProjectService.d.ts +209 -0
- package/dist/services/ProjectService.js +13239 -0
- package/dist/services/QueueService.d.ts +17 -0
- package/dist/services/QueueService.js +142 -0
- package/dist/services/RunService.d.ts +40 -0
- package/dist/services/RunService.js +420 -0
- package/dist/services/SkillParser.d.ts +30 -0
- package/dist/services/SkillParser.js +88 -0
- package/dist/services/StateManager.d.ts +16 -0
- package/dist/services/StateManager.js +127 -0
- package/dist/services/TemplateEngine.d.ts +43 -0
- package/dist/services/TemplateEngine.js +119 -0
- package/dist/services/TemplateGenerator.d.ts +40 -0
- package/dist/services/TemplateGenerator.js +273 -0
- package/dist/services/ValidationService.d.ts +19 -0
- package/dist/services/ValidationService.js +44 -0
- package/dist/services/Validator.d.ts +5 -0
- package/dist/services/Validator.js +6 -0
- package/dist/services/index.d.ts +52 -0
- package/dist/services/index.js +91 -0
- package/dist/services/templates/ExecutionTemplateBuilder.d.ts +12 -0
- package/dist/services/templates/ExecutionTemplateBuilder.js +300 -0
- package/dist/services/templates/ProjectTemplateBuilder.d.ts +38 -0
- package/dist/services/templates/ProjectTemplateBuilder.js +1897 -0
- package/dist/services/templates/TemplateBuilderBase.d.ts +19 -0
- package/dist/services/templates/TemplateBuilderBase.js +60 -0
- package/dist/services/templates/TemplateInputFactory.d.ts +16 -0
- package/dist/services/templates/TemplateInputFactory.js +298 -0
- package/dist/services/templates/templateTypes.d.ts +90 -0
- package/dist/services/templates/templateTypes.js +3 -0
- package/dist/tools/build-index.js +632 -0
- package/dist/utils/DateUtils.d.ts +18 -0
- package/dist/utils/DateUtils.js +40 -0
- package/dist/utils/PathUtils.d.ts +9 -0
- package/dist/utils/PathUtils.js +66 -0
- package/dist/utils/StringUtils.d.ts +26 -0
- package/dist/utils/StringUtils.js +47 -0
- package/dist/utils/helpers.d.ts +5 -0
- package/dist/utils/helpers.js +6 -0
- package/dist/utils/index.d.ts +7 -0
- package/dist/utils/index.js +23 -0
- package/dist/utils/logger.d.ts +5 -0
- package/dist/utils/logger.js +6 -0
- package/dist/utils/path.d.ts +5 -0
- package/dist/utils/path.js +6 -0
- package/dist/utils/subcommandHelp.d.ts +11 -0
- package/dist/utils/subcommandHelp.js +119 -0
- package/dist/workflow/ArchiveGate.d.ts +30 -0
- package/dist/workflow/ArchiveGate.js +93 -0
- package/dist/workflow/ConfigurableWorkflow.d.ts +89 -0
- package/dist/workflow/ConfigurableWorkflow.js +186 -0
- package/dist/workflow/HookSystem.d.ts +38 -0
- package/dist/workflow/HookSystem.js +66 -0
- package/dist/workflow/IndexRegenerator.d.ts +49 -0
- package/dist/workflow/IndexRegenerator.js +147 -0
- package/dist/workflow/PluginWorkflowComposer.d.ts +138 -0
- package/dist/workflow/PluginWorkflowComposer.js +239 -0
- package/dist/workflow/SkillUpdateEngine.d.ts +26 -0
- package/dist/workflow/SkillUpdateEngine.js +113 -0
- package/dist/workflow/VerificationSystem.d.ts +24 -0
- package/dist/workflow/VerificationSystem.js +116 -0
- package/dist/workflow/WorkflowEngine.d.ts +15 -0
- package/dist/workflow/WorkflowEngine.js +57 -0
- package/dist/workflow/index.d.ts +19 -0
- package/dist/workflow/index.js +32 -0
- package/package.json +78 -0
- 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
|