@aiready/cli 0.12.0 → 0.12.3

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.
@@ -1,6 +1,6 @@
1
1
 
2
2
  
3
- > @aiready/cli@0.11.0 build /Users/pengcao/projects/aiready/packages/cli
3
+ > @aiready/cli@0.12.2 build /Users/pengcao/projects/aiready/packages/cli
4
4
  > tsup src/index.ts src/cli.ts --format cjs,esm
5
5
 
6
6
  CLI Building entry: src/cli.ts, src/index.ts
@@ -10,7 +10,7 @@
10
10
  CJS Build start
11
11
  ESM Build start
12
12
 
13
- [9:32:48 AM]  WARN  ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta]
13
+  WARN  ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta] 10:55:57 am
14
14
 
15
15
  src/cli.ts:25:31:
16
16
   25 │ return dirname(fileURLToPath(import.meta.url));
@@ -21,9 +21,9 @@
21
21
 
22
22
 
23
23
  ESM dist/index.mjs 170.00 B
24
- ESM dist/cli.mjs 56.63 KB
25
- ESM dist/chunk-N56YAZVN.mjs 5.89 KB
26
- ESM ⚡️ Build success in 29ms
27
- CJS dist/index.js 6.76 KB
28
- CJS dist/cli.js 65.35 KB
29
- CJS ⚡️ Build success in 29ms
24
+ ESM dist/cli.mjs 56.79 KB
25
+ ESM dist/chunk-LTUQDJPO.mjs 7.08 KB
26
+ ESM ⚡️ Build success in 26ms
27
+ CJS dist/index.js 8.21 KB
28
+ CJS dist/cli.js 66.96 KB
29
+ CJS ⚡️ Build success in 26ms
@@ -1,28 +1,55 @@
1
1
 
2
2
  
3
- > @aiready/cli@0.11.0 test /Users/pengcao/projects/aiready/packages/cli
3
+ > @aiready/cli@0.12.2 test /Users/pengcao/projects/aiready/packages/cli
4
4
  > vitest run
5
5
 
6
6
  [?25l
7
7
   RUN  v4.0.18 /Users/pengcao/projects/aiready/packages/cli
8
8
 
9
+ stdout | src/__tests__/cli.test.ts
10
+ [ToolRegistry#0.20396533597825972] Registering tool: pattern-detect (patterns, duplicates, duplication)
11
+
12
+ stdout | src/__tests__/cli.test.ts
13
+ [ToolRegistry#0.20396533597825972] Registering tool: context-analyzer (context, fragmentation, budget)
14
+
15
+ stdout | src/__tests__/cli.test.ts
16
+ [ToolRegistry#0.20396533597825972] Registering tool: naming-consistency (consistency, naming, standards)
17
+
18
+ stdout | src/__tests__/cli.test.ts
19
+ [ToolRegistry#0.20396533597825972] Registering tool: ai-signal-clarity (ai-signal, clarity, hallucination)
20
+
21
+ stdout | src/__tests__/cli.test.ts
22
+ [ToolRegistry#0.20396533597825972] Registering tool: agent-grounding (agent-grounding, grounding, navigation)
23
+
24
+ stdout | src/__tests__/cli.test.ts
25
+ [ToolRegistry#0.20396533597825972] Registering tool: testability-index (testability, tests, verification)
26
+
27
+ stdout | src/__tests__/cli.test.ts
28
+ [ToolRegistry#0.20396533597825972] Registering tool: doc-drift (doc-drift, docs, jsdoc)
29
+
30
+ stdout | src/__tests__/cli.test.ts
31
+ [ToolRegistry#0.20396533597825972] Registering tool: dependency-health (deps, deps-health, packages)
32
+
33
+ stdout | src/__tests__/cli.test.ts
34
+ [ToolRegistry#0.20396533597825972] Registering tool: change-amplification (change-amp, change-amplification, coupling)
35
+
9
36
  stdout | src/__tests__/cli.test.ts > CLI Unified Analysis > should run unified analysis with both tools
10
- [ToolRegistry#0.13203462306633074] Registering tool: pattern-detect (patterns)
11
- [ToolRegistry#0.13203462306633074] Registering tool: context-analyzer (context)
37
+ [ToolRegistry#0.20396533597825972] Registering tool: pattern-detect (patterns)
38
+ [ToolRegistry#0.20396533597825972] Registering tool: context-analyzer (context)
12
39
 
13
40
  stdout | src/__tests__/cli.test.ts > CLI Unified Analysis > should run analysis with only patterns tool
14
- [ToolRegistry#0.13203462306633074] Registering tool: pattern-detect (patterns)
15
- [ToolRegistry#0.13203462306633074] Registering tool: context-analyzer (context)
41
+ [ToolRegistry#0.20396533597825972] Registering tool: pattern-detect (patterns)
42
+ [ToolRegistry#0.20396533597825972] Registering tool: context-analyzer (context)
16
43
 
17
44
  stdout | src/__tests__/cli.test.ts > CLI Unified Analysis > should run analysis with only context tool
18
- [ToolRegistry#0.13203462306633074] Registering tool: pattern-detect (patterns)
19
- [ToolRegistry#0.13203462306633074] Registering tool: context-analyzer (context)
45
+ [ToolRegistry#0.20396533597825972] Registering tool: pattern-detect (patterns)
46
+ [ToolRegistry#0.20396533597825972] Registering tool: context-analyzer (context)
20
47
 
21
- ✓ src/__tests__/cli.test.ts (3 tests) 4ms
48
+ ✓ src/__tests__/cli.test.ts (3 tests) 3ms
22
49
 
23
50
   Test Files  1 passed (1)
24
51
   Tests  3 passed (3)
25
-  Start at  09:33:05
26
-  Duration  352ms (transform 64ms, setup 0ms, import 238ms, tests 4ms, environment 0ms)
52
+  Start at  10:56:14
53
+  Duration  443ms (transform 113ms, setup 0ms, import 326ms, tests 3ms, environment 0ms)
27
54
 
28
55
  [?25h
@@ -0,0 +1,229 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined") return require.apply(this, arguments);
5
+ throw Error('Dynamic require of "' + x + '" is not supported');
6
+ });
7
+
8
+ // src/index.ts
9
+ import {
10
+ ToolRegistry,
11
+ ToolName,
12
+ calculateOverallScore,
13
+ calculateTokenBudget
14
+ } from "@aiready/core";
15
+ import "@aiready/pattern-detect";
16
+ import "@aiready/context-analyzer";
17
+ import "@aiready/consistency";
18
+ import "@aiready/ai-signal-clarity";
19
+ import "@aiready/agent-grounding";
20
+ import "@aiready/testability";
21
+ import "@aiready/doc-drift";
22
+ import "@aiready/deps";
23
+ import "@aiready/change-amplification";
24
+ var TOOL_PACKAGE_MAP = {
25
+ [ToolName.PatternDetect]: "@aiready/pattern-detect",
26
+ [ToolName.ContextAnalyzer]: "@aiready/context-analyzer",
27
+ [ToolName.NamingConsistency]: "@aiready/consistency",
28
+ [ToolName.AiSignalClarity]: "@aiready/ai-signal-clarity",
29
+ [ToolName.AgentGrounding]: "@aiready/agent-grounding",
30
+ [ToolName.TestabilityIndex]: "@aiready/testability",
31
+ [ToolName.DocDrift]: "@aiready/doc-drift",
32
+ [ToolName.DependencyHealth]: "@aiready/deps",
33
+ [ToolName.ChangeAmplification]: "@aiready/change-amplification",
34
+ // Aliases handled by registry
35
+ patterns: "@aiready/pattern-detect",
36
+ duplicates: "@aiready/pattern-detect",
37
+ context: "@aiready/context-analyzer",
38
+ fragmentation: "@aiready/context-analyzer",
39
+ consistency: "@aiready/consistency",
40
+ "naming-consistency": "@aiready/consistency",
41
+ "ai-signal": "@aiready/ai-signal-clarity",
42
+ "ai-signal-clarity": "@aiready/ai-signal-clarity",
43
+ grounding: "@aiready/agent-grounding",
44
+ "agent-grounding": "@aiready/agent-grounding",
45
+ testability: "@aiready/testability",
46
+ "testability-index": "@aiready/testability",
47
+ "doc-drift": "@aiready/doc-drift",
48
+ "deps-health": "@aiready/deps",
49
+ "dependency-health": "@aiready/deps",
50
+ "change-amp": "@aiready/change-amplification",
51
+ "change-amplification": "@aiready/change-amplification"
52
+ };
53
+ async function analyzeUnified(options) {
54
+ const startTime = Date.now();
55
+ const requestedTools = options.tools || [
56
+ "patterns",
57
+ "context",
58
+ "consistency"
59
+ ];
60
+ const result = {
61
+ summary: {
62
+ totalIssues: 0,
63
+ toolsRun: [],
64
+ executionTime: 0
65
+ }
66
+ };
67
+ for (const toolName of requestedTools) {
68
+ let provider = ToolRegistry.find(toolName);
69
+ if (!provider) {
70
+ const packageName = TOOL_PACKAGE_MAP[toolName] || (toolName.startsWith("@aiready/") ? toolName : `@aiready/${toolName}`);
71
+ try {
72
+ await import(packageName);
73
+ provider = ToolRegistry.find(toolName);
74
+ if (provider) {
75
+ console.log(
76
+ `\u2705 Successfully loaded tool provider: ${toolName} from ${packageName}`
77
+ );
78
+ } else {
79
+ console.log(
80
+ `\u26A0\uFE0F Loaded ${packageName} but provider ${toolName} still not found in registry.`
81
+ );
82
+ }
83
+ } catch (err) {
84
+ console.log(
85
+ `\u274C Failed to dynamically load tool ${toolName} (${packageName}):`,
86
+ err.message
87
+ );
88
+ }
89
+ }
90
+ if (!provider) {
91
+ console.warn(
92
+ `\u26A0\uFE0F Warning: Tool provider for '${toolName}' not found. Skipping.`
93
+ );
94
+ continue;
95
+ }
96
+ try {
97
+ const output = await provider.analyze({
98
+ ...options,
99
+ onProgress: (processed, total, message) => {
100
+ if (options.progressCallback) {
101
+ options.progressCallback({
102
+ tool: provider.id,
103
+ processed,
104
+ total,
105
+ message
106
+ });
107
+ }
108
+ }
109
+ });
110
+ if (options.progressCallback) {
111
+ options.progressCallback({ tool: provider.id, data: output });
112
+ }
113
+ result[provider.id] = output;
114
+ result.summary.toolsRun.push(provider.id);
115
+ const issueCount = output.results.reduce(
116
+ (sum, file) => sum + (file.issues?.length || 0),
117
+ 0
118
+ );
119
+ result.summary.totalIssues += issueCount;
120
+ if (provider.alias && Array.isArray(provider.alias)) {
121
+ for (const alias of provider.alias) {
122
+ if (!result[alias]) {
123
+ result[alias] = output;
124
+ }
125
+ }
126
+ }
127
+ const camelCaseId = provider.id.replace(
128
+ /-([a-z])/g,
129
+ (g) => g[1].toUpperCase()
130
+ );
131
+ if (camelCaseId !== provider.id && !result[camelCaseId]) {
132
+ result[camelCaseId] = output;
133
+ }
134
+ } catch (err) {
135
+ console.error(`\u274C Error running tool '${provider.id}':`, err);
136
+ }
137
+ }
138
+ result.summary.executionTime = Date.now() - startTime;
139
+ return result;
140
+ }
141
+ async function scoreUnified(results, options) {
142
+ const toolScores = /* @__PURE__ */ new Map();
143
+ for (const toolId of results.summary.toolsRun) {
144
+ const provider = ToolRegistry.get(toolId);
145
+ if (!provider) continue;
146
+ const output = results[toolId];
147
+ if (!output) continue;
148
+ try {
149
+ const toolScore = provider.score(output, options);
150
+ if (!toolScore.tokenBudget) {
151
+ if (toolId === ToolName.PatternDetect && output.duplicates) {
152
+ const wastedTokens = output.duplicates.reduce(
153
+ (sum, d) => sum + (d.tokenCost || 0),
154
+ 0
155
+ );
156
+ toolScore.tokenBudget = calculateTokenBudget({
157
+ totalContextTokens: wastedTokens * 2,
158
+ wastedTokens: {
159
+ duplication: wastedTokens,
160
+ fragmentation: 0,
161
+ chattiness: 0
162
+ }
163
+ });
164
+ } else if (toolId === ToolName.ContextAnalyzer && output.summary) {
165
+ toolScore.tokenBudget = calculateTokenBudget({
166
+ totalContextTokens: output.summary.totalTokens,
167
+ wastedTokens: {
168
+ duplication: 0,
169
+ fragmentation: output.summary.totalPotentialSavings || 0,
170
+ chattiness: 0
171
+ }
172
+ });
173
+ }
174
+ }
175
+ toolScores.set(toolId, toolScore);
176
+ } catch (err) {
177
+ console.error(`\u274C Error scoring tool '${toolId}':`, err);
178
+ }
179
+ }
180
+ if (toolScores.size === 0) {
181
+ return {
182
+ overall: 0,
183
+ rating: "Critical",
184
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
185
+ toolsUsed: [],
186
+ breakdown: [],
187
+ calculation: {
188
+ formula: "0 / 0 = 0",
189
+ weights: {},
190
+ normalized: "0 / 0 = 0"
191
+ }
192
+ };
193
+ }
194
+ return calculateOverallScore(toolScores, options, void 0);
195
+ }
196
+ function generateUnifiedSummary(result) {
197
+ const { summary } = result;
198
+ let output = `\u{1F680} AIReady Analysis Complete
199
+
200
+ `;
201
+ output += `\u{1F4CA} Summary:
202
+ `;
203
+ output += ` Tools run: ${summary.toolsRun.join(", ")}
204
+ `;
205
+ output += ` Total issues found: ${summary.totalIssues}
206
+ `;
207
+ output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
208
+
209
+ `;
210
+ for (const provider of ToolRegistry.getAll()) {
211
+ const toolResult = result[provider.id];
212
+ if (toolResult) {
213
+ const issueCount = toolResult.results.reduce(
214
+ (sum, r) => sum + (r.issues?.length || 0),
215
+ 0
216
+ );
217
+ output += `\u2022 ${provider.id}: ${issueCount} issues
218
+ `;
219
+ }
220
+ }
221
+ return output;
222
+ }
223
+
224
+ export {
225
+ __require,
226
+ analyzeUnified,
227
+ scoreUnified,
228
+ generateUnifiedSummary
229
+ };
package/dist/cli.js CHANGED
@@ -37,6 +37,15 @@ var import_core3 = require("@aiready/core");
37
37
 
38
38
  // src/index.ts
39
39
  var import_core = require("@aiready/core");
40
+ var import_pattern_detect = require("@aiready/pattern-detect");
41
+ var import_context_analyzer = require("@aiready/context-analyzer");
42
+ var import_consistency = require("@aiready/consistency");
43
+ var import_ai_signal_clarity = require("@aiready/ai-signal-clarity");
44
+ var import_agent_grounding = require("@aiready/agent-grounding");
45
+ var import_testability = require("@aiready/testability");
46
+ var import_doc_drift = require("@aiready/doc-drift");
47
+ var import_deps = require("@aiready/deps");
48
+ var import_change_amplification = require("@aiready/change-amplification");
40
49
  var TOOL_PACKAGE_MAP = {
41
50
  [import_core.ToolName.PatternDetect]: "@aiready/pattern-detect",
42
51
  [import_core.ToolName.ContextAnalyzer]: "@aiready/context-analyzer",
@@ -49,8 +58,22 @@ var TOOL_PACKAGE_MAP = {
49
58
  [import_core.ToolName.ChangeAmplification]: "@aiready/change-amplification",
50
59
  // Aliases handled by registry
51
60
  patterns: "@aiready/pattern-detect",
61
+ duplicates: "@aiready/pattern-detect",
52
62
  context: "@aiready/context-analyzer",
53
- consistency: "@aiready/consistency"
63
+ fragmentation: "@aiready/context-analyzer",
64
+ consistency: "@aiready/consistency",
65
+ "naming-consistency": "@aiready/consistency",
66
+ "ai-signal": "@aiready/ai-signal-clarity",
67
+ "ai-signal-clarity": "@aiready/ai-signal-clarity",
68
+ grounding: "@aiready/agent-grounding",
69
+ "agent-grounding": "@aiready/agent-grounding",
70
+ testability: "@aiready/testability",
71
+ "testability-index": "@aiready/testability",
72
+ "doc-drift": "@aiready/doc-drift",
73
+ "deps-health": "@aiready/deps",
74
+ "dependency-health": "@aiready/deps",
75
+ "change-amp": "@aiready/change-amplification",
76
+ "change-amplification": "@aiready/change-amplification"
54
77
  };
55
78
  async function analyzeUnified(options) {
56
79
  const startTime = Date.now();
@@ -96,7 +119,19 @@ async function analyzeUnified(options) {
96
119
  continue;
97
120
  }
98
121
  try {
99
- const output = await provider.analyze(options);
122
+ const output = await provider.analyze({
123
+ ...options,
124
+ onProgress: (processed, total, message) => {
125
+ if (options.progressCallback) {
126
+ options.progressCallback({
127
+ tool: provider.id,
128
+ processed,
129
+ total,
130
+ message
131
+ });
132
+ }
133
+ }
134
+ });
100
135
  if (options.progressCallback) {
101
136
  options.progressCallback({ tool: provider.id, data: output });
102
137
  }
@@ -495,10 +530,14 @@ async function scanAction(directory, options) {
495
530
  (finalOptions.tools || []).join(", ")
496
531
  );
497
532
  const progressCallback = (event) => {
498
- console.log(import_chalk3.default.cyan(`
499
- --- ${event.tool.toUpperCase()} RESULTS ---`));
533
+ if (event.message) {
534
+ process.stdout.write(`\r\x1B[K [${event.tool}] ${event.message}`);
535
+ return;
536
+ }
537
+ process.stdout.write("\n");
538
+ console.log(import_chalk3.default.cyan(`--- ${event.tool.toUpperCase()} RESULTS ---`));
500
539
  const res = event.data;
501
- if (res.summary) {
540
+ if (res && res.summary) {
502
541
  if (res.summary.totalIssues !== void 0)
503
542
  console.log(` Issues found: ${import_chalk3.default.bold(res.summary.totalIssues)}`);
504
543
  if (res.summary.score !== void 0)
package/dist/cli.mjs CHANGED
@@ -3,7 +3,7 @@ import {
3
3
  __require,
4
4
  analyzeUnified,
5
5
  scoreUnified
6
- } from "./chunk-N56YAZVN.mjs";
6
+ } from "./chunk-LTUQDJPO.mjs";
7
7
 
8
8
  // src/cli.ts
9
9
  import { Command } from "commander";
@@ -341,10 +341,14 @@ async function scanAction(directory, options) {
341
341
  (finalOptions.tools || []).join(", ")
342
342
  );
343
343
  const progressCallback = (event) => {
344
- console.log(chalk3.cyan(`
345
- --- ${event.tool.toUpperCase()} RESULTS ---`));
344
+ if (event.message) {
345
+ process.stdout.write(`\r\x1B[K [${event.tool}] ${event.message}`);
346
+ return;
347
+ }
348
+ process.stdout.write("\n");
349
+ console.log(chalk3.cyan(`--- ${event.tool.toUpperCase()} RESULTS ---`));
346
350
  const res = event.data;
347
- if (res.summary) {
351
+ if (res && res.summary) {
348
352
  if (res.summary.totalIssues !== void 0)
349
353
  console.log(` Issues found: ${chalk3.bold(res.summary.totalIssues)}`);
350
354
  if (res.summary.score !== void 0)
package/dist/index.js CHANGED
@@ -26,6 +26,15 @@ __export(index_exports, {
26
26
  });
27
27
  module.exports = __toCommonJS(index_exports);
28
28
  var import_core = require("@aiready/core");
29
+ var import_pattern_detect = require("@aiready/pattern-detect");
30
+ var import_context_analyzer = require("@aiready/context-analyzer");
31
+ var import_consistency = require("@aiready/consistency");
32
+ var import_ai_signal_clarity = require("@aiready/ai-signal-clarity");
33
+ var import_agent_grounding = require("@aiready/agent-grounding");
34
+ var import_testability = require("@aiready/testability");
35
+ var import_doc_drift = require("@aiready/doc-drift");
36
+ var import_deps = require("@aiready/deps");
37
+ var import_change_amplification = require("@aiready/change-amplification");
29
38
  var TOOL_PACKAGE_MAP = {
30
39
  [import_core.ToolName.PatternDetect]: "@aiready/pattern-detect",
31
40
  [import_core.ToolName.ContextAnalyzer]: "@aiready/context-analyzer",
@@ -38,8 +47,22 @@ var TOOL_PACKAGE_MAP = {
38
47
  [import_core.ToolName.ChangeAmplification]: "@aiready/change-amplification",
39
48
  // Aliases handled by registry
40
49
  patterns: "@aiready/pattern-detect",
50
+ duplicates: "@aiready/pattern-detect",
41
51
  context: "@aiready/context-analyzer",
42
- consistency: "@aiready/consistency"
52
+ fragmentation: "@aiready/context-analyzer",
53
+ consistency: "@aiready/consistency",
54
+ "naming-consistency": "@aiready/consistency",
55
+ "ai-signal": "@aiready/ai-signal-clarity",
56
+ "ai-signal-clarity": "@aiready/ai-signal-clarity",
57
+ grounding: "@aiready/agent-grounding",
58
+ "agent-grounding": "@aiready/agent-grounding",
59
+ testability: "@aiready/testability",
60
+ "testability-index": "@aiready/testability",
61
+ "doc-drift": "@aiready/doc-drift",
62
+ "deps-health": "@aiready/deps",
63
+ "dependency-health": "@aiready/deps",
64
+ "change-amp": "@aiready/change-amplification",
65
+ "change-amplification": "@aiready/change-amplification"
43
66
  };
44
67
  async function analyzeUnified(options) {
45
68
  const startTime = Date.now();
@@ -85,7 +108,19 @@ async function analyzeUnified(options) {
85
108
  continue;
86
109
  }
87
110
  try {
88
- const output = await provider.analyze(options);
111
+ const output = await provider.analyze({
112
+ ...options,
113
+ onProgress: (processed, total, message) => {
114
+ if (options.progressCallback) {
115
+ options.progressCallback({
116
+ tool: provider.id,
117
+ processed,
118
+ total,
119
+ message
120
+ });
121
+ }
122
+ }
123
+ });
89
124
  if (options.progressCallback) {
90
125
  options.progressCallback({ tool: provider.id, data: output });
91
126
  }
package/dist/index.mjs CHANGED
@@ -2,7 +2,7 @@ import {
2
2
  analyzeUnified,
3
3
  generateUnifiedSummary,
4
4
  scoreUnified
5
- } from "./chunk-N56YAZVN.mjs";
5
+ } from "./chunk-LTUQDJPO.mjs";
6
6
  export {
7
7
  analyzeUnified,
8
8
  generateUnifiedSummary,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aiready/cli",
3
- "version": "0.12.0",
3
+ "version": "0.12.3",
4
4
  "description": "Unified CLI for AIReady analysis tools",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.mjs",
@@ -11,17 +11,17 @@
11
11
  "dependencies": {
12
12
  "chalk": "^5.3.0",
13
13
  "commander": "^14.0.0",
14
- "@aiready/agent-grounding": "0.11.0",
15
- "@aiready/context-analyzer": "0.19.0",
16
- "@aiready/doc-drift": "0.11.0",
17
- "@aiready/consistency": "0.18.0",
18
- "@aiready/core": "0.21.0",
19
- "@aiready/change-amplification": "0.11.0",
20
- "@aiready/pattern-detect": "0.14.0",
21
- "@aiready/ai-signal-clarity": "0.11.0",
22
- "@aiready/testability": "0.4.0",
23
- "@aiready/deps": "0.11.0",
24
- "@aiready/visualizer": "0.4.0"
14
+ "@aiready/agent-grounding": "0.11.3",
15
+ "@aiready/core": "0.21.3",
16
+ "@aiready/consistency": "0.18.3",
17
+ "@aiready/doc-drift": "0.11.3",
18
+ "@aiready/change-amplification": "0.11.3",
19
+ "@aiready/context-analyzer": "0.19.3",
20
+ "@aiready/deps": "0.11.3",
21
+ "@aiready/pattern-detect": "0.14.3",
22
+ "@aiready/testability": "0.4.3",
23
+ "@aiready/visualizer": "0.4.3",
24
+ "@aiready/ai-signal-clarity": "0.11.3"
25
25
  },
26
26
  "devDependencies": {
27
27
  "@types/node": "^24.0.0",