mta-mcp 1.9.0 → 2.2.0

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 (117) hide show
  1. package/README.md +140 -2
  2. package/build/core/analyzers/eslint.d.ts +51 -0
  3. package/build/core/analyzers/eslint.d.ts.map +1 -0
  4. package/build/core/analyzers/eslint.js +259 -0
  5. package/build/core/analyzers/eslint.js.map +1 -0
  6. package/build/core/analyzers/index.d.ts +9 -0
  7. package/build/core/analyzers/index.d.ts.map +1 -0
  8. package/build/core/analyzers/index.js +9 -0
  9. package/build/core/analyzers/index.js.map +1 -0
  10. package/build/core/analyzers/registry.d.ts +59 -0
  11. package/build/core/analyzers/registry.d.ts.map +1 -0
  12. package/build/core/analyzers/registry.js +241 -0
  13. package/build/core/analyzers/registry.js.map +1 -0
  14. package/build/core/analyzers/tsconfig.d.ts +45 -0
  15. package/build/core/analyzers/tsconfig.d.ts.map +1 -0
  16. package/build/core/analyzers/tsconfig.js +197 -0
  17. package/build/core/analyzers/tsconfig.js.map +1 -0
  18. package/build/core/analyzers/types.d.ts +176 -0
  19. package/build/core/analyzers/types.d.ts.map +1 -0
  20. package/build/core/analyzers/types.js +39 -0
  21. package/build/core/analyzers/types.js.map +1 -0
  22. package/build/core/analyzers/vite.d.ts +46 -0
  23. package/build/core/analyzers/vite.d.ts.map +1 -0
  24. package/build/core/analyzers/vite.js +211 -0
  25. package/build/core/analyzers/vite.js.map +1 -0
  26. package/build/core/enhancedProjectAnalyzer.d.ts +102 -0
  27. package/build/core/enhancedProjectAnalyzer.d.ts.map +1 -0
  28. package/build/core/enhancedProjectAnalyzer.js +312 -0
  29. package/build/core/enhancedProjectAnalyzer.js.map +1 -0
  30. package/build/core/errors.d.ts +84 -0
  31. package/build/core/errors.d.ts.map +1 -0
  32. package/build/core/errors.js +151 -0
  33. package/build/core/errors.js.map +1 -0
  34. package/build/core/index.d.ts +11 -0
  35. package/build/core/index.d.ts.map +1 -0
  36. package/build/core/index.js +14 -0
  37. package/build/core/index.js.map +1 -0
  38. package/build/core/logger.d.ts +91 -0
  39. package/build/core/logger.d.ts.map +1 -0
  40. package/build/core/logger.js +164 -0
  41. package/build/core/logger.js.map +1 -0
  42. package/build/core/mappings/index.d.ts +5 -0
  43. package/build/core/mappings/index.d.ts.map +1 -0
  44. package/build/core/mappings/index.js +5 -0
  45. package/build/core/mappings/index.js.map +1 -0
  46. package/build/core/mappings/scenarioMappings.d.ts +51 -0
  47. package/build/core/mappings/scenarioMappings.d.ts.map +1 -0
  48. package/build/core/mappings/scenarioMappings.js +105 -0
  49. package/build/core/mappings/scenarioMappings.js.map +1 -0
  50. package/build/core/matching/index.d.ts +8 -0
  51. package/build/core/matching/index.d.ts.map +1 -0
  52. package/build/core/matching/index.js +8 -0
  53. package/build/core/matching/index.js.map +1 -0
  54. package/build/core/matching/intentAnalyzer.d.ts +78 -0
  55. package/build/core/matching/intentAnalyzer.d.ts.map +1 -0
  56. package/build/core/matching/intentAnalyzer.js +255 -0
  57. package/build/core/matching/intentAnalyzer.js.map +1 -0
  58. package/build/core/matching/standardMatcher.d.ts +101 -0
  59. package/build/core/matching/standardMatcher.d.ts.map +1 -0
  60. package/build/core/matching/standardMatcher.js +299 -0
  61. package/build/core/matching/standardMatcher.js.map +1 -0
  62. package/build/core/matching/weights.d.ts +64 -0
  63. package/build/core/matching/weights.d.ts.map +1 -0
  64. package/build/core/matching/weights.js +334 -0
  65. package/build/core/matching/weights.js.map +1 -0
  66. package/build/core/scenarioDetector.d.ts +2 -0
  67. package/build/core/scenarioDetector.d.ts.map +1 -0
  68. package/build/core/scenarioDetector.js +2 -0
  69. package/build/core/scenarioDetector.js.map +1 -0
  70. package/build/core/templates/discovery.d.ts +41 -0
  71. package/build/core/templates/discovery.d.ts.map +1 -0
  72. package/build/core/templates/discovery.js +262 -0
  73. package/build/core/templates/discovery.js.map +1 -0
  74. package/build/core/templates/types.d.ts +80 -0
  75. package/build/core/templates/types.d.ts.map +1 -0
  76. package/build/core/templates/types.js +10 -0
  77. package/build/core/templates/types.js.map +1 -0
  78. package/build/core/types.d.ts +2 -0
  79. package/build/core/types.d.ts.map +1 -1
  80. package/build/core/types.js +4 -3
  81. package/build/core/types.js.map +1 -1
  82. package/build/index.js +136 -23
  83. package/build/index.js.map +1 -1
  84. package/build/tools/getStandardById.d.ts +42 -0
  85. package/build/tools/getStandardById.d.ts.map +1 -0
  86. package/build/tools/getStandardById.js +289 -0
  87. package/build/tools/getStandardById.js.map +1 -0
  88. package/build/tools/getTemplate.d.ts +37 -0
  89. package/build/tools/getTemplate.d.ts.map +1 -0
  90. package/build/tools/getTemplate.js +78 -0
  91. package/build/tools/getTemplate.js.map +1 -0
  92. package/build/tools/listTemplates.d.ts +41 -0
  93. package/build/tools/listTemplates.d.ts.map +1 -0
  94. package/build/tools/listTemplates.js +81 -0
  95. package/build/tools/listTemplates.js.map +1 -0
  96. package/build/tools/queryMappings.d.ts +55 -0
  97. package/build/tools/queryMappings.d.ts.map +1 -0
  98. package/build/tools/queryMappings.js +119 -0
  99. package/build/tools/queryMappings.js.map +1 -0
  100. package/package.json +25 -8
  101. package/src/core/autoInitializer.ts +0 -170
  102. package/src/core/codeValidator.ts +0 -357
  103. package/src/core/githubClient.ts +0 -64
  104. package/src/core/i18nDetector.ts +0 -357
  105. package/src/core/smartAgentMatcher.ts +0 -490
  106. package/src/core/standardsManager.ts +0 -769
  107. package/src/core/types.ts +0 -72
  108. package/src/index.ts +0 -519
  109. package/src/tools/analyzeProject.ts +0 -94
  110. package/src/tools/autoSetup.ts +0 -312
  111. package/src/tools/generateConfig.ts +0 -429
  112. package/src/tools/getCompactStandards.ts +0 -413
  113. package/src/tools/getSmartStandards.ts +0 -225
  114. package/src/tools/healthCheck.ts +0 -261
  115. package/src/tools/listAgents.ts +0 -91
  116. package/src/tools/matchAgents.ts +0 -80
  117. package/src/tools/usePreset.ts +0 -180
@@ -0,0 +1,255 @@
1
+ /**
2
+ * 意图分析器
3
+ *
4
+ * 分析用户意图,提取关键信息用于精准匹配规范
5
+ *
6
+ * @module core/matching/intentAnalyzer
7
+ */
8
+ /**
9
+ * 意图关键词映射
10
+ */
11
+ const INTENT_KEYWORDS = {
12
+ 'create': ['创建', '新建', '添加', '生成', 'create', 'new', 'add', 'generate', '写一个', '做一个', '实现'],
13
+ 'modify': ['修改', '更新', '调整', '改变', 'modify', 'update', 'change', 'adjust', '改一下'],
14
+ 'fix': ['修复', '解决', '处理', 'fix', 'bug', 'solve', 'resolve', '报错', '错误', 'error'],
15
+ 'refactor': ['重构', '重写', '优化代码', 'refactor', 'rewrite', '整理', '重新组织'],
16
+ 'optimize': ['优化', '性能', '加速', 'optimize', 'performance', 'speed', '提升', '改进'],
17
+ 'test': ['测试', '单元测试', 'test', 'unit test', 'spec', '写测试'],
18
+ 'document': ['文档', '注释', '说明', 'document', 'comment', 'doc', 'readme'],
19
+ 'style': ['样式', 'css', 'style', 'ui', '界面', '布局', 'layout', '颜色', '主题'],
20
+ 'query': ['什么是', '怎么', '如何', '为什么', 'what', 'how', 'why', '解释', '说明'],
21
+ 'unknown': []
22
+ };
23
+ /**
24
+ * 目标类型关键词
25
+ */
26
+ const TARGET_KEYWORDS = {
27
+ 'component': ['组件', 'component', '按钮', '表单', '表格', '弹窗', '对话框', '卡片'],
28
+ 'page': ['页面', 'page', 'view', '视图', '路由'],
29
+ 'api': ['api', '接口', '请求', 'request', '服务', 'service'],
30
+ 'store': ['store', '状态', 'state', 'pinia', 'vuex', 'redux'],
31
+ 'style': ['样式', 'style', 'css', 'scss', 'less', '主题'],
32
+ 'type': ['类型', 'type', 'interface', '接口定义', '类型定义'],
33
+ 'hook': ['hook', 'composable', '钩子', '组合式函数'],
34
+ 'util': ['工具', 'util', 'helper', '辅助函数'],
35
+ 'config': ['配置', 'config', '设置', 'setting']
36
+ };
37
+ /**
38
+ * 技术关键词
39
+ */
40
+ const TECHNOLOGY_KEYWORDS = {
41
+ 'vue': ['vue', 'vue3', 'composition', 'ref', 'reactive', 'computed', 'watch'],
42
+ 'react': ['react', 'jsx', 'tsx', 'hooks', 'useState', 'useEffect'],
43
+ 'typescript': ['typescript', 'ts', '类型', 'interface', 'type', '泛型'],
44
+ 'element-plus': ['element', 'el-', 'ElForm', 'ElTable', 'ElButton'],
45
+ 'pinia': ['pinia', 'defineStore', 'store'],
46
+ 'axios': ['axios', 'http', 'request', 'fetch', '请求'],
47
+ 'i18n': ['i18n', '国际化', 'locale', '$t', 'useI18n'],
48
+ 'tailwind': ['tailwind', 'tw-', 'flex', 'grid', 'className'],
49
+ 'logicflow': ['logicflow', '流程图', '节点', 'node', 'edge', '连线']
50
+ };
51
+ /**
52
+ * 场景关键词
53
+ */
54
+ const SCENARIO_KEYWORDS = {
55
+ '表单开发': ['表单', 'form', '输入', '验证', '提交', '校验'],
56
+ '表格展示': ['表格', 'table', '列表', '分页', '排序', '筛选'],
57
+ 'API集成': ['api', '接口', '请求', '响应', '后端', '调用'],
58
+ '状态管理': ['状态', 'state', 'store', '全局', '共享'],
59
+ '路由配置': ['路由', 'router', '导航', '跳转', 'url'],
60
+ '国际化': ['i18n', '国际化', '多语言', '翻译', 'locale'],
61
+ '权限控制': ['权限', 'permission', '角色', '鉴权', '登录'],
62
+ '性能优化': ['性能', '优化', '懒加载', '缓存', '虚拟列表'],
63
+ '单元测试': ['测试', 'test', 'jest', 'vitest', 'mock'],
64
+ '组件封装': ['封装', '复用', '通用', '基础组件']
65
+ };
66
+ /**
67
+ * 意图分析器
68
+ */
69
+ export class IntentAnalyzer {
70
+ /**
71
+ * 分析用户意图
72
+ */
73
+ analyze(userIntent, context) {
74
+ const normalizedIntent = userIntent.toLowerCase();
75
+ // 分析意图类型
76
+ const intentResult = this.analyzeIntentType(normalizedIntent);
77
+ // 分析目标对象
78
+ const target = this.analyzeTarget(normalizedIntent, context?.currentFile);
79
+ // 提取技术关键词
80
+ const technologies = this.extractTechnologies(normalizedIntent, context?.fileContent);
81
+ // 提取场景
82
+ const scenarios = this.extractScenarios(normalizedIntent, context?.fileContent);
83
+ // 提取通用关键词
84
+ const keywords = this.extractKeywords(normalizedIntent);
85
+ return {
86
+ type: intentResult.type,
87
+ confidence: intentResult.confidence,
88
+ target,
89
+ keywords,
90
+ technologies,
91
+ scenarios
92
+ };
93
+ }
94
+ /**
95
+ * 分析意图类型
96
+ */
97
+ analyzeIntentType(text) {
98
+ const scores = [];
99
+ for (const [type, keywords] of Object.entries(INTENT_KEYWORDS)) {
100
+ const matchCount = keywords.filter(k => text.includes(k)).length;
101
+ if (matchCount > 0) {
102
+ scores.push([type, matchCount / keywords.length]);
103
+ }
104
+ }
105
+ if (scores.length === 0) {
106
+ return { type: 'unknown', confidence: 0 };
107
+ }
108
+ scores.sort((a, b) => b[1] - a[1]);
109
+ return { type: scores[0][0], confidence: Math.min(scores[0][1] * 2, 1) };
110
+ }
111
+ /**
112
+ * 分析目标对象
113
+ */
114
+ analyzeTarget(text, currentFile) {
115
+ // 从当前文件推断
116
+ if (currentFile) {
117
+ const path = currentFile.toLowerCase();
118
+ if (path.includes('/components/'))
119
+ return { type: 'component' };
120
+ if (path.includes('/views/') || path.includes('/pages/'))
121
+ return { type: 'page' };
122
+ if (path.includes('/api/') || path.includes('/services/'))
123
+ return { type: 'api' };
124
+ if (path.includes('/stores/') || path.includes('/store/'))
125
+ return { type: 'store' };
126
+ if (path.endsWith('.css') || path.endsWith('.scss'))
127
+ return { type: 'style' };
128
+ }
129
+ // 从文本推断
130
+ for (const [type, keywords] of Object.entries(TARGET_KEYWORDS)) {
131
+ if (keywords.some(k => text.includes(k))) {
132
+ // 尝试提取名称
133
+ const name = this.extractTargetName(text, type);
134
+ return { type, name };
135
+ }
136
+ }
137
+ return { type: 'unknown' };
138
+ }
139
+ /**
140
+ * 提取目标名称
141
+ */
142
+ extractTargetName(text, type) {
143
+ // 匹配常见的命名模式
144
+ const patterns = {
145
+ 'component': [
146
+ /(?:创建|新建|添加)(?:一个)?(.+?)(?:组件|按钮|表单|表格)/,
147
+ /(.+?)(?:Component|Button|Form|Table|Modal|Dialog)/i
148
+ ],
149
+ 'page': [
150
+ /(?:创建|新建|添加)(?:一个)?(.+?)(?:页面|page|view)/i
151
+ ],
152
+ 'api': [
153
+ /(?:创建|新建|添加)(.+?)(?:接口|api)/i
154
+ ]
155
+ };
156
+ const typePatterns = patterns[type] || [];
157
+ for (const pattern of typePatterns) {
158
+ const match = text.match(pattern);
159
+ if (match && match[1]) {
160
+ return match[1].trim();
161
+ }
162
+ }
163
+ return undefined;
164
+ }
165
+ /**
166
+ * 提取技术关键词
167
+ */
168
+ extractTechnologies(text, fileContent) {
169
+ const technologies = [];
170
+ const searchText = text + (fileContent ? ' ' + fileContent : '');
171
+ for (const [tech, keywords] of Object.entries(TECHNOLOGY_KEYWORDS)) {
172
+ if (keywords.some(k => searchText.toLowerCase().includes(k.toLowerCase()))) {
173
+ technologies.push(tech);
174
+ }
175
+ }
176
+ return technologies;
177
+ }
178
+ /**
179
+ * 提取场景
180
+ */
181
+ extractScenarios(text, fileContent) {
182
+ const scenarios = [];
183
+ const searchText = text + (fileContent ? ' ' + fileContent : '');
184
+ for (const [scenario, keywords] of Object.entries(SCENARIO_KEYWORDS)) {
185
+ const matchCount = keywords.filter(k => searchText.toLowerCase().includes(k.toLowerCase())).length;
186
+ // 需要至少匹配 2 个关键词
187
+ if (matchCount >= 2) {
188
+ scenarios.push(scenario);
189
+ }
190
+ }
191
+ return scenarios;
192
+ }
193
+ /**
194
+ * 提取通用关键词
195
+ */
196
+ extractKeywords(text) {
197
+ // 移除常见的停用词
198
+ const stopWords = ['的', '是', '在', '和', '一个', '这个', '那个', 'a', 'the', 'is', 'are', 'to'];
199
+ // 分词(简单处理)
200
+ const words = text.split(/[\s,,。.!!??、]+/).filter(w => w.length > 1 && !stopWords.includes(w));
201
+ return [...new Set(words)].slice(0, 10);
202
+ }
203
+ /**
204
+ * 获取推荐的规范类型
205
+ */
206
+ getRecommendedStandardTypes(analysis) {
207
+ const types = [];
208
+ // 基于意图类型
209
+ switch (analysis.type) {
210
+ case 'create':
211
+ case 'modify':
212
+ types.push('framework', 'pattern');
213
+ break;
214
+ case 'fix':
215
+ types.push('debugging', 'error-handling');
216
+ break;
217
+ case 'refactor':
218
+ types.push('pattern', 'clean-code');
219
+ break;
220
+ case 'optimize':
221
+ types.push('performance');
222
+ break;
223
+ case 'test':
224
+ types.push('testing');
225
+ break;
226
+ case 'style':
227
+ types.push('styling', 'ui');
228
+ break;
229
+ }
230
+ // 基于目标类型
231
+ switch (analysis.target.type) {
232
+ case 'component':
233
+ types.push('component-design');
234
+ break;
235
+ case 'api':
236
+ types.push('api-design');
237
+ break;
238
+ case 'store':
239
+ types.push('state-management');
240
+ break;
241
+ }
242
+ // 基于技术
243
+ analysis.technologies.forEach(tech => {
244
+ types.push(tech);
245
+ });
246
+ return [...new Set(types)];
247
+ }
248
+ }
249
+ /**
250
+ * 获取默认意图分析器
251
+ */
252
+ export function getDefaultIntentAnalyzer() {
253
+ return new IntentAnalyzer();
254
+ }
255
+ //# sourceMappingURL=intentAnalyzer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"intentAnalyzer.js","sourceRoot":"","sources":["../../../src/core/matching/intentAnalyzer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,101 @@
1
+ /**
2
+ * 标准匹配器
3
+ *
4
+ * 综合项目特征、用户意图、文件上下文,精准匹配开发规范
5
+ *
6
+ * @module core/matching/standardMatcher
7
+ */
8
+ import { ProjectFeaturesExtended } from '../analyzers/types.js';
9
+ /**
10
+ * 规范信息
11
+ */
12
+ export interface StandardInfo {
13
+ id: string;
14
+ name: string;
15
+ path: string;
16
+ category: string;
17
+ tags: string[];
18
+ description?: string;
19
+ priority?: number;
20
+ }
21
+ /**
22
+ * 匹配结果
23
+ */
24
+ export interface MatchedStandard {
25
+ standard: StandardInfo;
26
+ score: number;
27
+ matchReasons: string[];
28
+ }
29
+ /**
30
+ * 匹配上下文
31
+ */
32
+ export interface MatchContext {
33
+ /** 项目特征 */
34
+ projectFeatures?: ProjectFeaturesExtended;
35
+ /** 用户意图 */
36
+ userIntent?: string;
37
+ /** 当前文件路径 */
38
+ currentFile?: string;
39
+ /** 文件内容 */
40
+ fileContent?: string;
41
+ /** 场景 */
42
+ scenario?: string;
43
+ /** 文件类型 */
44
+ fileType?: string;
45
+ /** 导入的包 */
46
+ imports?: string[];
47
+ }
48
+ /**
49
+ * 匹配选项
50
+ */
51
+ export interface MatchOptions {
52
+ /** 最大返回数量 */
53
+ maxResults?: number;
54
+ /** 最小分数阈值 */
55
+ minScore?: number;
56
+ /** 是否包含全部内容 */
57
+ includeContent?: boolean;
58
+ /** 加载模式:summary(摘要) | key-rules(关键规则) | full(完整) */
59
+ mode?: 'summary' | 'key-rules' | 'full';
60
+ }
61
+ /**
62
+ * 标准匹配器
63
+ */
64
+ export declare class StandardMatcher {
65
+ private intentAnalyzer;
66
+ private weightCalculator;
67
+ constructor();
68
+ /**
69
+ * 匹配规范
70
+ */
71
+ match(availableStandards: StandardInfo[], context: MatchContext, options?: MatchOptions): MatchedStandard[];
72
+ /**
73
+ * 确定场景
74
+ */
75
+ private determineScenario;
76
+ /**
77
+ * 从路径推断场景
78
+ */
79
+ private inferScenarioFromPath;
80
+ /**
81
+ * 映射场景字符串到 Scenario 类型
82
+ */
83
+ private mapToScenario;
84
+ /**
85
+ * 计算标准分数
86
+ */
87
+ private calculateScore;
88
+ /**
89
+ * 获取场景推荐的规范
90
+ */
91
+ getScenarioRecommendations(scenario: string): string[];
92
+ /**
93
+ * 根据标签获取相关规范
94
+ */
95
+ getStandardsByTag(tag: string): string[];
96
+ }
97
+ /**
98
+ * 获取默认标准匹配器
99
+ */
100
+ export declare function getDefaultStandardMatcher(): StandardMatcher;
101
+ //# sourceMappingURL=standardMatcher.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"standardMatcher.d.ts","sourceRoot":"","sources":["../../../src/core/matching/standardMatcher.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AAIhE;;GAEG;AACH,MAAM,WAAW,YAAY;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC5B,QAAQ,EAAE,YAAY,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,EAAE,CAAC;CAC1B;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IACzB,WAAW;IACX,eAAe,CAAC,EAAE,uBAAuB,CAAC;IAC1C,WAAW;IACX,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW;IACX,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS;IACT,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW;IACX,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW;IACX,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IACzB,aAAa;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe;IACf,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,oDAAoD;IACpD,IAAI,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,MAAM,CAAC;CAC3C;AA+DD;;GAEG;AACH,qBAAa,eAAe;IACxB,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,gBAAgB,CAA0B;;IAOlD;;OAEG;IACH,KAAK,CACD,kBAAkB,EAAE,YAAY,EAAE,EAClC,OAAO,EAAE,YAAY,EACrB,OAAO,GAAE,YAAiB,GAC3B,eAAe,EAAE;IAsDpB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IA6CzB;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAY7B;;OAEG;IACH,OAAO,CAAC,aAAa;IAoBrB;;OAEG;IACH,OAAO,CAAC,cAAc;IAsGtB;;OAEG;IACH,0BAA0B,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,EAAE;IAItD;;OAEG;IACH,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE;CAG3C;AAED;;GAEG;AACH,wBAAgB,yBAAyB,IAAI,eAAe,CAE3D"}
@@ -0,0 +1,299 @@
1
+ /**
2
+ * 标准匹配器
3
+ *
4
+ * 综合项目特征、用户意图、文件上下文,精准匹配开发规范
5
+ *
6
+ * @module core/matching/standardMatcher
7
+ */
8
+ import { DynamicWeightCalculator } from './weights.js';
9
+ import { IntentAnalyzer } from './intentAnalyzer.js';
10
+ /**
11
+ * 标准分类权重
12
+ */
13
+ const CATEGORY_WEIGHTS = {
14
+ 'core': 10,
15
+ 'frameworks': 8,
16
+ 'libraries': 7,
17
+ 'patterns': 6,
18
+ 'workflows': 5
19
+ };
20
+ /**
21
+ * 标签到标准的映射
22
+ */
23
+ const TAG_STANDARD_MAPPING = {
24
+ // 框架
25
+ 'vue': ['vue3-composition', 'vue3-component'],
26
+ 'vue3': ['vue3-composition', 'vue3-component'],
27
+ 'react': ['react-hooks', 'react-component'],
28
+ 'flutter': ['flutter-bloc', 'dart-style'],
29
+ // 库
30
+ 'element-plus': ['element-plus', 'vue3-form'],
31
+ 'pinia': ['pinia-store'],
32
+ 'axios': ['api-call', 'error-handling'],
33
+ 'logicflow': ['logicflow'],
34
+ // 场景
35
+ 'i18n': ['i18n'],
36
+ '国际化': ['i18n'],
37
+ 'form': ['vue3-form'],
38
+ '表单': ['vue3-form'],
39
+ 'table': ['vue3-table'],
40
+ '表格': ['vue3-table'],
41
+ 'api': ['api-call', 'api-design'],
42
+ '接口': ['api-call'],
43
+ 'store': ['pinia-store'],
44
+ '状态管理': ['pinia-store'],
45
+ // 通用
46
+ 'typescript': ['typescript-strict'],
47
+ 'testing': ['unit-testing'],
48
+ 'performance': ['performance-optimization']
49
+ };
50
+ /**
51
+ * 场景到标准的映射
52
+ */
53
+ const SCENARIO_STANDARD_MAPPING = {
54
+ '表单开发': ['vue3-form', 'element-plus', 'form-validation'],
55
+ '表格展示': ['vue3-table', 'element-plus', 'pagination'],
56
+ 'API集成': ['api-call', 'axios-interceptor', 'error-handling'],
57
+ '状态管理': ['pinia-store', 'state-management'],
58
+ '路由配置': ['vue-router', 'route-guard'],
59
+ '国际化': ['i18n', 'locale-management'],
60
+ '权限控制': ['permission-design', 'route-guard'],
61
+ '性能优化': ['performance-optimization', 'lazy-loading'],
62
+ '单元测试': ['unit-testing', 'vitest-guide'],
63
+ '组件封装': ['vue3-component', 'component-design']
64
+ };
65
+ /**
66
+ * 标准匹配器
67
+ */
68
+ export class StandardMatcher {
69
+ intentAnalyzer;
70
+ weightCalculator;
71
+ constructor() {
72
+ this.intentAnalyzer = new IntentAnalyzer();
73
+ this.weightCalculator = new DynamicWeightCalculator();
74
+ }
75
+ /**
76
+ * 匹配规范
77
+ */
78
+ match(availableStandards, context, options = {}) {
79
+ const { maxResults = 5, minScore = 10 } = options;
80
+ // 1. 分析用户意图
81
+ const intentAnalysis = context.userIntent
82
+ ? this.intentAnalyzer.analyze(context.userIntent, {
83
+ currentFile: context.currentFile,
84
+ fileContent: context.fileContent
85
+ })
86
+ : null;
87
+ // 2. 确定场景
88
+ const scenario = this.determineScenario(context, intentAnalysis);
89
+ // 3. 计算动态权重
90
+ const weights = context.projectFeatures
91
+ ? this.weightCalculator.calculateWeights(scenario, context.projectFeatures.projectType, context.projectFeatures)
92
+ : {
93
+ framework: 30,
94
+ language: 15,
95
+ library: 20,
96
+ pattern: 15,
97
+ scenario: 20
98
+ };
99
+ // 4. 为每个标准计算分数
100
+ const scoredStandards = availableStandards.map(standard => {
101
+ const { score, reasons } = this.calculateScore(standard, context, intentAnalysis, weights);
102
+ return {
103
+ standard,
104
+ score,
105
+ matchReasons: reasons
106
+ };
107
+ });
108
+ // 5. 过滤和排序
109
+ return scoredStandards
110
+ .filter(s => s.score >= minScore)
111
+ .sort((a, b) => b.score - a.score)
112
+ .slice(0, maxResults);
113
+ }
114
+ /**
115
+ * 确定场景
116
+ */
117
+ determineScenario(context, intentAnalysis) {
118
+ // 优先使用明确指定的场景
119
+ if (context.scenario) {
120
+ return this.mapToScenario(context.scenario);
121
+ }
122
+ // 使用意图分析结果
123
+ if (intentAnalysis) {
124
+ switch (intentAnalysis.type) {
125
+ case 'create':
126
+ if (intentAnalysis.target.type === 'component' ||
127
+ intentAnalysis.target.type === 'page') {
128
+ return 'new-component';
129
+ }
130
+ if (intentAnalysis.target.type === 'api') {
131
+ return 'api-integration';
132
+ }
133
+ break;
134
+ case 'fix':
135
+ return 'bug-fix';
136
+ case 'refactor':
137
+ return 'refactoring';
138
+ case 'optimize':
139
+ return 'performance';
140
+ case 'test':
141
+ return 'testing';
142
+ case 'style':
143
+ return 'styling';
144
+ case 'document':
145
+ return 'documentation';
146
+ }
147
+ }
148
+ // 从文件路径推断
149
+ if (context.currentFile) {
150
+ return this.weightCalculator.analyzeScenario('') ||
151
+ this.inferScenarioFromPath(context.currentFile);
152
+ }
153
+ return 'general';
154
+ }
155
+ /**
156
+ * 从路径推断场景
157
+ */
158
+ inferScenarioFromPath(filePath) {
159
+ const path = filePath.toLowerCase();
160
+ if (path.includes('.test.') || path.includes('.spec.'))
161
+ return 'testing';
162
+ if (path.includes('/api/') || path.includes('/services/'))
163
+ return 'api-integration';
164
+ if (path.endsWith('.css') || path.endsWith('.scss'))
165
+ return 'styling';
166
+ if (path.includes('/components/') || path.includes('/views/'))
167
+ return 'new-component';
168
+ if (path.endsWith('.md'))
169
+ return 'documentation';
170
+ return 'general';
171
+ }
172
+ /**
173
+ * 映射场景字符串到 Scenario 类型
174
+ */
175
+ mapToScenario(scenarioStr) {
176
+ const mapping = {
177
+ '表单开发': 'new-component',
178
+ '表格展示': 'new-component',
179
+ 'API集成': 'api-integration',
180
+ '状态管理': 'new-component',
181
+ '路由配置': 'new-component',
182
+ '国际化': 'new-component',
183
+ '权限控制': 'new-component',
184
+ '性能优化': 'performance',
185
+ '单元测试': 'testing',
186
+ '组件封装': 'new-component',
187
+ '修复': 'bug-fix',
188
+ '重构': 'refactoring',
189
+ '样式': 'styling'
190
+ };
191
+ return mapping[scenarioStr] || 'general';
192
+ }
193
+ /**
194
+ * 计算标准分数
195
+ */
196
+ calculateScore(standard, context, intentAnalysis, weights) {
197
+ let score = 0;
198
+ const reasons = [];
199
+ // 1. 分类权重
200
+ const categoryWeight = CATEGORY_WEIGHTS[standard.category] || 3;
201
+ score += categoryWeight;
202
+ // 2. 文件类型匹配
203
+ if (context.fileType && standard.tags.includes(context.fileType)) {
204
+ score += weights.framework * 0.3;
205
+ reasons.push(`文件类型匹配: ${context.fileType}`);
206
+ }
207
+ // 3. 导入包匹配
208
+ if (context.imports && context.imports.length > 0) {
209
+ for (const imp of context.imports) {
210
+ const relatedStandards = TAG_STANDARD_MAPPING[imp.toLowerCase()] || [];
211
+ if (relatedStandards.includes(standard.id)) {
212
+ score += weights.library * 0.5;
213
+ reasons.push(`导入匹配: ${imp}`);
214
+ }
215
+ }
216
+ }
217
+ // 4. 项目特征匹配
218
+ if (context.projectFeatures) {
219
+ const features = context.projectFeatures;
220
+ // 框架匹配
221
+ for (const fw of features.frameworks) {
222
+ if (standard.tags.some(t => t.toLowerCase().includes(fw.toLowerCase()))) {
223
+ score += weights.framework * 0.4;
224
+ reasons.push(`框架匹配: ${fw}`);
225
+ break;
226
+ }
227
+ }
228
+ // UI 库匹配
229
+ for (const lib of features.uiLibraries) {
230
+ const relatedStandards = TAG_STANDARD_MAPPING[lib.toLowerCase()] || [];
231
+ if (relatedStandards.includes(standard.id)) {
232
+ score += weights.library * 0.4;
233
+ reasons.push(`UI库匹配: ${lib}`);
234
+ break;
235
+ }
236
+ }
237
+ // 状态管理匹配
238
+ for (const sm of features.stateManagement) {
239
+ const relatedStandards = TAG_STANDARD_MAPPING[sm.toLowerCase()] || [];
240
+ if (relatedStandards.includes(standard.id)) {
241
+ score += weights.library * 0.3;
242
+ reasons.push(`状态管理匹配: ${sm}`);
243
+ break;
244
+ }
245
+ }
246
+ }
247
+ // 5. 意图分析匹配
248
+ if (intentAnalysis) {
249
+ // 技术匹配
250
+ for (const tech of intentAnalysis.technologies) {
251
+ const relatedStandards = TAG_STANDARD_MAPPING[tech] || [];
252
+ if (relatedStandards.includes(standard.id)) {
253
+ score += weights.scenario * 0.4;
254
+ reasons.push(`技术匹配: ${tech}`);
255
+ }
256
+ }
257
+ // 场景匹配
258
+ for (const scenario of intentAnalysis.scenarios) {
259
+ const relatedStandards = SCENARIO_STANDARD_MAPPING[scenario] || [];
260
+ if (relatedStandards.includes(standard.id)) {
261
+ score += weights.scenario * 0.5;
262
+ reasons.push(`场景匹配: ${scenario}`);
263
+ }
264
+ }
265
+ }
266
+ // 6. 标准优先级
267
+ if (standard.priority) {
268
+ score += standard.priority * 2;
269
+ }
270
+ // 7. 标签直接匹配(用户指定的 scenario)
271
+ if (context.scenario) {
272
+ const relatedStandards = SCENARIO_STANDARD_MAPPING[context.scenario] || [];
273
+ if (relatedStandards.includes(standard.id)) {
274
+ score += weights.scenario;
275
+ reasons.push(`场景直接匹配: ${context.scenario}`);
276
+ }
277
+ }
278
+ return { score: Math.round(score * 10) / 10, reasons };
279
+ }
280
+ /**
281
+ * 获取场景推荐的规范
282
+ */
283
+ getScenarioRecommendations(scenario) {
284
+ return SCENARIO_STANDARD_MAPPING[scenario] || [];
285
+ }
286
+ /**
287
+ * 根据标签获取相关规范
288
+ */
289
+ getStandardsByTag(tag) {
290
+ return TAG_STANDARD_MAPPING[tag.toLowerCase()] || [];
291
+ }
292
+ }
293
+ /**
294
+ * 获取默认标准匹配器
295
+ */
296
+ export function getDefaultStandardMatcher() {
297
+ return new StandardMatcher();
298
+ }
299
+ //# sourceMappingURL=standardMatcher.js.map