@aiready/core 0.23.4 → 0.23.6

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 (109) hide show
  1. package/dist/{chunk-NGHT7JOG.mjs → chunk-Q55AMEFV.mjs} +63 -0
  2. package/dist/{client-D-cn9ydj.d.mts → client-CKcjnPXt.d.mts} +79 -1
  3. package/dist/{client-D-cn9ydj.d.ts → client-CKcjnPXt.d.ts} +79 -1
  4. package/dist/client.d.mts +1 -1
  5. package/dist/client.d.ts +1 -1
  6. package/dist/client.js +66 -0
  7. package/dist/client.mjs +9 -1
  8. package/dist/index.d.mts +10 -2
  9. package/dist/index.d.ts +10 -2
  10. package/dist/index.js +159 -21
  11. package/dist/index.mjs +102 -22
  12. package/package.json +1 -1
  13. package/dist/__tests__/parser-factory.test.d.ts +0 -5
  14. package/dist/__tests__/parser-factory.test.d.ts.map +0 -1
  15. package/dist/__tests__/parser-factory.test.js +0 -70
  16. package/dist/__tests__/parser-factory.test.js.map +0 -1
  17. package/dist/__tests__/python-parser.test.d.ts +0 -5
  18. package/dist/__tests__/python-parser.test.d.ts.map +0 -1
  19. package/dist/__tests__/python-parser.test.js +0 -194
  20. package/dist/__tests__/python-parser.test.js.map +0 -1
  21. package/dist/__tests__/scoring.test.d.ts +0 -2
  22. package/dist/__tests__/scoring.test.d.ts.map +0 -1
  23. package/dist/__tests__/scoring.test.js +0 -197
  24. package/dist/__tests__/scoring.test.js.map +0 -1
  25. package/dist/chunk-3YI4IS3D.mjs +0 -601
  26. package/dist/chunk-5HIXDC3X.mjs +0 -716
  27. package/dist/chunk-5V3L53AE.mjs +0 -805
  28. package/dist/chunk-CKVKHN3G.mjs +0 -660
  29. package/dist/chunk-COHIBX3Q.mjs +0 -635
  30. package/dist/chunk-CWRCDSKZ.mjs +0 -417
  31. package/dist/chunk-D3D3NCRR.mjs +0 -556
  32. package/dist/chunk-HCFYP7UD.mjs +0 -805
  33. package/dist/chunk-HFLFBA6F.mjs +0 -417
  34. package/dist/chunk-HKSARRCD.mjs +0 -365
  35. package/dist/chunk-JJ5JL5FX.mjs +0 -417
  36. package/dist/chunk-KDSTXVLQ.mjs +0 -724
  37. package/dist/chunk-KI7XORTN.mjs +0 -417
  38. package/dist/chunk-LTMHFNFK.mjs +0 -690
  39. package/dist/chunk-LTNXTXRI.mjs +0 -659
  40. package/dist/chunk-M22BXHBR.mjs +0 -805
  41. package/dist/chunk-MH3A3LX6.mjs +0 -615
  42. package/dist/chunk-OQ6IGDXG.mjs +0 -553
  43. package/dist/chunk-QAFB3HXQ.mjs +0 -590
  44. package/dist/chunk-QQBKXHLU.mjs +0 -678
  45. package/dist/chunk-RDHYGES7.mjs +0 -678
  46. package/dist/chunk-SWTDBVYJ.mjs +0 -660
  47. package/dist/chunk-UIWL5JQB.mjs +0 -417
  48. package/dist/chunk-UQGI67WR.mjs +0 -417
  49. package/dist/chunk-UTZOO4XO.mjs +0 -553
  50. package/dist/chunk-X4F46I5L.mjs +0 -635
  51. package/dist/chunk-XKK7YHPX.mjs +0 -619
  52. package/dist/chunk-YCA4FTEK.mjs +0 -600
  53. package/dist/chunk-ZSZRRTJM.mjs +0 -719
  54. package/dist/client-BgmiMoil.d.mts +0 -1344
  55. package/dist/client-BgmiMoil.d.ts +0 -1344
  56. package/dist/client-BxGrPuuN.d.mts +0 -1191
  57. package/dist/client-BxGrPuuN.d.ts +0 -1191
  58. package/dist/client-D9seCH4K.d.mts +0 -1334
  59. package/dist/client-D9seCH4K.d.ts +0 -1334
  60. package/dist/client-DIXIh7rw.d.mts +0 -1193
  61. package/dist/client-DIXIh7rw.d.ts +0 -1193
  62. package/dist/client-DVHXWOHw.d.mts +0 -1245
  63. package/dist/client-DVHXWOHw.d.ts +0 -1245
  64. package/dist/index.d.ts.map +0 -1
  65. package/dist/index.js.map +0 -1
  66. package/dist/parsers/parser-factory.d.ts +0 -69
  67. package/dist/parsers/parser-factory.d.ts.map +0 -1
  68. package/dist/parsers/parser-factory.js +0 -116
  69. package/dist/parsers/parser-factory.js.map +0 -1
  70. package/dist/parsers/python-parser.d.ts +0 -47
  71. package/dist/parsers/python-parser.d.ts.map +0 -1
  72. package/dist/parsers/python-parser.js +0 -243
  73. package/dist/parsers/python-parser.js.map +0 -1
  74. package/dist/parsers/typescript-parser.d.ts +0 -22
  75. package/dist/parsers/typescript-parser.d.ts.map +0 -1
  76. package/dist/parsers/typescript-parser.js +0 -242
  77. package/dist/parsers/typescript-parser.js.map +0 -1
  78. package/dist/scoring.d.ts +0 -120
  79. package/dist/scoring.d.ts.map +0 -1
  80. package/dist/scoring.js +0 -197
  81. package/dist/scoring.js.map +0 -1
  82. package/dist/types/language.d.ts +0 -172
  83. package/dist/types/language.d.ts.map +0 -1
  84. package/dist/types/language.js +0 -45
  85. package/dist/types/language.js.map +0 -1
  86. package/dist/types.d.ts +0 -122
  87. package/dist/types.d.ts.map +0 -1
  88. package/dist/types.js +0 -2
  89. package/dist/types.js.map +0 -1
  90. package/dist/utils/ast-parser.d.ts +0 -59
  91. package/dist/utils/ast-parser.d.ts.map +0 -1
  92. package/dist/utils/ast-parser.js +0 -213
  93. package/dist/utils/ast-parser.js.map +0 -1
  94. package/dist/utils/cli-helpers.d.ts +0 -54
  95. package/dist/utils/cli-helpers.d.ts.map +0 -1
  96. package/dist/utils/cli-helpers.js +0 -78
  97. package/dist/utils/cli-helpers.js.map +0 -1
  98. package/dist/utils/config.d.ts +0 -9
  99. package/dist/utils/config.d.ts.map +0 -1
  100. package/dist/utils/config.js +0 -80
  101. package/dist/utils/config.js.map +0 -1
  102. package/dist/utils/file-scanner.d.ts +0 -16
  103. package/dist/utils/file-scanner.d.ts.map +0 -1
  104. package/dist/utils/file-scanner.js +0 -104
  105. package/dist/utils/file-scanner.js.map +0 -1
  106. package/dist/utils/metrics.d.ts +0 -6
  107. package/dist/utils/metrics.d.ts.map +0 -1
  108. package/dist/utils/metrics.js +0 -8
  109. package/dist/utils/metrics.js.map +0 -1
@@ -1,365 +0,0 @@
1
- // src/types/language.ts
2
- var Language = /* @__PURE__ */ ((Language2) => {
3
- Language2['TypeScript'] = 'typescript';
4
- Language2['JavaScript'] = 'javascript';
5
- Language2['Python'] = 'python';
6
- Language2['Java'] = 'java';
7
- Language2['Go'] = 'go';
8
- Language2['Rust'] = 'rust';
9
- Language2['CSharp'] = 'csharp';
10
- return Language2;
11
- })(Language || {});
12
- var LANGUAGE_EXTENSIONS = {
13
- '.ts': 'typescript' /* TypeScript */,
14
- '.tsx': 'typescript' /* TypeScript */,
15
- '.js': 'javascript' /* JavaScript */,
16
- '.jsx': 'javascript' /* JavaScript */,
17
- '.py': 'python' /* Python */,
18
- '.java': 'java' /* Java */,
19
- '.go': 'go' /* Go */,
20
- '.rs': 'rust' /* Rust */,
21
- '.cs': 'csharp' /* CSharp */,
22
- };
23
- var ParseError = class extends Error {
24
- constructor(message, filePath, loc) {
25
- super(message);
26
- this.filePath = filePath;
27
- this.loc = loc;
28
- this.name = 'ParseError';
29
- }
30
- };
31
-
32
- // src/scoring.ts
33
- var DEFAULT_TOOL_WEIGHTS = {
34
- 'pattern-detect': 40,
35
- 'context-analyzer': 35,
36
- consistency: 25,
37
- 'doc-drift': 20,
38
- deps: 15,
39
- };
40
- var TOOL_NAME_MAP = {
41
- patterns: 'pattern-detect',
42
- context: 'context-analyzer',
43
- consistency: 'consistency',
44
- 'doc-drift': 'doc-drift',
45
- deps: 'deps',
46
- };
47
- function normalizeToolName(shortName) {
48
- return TOOL_NAME_MAP[shortName] || shortName;
49
- }
50
- function getToolWeight(toolName, toolConfig, cliOverride) {
51
- if (cliOverride !== void 0) {
52
- return cliOverride;
53
- }
54
- if (toolConfig?.scoreWeight !== void 0) {
55
- return toolConfig.scoreWeight;
56
- }
57
- return DEFAULT_TOOL_WEIGHTS[toolName] || 10;
58
- }
59
- function parseWeightString(weightStr) {
60
- const weights = /* @__PURE__ */ new Map();
61
- if (!weightStr) {
62
- return weights;
63
- }
64
- const pairs = weightStr.split(',');
65
- for (const pair of pairs) {
66
- const [toolShortName, weightStr2] = pair.split(':');
67
- if (toolShortName && weightStr2) {
68
- const toolName = normalizeToolName(toolShortName.trim());
69
- const weight = parseInt(weightStr2.trim(), 10);
70
- if (!isNaN(weight) && weight > 0) {
71
- weights.set(toolName, weight);
72
- }
73
- }
74
- }
75
- return weights;
76
- }
77
- function calculateOverallScore(toolOutputs, config, cliWeights) {
78
- if (toolOutputs.size === 0) {
79
- throw new Error('No tool outputs provided for scoring');
80
- }
81
- const weights = /* @__PURE__ */ new Map();
82
- for (const [toolName] of toolOutputs.entries()) {
83
- const cliWeight = cliWeights?.get(toolName);
84
- const configWeight = config?.tools?.[toolName]?.scoreWeight;
85
- const weight =
86
- cliWeight ?? configWeight ?? DEFAULT_TOOL_WEIGHTS[toolName] ?? 10;
87
- weights.set(toolName, weight);
88
- }
89
- let weightedSum = 0;
90
- let totalWeight = 0;
91
- const breakdown = [];
92
- const toolsUsed = [];
93
- const calculationWeights = {};
94
- for (const [toolName, output] of toolOutputs.entries()) {
95
- const weight = weights.get(toolName) || 10;
96
- const weightedScore = output.score * weight;
97
- weightedSum += weightedScore;
98
- totalWeight += weight;
99
- toolsUsed.push(toolName);
100
- calculationWeights[toolName] = weight;
101
- breakdown.push(output);
102
- }
103
- const overall = Math.round(weightedSum / totalWeight);
104
- const rating = getRating(overall);
105
- const formulaParts = Array.from(toolOutputs.entries()).map(
106
- ([name, output]) => {
107
- const w = weights.get(name) || 10;
108
- return `(${output.score} \xD7 ${w})`;
109
- }
110
- );
111
- const formulaStr = `[${formulaParts.join(' + ')}] / ${totalWeight} = ${overall}`;
112
- return {
113
- overall,
114
- rating,
115
- timestamp: /* @__PURE__ */ new Date().toISOString(),
116
- toolsUsed,
117
- breakdown,
118
- calculation: {
119
- formula: formulaStr,
120
- weights: calculationWeights,
121
- normalized: formulaStr,
122
- },
123
- };
124
- }
125
- function getRating(score) {
126
- if (score >= 90) return 'Excellent';
127
- if (score >= 75) return 'Good';
128
- if (score >= 60) return 'Fair';
129
- if (score >= 40) return 'Needs Work';
130
- return 'Critical';
131
- }
132
- function getRatingDisplay(rating) {
133
- switch (rating) {
134
- case 'Excellent':
135
- return { emoji: '\u2705', color: 'green' };
136
- case 'Good':
137
- return { emoji: '\u{1F44D}', color: 'blue' };
138
- case 'Fair':
139
- return { emoji: '\u26A0\uFE0F', color: 'yellow' };
140
- case 'Needs Work':
141
- return { emoji: '\u{1F528}', color: 'orange' };
142
- case 'Critical':
143
- return { emoji: '\u274C', color: 'red' };
144
- }
145
- }
146
- function formatScore(result) {
147
- const { emoji, color } = getRatingDisplay(result.rating);
148
- return `${result.overall}/100 (${result.rating}) ${emoji}`;
149
- }
150
- function formatToolScore(output) {
151
- let result = ` Score: ${output.score}/100
152
-
153
- `;
154
- if (output.factors && output.factors.length > 0) {
155
- result += ` Factors:
156
- `;
157
- output.factors.forEach((factor) => {
158
- const impactSign = factor.impact > 0 ? '+' : '';
159
- result += ` \u2022 ${factor.name}: ${impactSign}${factor.impact} - ${factor.description}
160
- `;
161
- });
162
- result += '\n';
163
- }
164
- if (output.recommendations && output.recommendations.length > 0) {
165
- result += ` Recommendations:
166
- `;
167
- output.recommendations.forEach((rec, i) => {
168
- const priorityIcon =
169
- rec.priority === 'high'
170
- ? '\u{1F534}'
171
- : rec.priority === 'medium'
172
- ? '\u{1F7E1}'
173
- : '\u{1F535}';
174
- result += ` ${i + 1}. ${priorityIcon} ${rec.action}
175
- `;
176
- result += ` Impact: +${rec.estimatedImpact} points
177
-
178
- `;
179
- });
180
- }
181
- return result;
182
- }
183
-
184
- // src/utils/visualization.ts
185
- function generateHTML(graph) {
186
- const payload = JSON.stringify(graph, null, 2);
187
- return `<!doctype html>
188
- <html>
189
- <head>
190
- <meta charset="utf-8" />
191
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
192
- <title>AIReady Visualization</title>
193
- <style>
194
- html,body { height: 100%; margin: 0; padding: 0; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; background: #0f172a; color: #e2e8f0 }
195
- #container { display:flex; height:100vh }
196
- #panel { width: 320px; padding: 16px; background: #071130; box-shadow: -2px 0 8px rgba(0,0,0,0.3); overflow:auto }
197
- #canvasWrap { flex:1; display:flex; align-items:center; justify-content:center }
198
- canvas { background: #0b1220; border-radius:8px }
199
- .stat { margin-bottom:12px }
200
- </style>
201
- </head>
202
- <body>
203
- <div id="container">
204
- <div id="canvasWrap"><canvas id="canvas" width="1200" height="800"></canvas></div>
205
- <div id="panel">
206
- <h2>AIReady Visualization</h2>
207
- <div class="stat"><strong>Files:</strong> <span id="stat-files"></span></div>
208
- <div class="stat"><strong>Dependencies:</strong> <span id="stat-deps"></span></div>
209
- <div class="stat"><strong>Legend</strong></div>
210
- <div style="font-size:13px;line-height:1.3;color:#cbd5e1;margin-top:8px">
211
- <div style="margin-bottom:8px"><span style="display:inline-block;width:12px;height:12px;background:#ff4d4f;margin-right:8px;border:1px solid rgba(255,255,255,0.06)"></span><strong>Critical</strong>: highest severity issues.</div>
212
- <div style="margin-bottom:8px"><span style="display:inline-block;width:12px;height:12px;background:#ff9900;margin-right:8px;border:1px solid rgba(255,255,255,0.06)"></span><strong>Major</strong>: important issues.</div>
213
- <div style="margin-bottom:8px"><span style="display:inline-block;width:12px;height:12px;background:#ffd666;margin-right:8px;border:1px solid rgba(255,255,255,0.06)"></span><strong>Minor</strong>: low priority issues.</div>
214
- <div style="margin-bottom:8px"><span style="display:inline-block;width:12px;height:12px;background:#91d5ff;margin-right:8px;border:1px solid rgba(255,255,255,0.06)"></span><strong>Info</strong>: informational notes.</div>
215
- <div style="margin-top:10px;color:#94a3b8"><strong>Node size</strong>: larger = higher token cost, more issues or dependency weight.</div>
216
- <div style="margin-top:6px;color:#94a3b8"><strong>Proximity</strong>: nodes that are spatially close are more contextually related; relatedness is represented by distance and size rather than explicit edges.</div>
217
- <div style="margin-top:6px;color:#94a3b8"><strong>Edge colors</strong>: <span style="color:#fb7e81">Similarity</span>, <span style="color:#84c1ff">Dependency</span>, <span style="color:#ffa500">Reference</span>, default <span style="color:#334155">Other</span>.</div>
218
- </div>
219
- </div>
220
- </div>
221
-
222
- <script>
223
- const graphData = ${payload};
224
- document.getElementById('stat-files').textContent = graphData.metadata.totalFiles;
225
- document.getElementById('stat-deps').textContent = graphData.metadata.totalDependencies;
226
-
227
- const canvas = document.getElementById('canvas');
228
- const ctx = canvas.getContext('2d');
229
-
230
- const nodes = graphData.nodes.map((n, i) => ({
231
- ...n,
232
- x: canvas.width / 2 + Math.cos(i / graphData.nodes.length * Math.PI * 2) * (Math.min(canvas.width, canvas.height) / 3),
233
- y: canvas.height / 2 + Math.sin(i / graphData.nodes.length * Math.PI * 2) * (Math.min(canvas.width, canvas.height) / 3),
234
- }));
235
-
236
- function draw() {
237
- ctx.clearRect(0, 0, canvas.width, canvas.height);
238
-
239
- graphData.edges.forEach(edge => {
240
- const s = nodes.find(n => n.id === edge.source);
241
- const t = nodes.find(n => n.id === edge.target);
242
- if (!s || !t) return;
243
- if (edge.type === 'related') return;
244
- if (edge.type === 'similarity') {
245
- ctx.strokeStyle = '#fb7e81';
246
- ctx.lineWidth = 1.2;
247
- } else if (edge.type === 'dependency') {
248
- ctx.strokeStyle = '#84c1ff';
249
- ctx.lineWidth = 1.0;
250
- } else if (edge.type === 'reference') {
251
- ctx.strokeStyle = '#ffa500';
252
- ctx.lineWidth = 0.9;
253
- } else {
254
- ctx.strokeStyle = '#334155';
255
- ctx.lineWidth = 0.8;
256
- }
257
- ctx.beginPath();
258
- ctx.moveTo(s.x, s.y);
259
- ctx.lineTo(t.x, t.y);
260
- ctx.stroke();
261
- });
262
-
263
- const groups = {};
264
- nodes.forEach(n => {
265
- const g = n.group || '__default';
266
- if (!groups[g]) groups[g] = { minX: n.x, minY: n.y, maxX: n.x, maxY: n.y };
267
- groups[g].minX = Math.min(groups[g].minX, n.x);
268
- groups[g].minY = Math.min(groups[g].minY, n.y);
269
- groups[g].maxX = Math.max(groups[g].maxX, n.x);
270
- groups[g].maxY = Math.max(groups[g].maxY, n.y);
271
- });
272
-
273
- const groupRelations = {};
274
- graphData.edges.forEach(edge => {
275
- const sNode = nodes.find(n => n.id === edge.source);
276
- const tNode = nodes.find(n => n.id === edge.target);
277
- if (!sNode || !tNode) return;
278
- const g1 = sNode.group || '__default';
279
- const g2 = tNode.group || '__default';
280
- if (g1 === g2) return;
281
- const key = g1 < g2 ? g1 + '::' + g2 : g2 + '::' + g1;
282
- groupRelations[key] = (groupRelations[key] || 0) + 1;
283
- });
284
-
285
- Object.keys(groupRelations).forEach(k => {
286
- const count = groupRelations[k];
287
- const [ga, gb] = k.split('::');
288
- if (!groups[ga] || !groups[gb]) return;
289
- const ax = (groups[ga].minX + groups[ga].maxX) / 2;
290
- const ay = (groups[ga].minY + groups[ga].maxY) / 2;
291
- const bx = (groups[gb].minX + groups[gb].maxX) / 2;
292
- const by = (groups[gb].minY + groups[gb].maxY) / 2;
293
- ctx.beginPath();
294
- ctx.strokeStyle = 'rgba(148,163,184,0.25)';
295
- ctx.lineWidth = Math.min(6, 0.6 + Math.sqrt(count));
296
- ctx.moveTo(ax, ay);
297
- ctx.lineTo(bx, by);
298
- ctx.stroke();
299
- });
300
-
301
- Object.keys(groups).forEach(g => {
302
- if (g === '__default') return;
303
- const box = groups[g];
304
- const pad = 16;
305
- const x = box.minX - pad;
306
- const y = box.minY - pad;
307
- const w = (box.maxX - box.minX) + pad * 2;
308
- const h = (box.maxY - box.minY) + pad * 2;
309
- ctx.save();
310
- ctx.fillStyle = 'rgba(30,64,175,0.04)';
311
- ctx.strokeStyle = 'rgba(30,64,175,0.12)';
312
- ctx.lineWidth = 1.2;
313
- const r = 8;
314
- ctx.beginPath();
315
- ctx.moveTo(x + r, y);
316
- ctx.arcTo(x + w, y, x + w, y + h, r);
317
- ctx.arcTo(x + w, y + h, x, y + h, r);
318
- ctx.arcTo(x, y + h, x, y, r);
319
- ctx.arcTo(x, y, x + w, y, r);
320
- ctx.closePath();
321
- ctx.fill();
322
- ctx.stroke();
323
- ctx.restore();
324
- ctx.fillStyle = '#94a3b8';
325
- ctx.font = '11px sans-serif';
326
- ctx.fillText(g, x + 8, y + 14);
327
- });
328
-
329
- nodes.forEach(n => {
330
- const sizeVal = (n.size || n.value || 1);
331
- const r = 6 + (sizeVal / 2);
332
- ctx.beginPath();
333
- ctx.fillStyle = n.color || '#60a5fa';
334
- ctx.arc(n.x, n.y, r, 0, Math.PI * 2);
335
- ctx.fill();
336
-
337
- ctx.fillStyle = '#e2e8f0';
338
- ctx.font = '11px sans-serif';
339
- ctx.textAlign = 'center';
340
- ctx.fillText(n.label || n.id.split('/').slice(-1)[0], n.x, n.y + r + 12);
341
- });
342
- }
343
-
344
- draw();
345
- </script>
346
- </body>
347
- </html>`;
348
- }
349
-
350
- export {
351
- Language,
352
- LANGUAGE_EXTENSIONS,
353
- ParseError,
354
- DEFAULT_TOOL_WEIGHTS,
355
- TOOL_NAME_MAP,
356
- normalizeToolName,
357
- getToolWeight,
358
- parseWeightString,
359
- calculateOverallScore,
360
- getRating,
361
- getRatingDisplay,
362
- formatScore,
363
- formatToolScore,
364
- generateHTML,
365
- };