@aiready/cli 0.12.4 → 0.12.9

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.12.3 build /Users/pengcao/projects/aiready/packages/cli
3
+ > @aiready/cli@0.12.8 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
-  WARN  ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta] 11:12:15 am
13
+ [1:29:18 PM]  WARN  ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta]
14
14
 
15
15
  src/cli.ts:25:31:
16
16
   25 │ return dirname(fileURLToPath(import.meta.url));
@@ -20,10 +20,10 @@
20
20
 
21
21
 
22
22
 
23
- CJS dist/cli.js 67.18 KB
24
- CJS dist/index.js 8.42 KB
25
- CJS ⚡️ Build success in 28ms
26
- ESM dist/cli.mjs 56.79 KB
23
+ CJS dist/index.js 8.48 KB
24
+ CJS dist/cli.js 67.06 KB
25
+ CJS ⚡️ Build success in 27ms
26
+ ESM dist/cli.mjs 56.62 KB
27
27
  ESM dist/index.mjs 170.00 B
28
- ESM dist/chunk-7K3CNS6C.mjs 7.29 KB
29
- ESM ⚡️ Build success in 28ms
28
+ ESM dist/chunk-L4MJHD72.mjs 7.35 KB
29
+ ESM ⚡️ Build success in 27ms
@@ -1,55 +1,55 @@
1
1
 
2
2
  
3
- > @aiready/cli@0.12.3 test /Users/pengcao/projects/aiready/packages/cli
3
+ > @aiready/cli@0.12.8 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
9
  stdout | src/__tests__/cli.test.ts
10
- [ToolRegistry#0.657519876473521] Registering tool: pattern-detect (patterns, duplicates, duplication)
10
+ [ToolRegistry#0.3730169166647759] Registering tool: pattern-detect (patterns, duplicates, duplication)
11
11
 
12
12
  stdout | src/__tests__/cli.test.ts
13
- [ToolRegistry#0.657519876473521] Registering tool: context-analyzer (context, fragmentation, budget)
13
+ [ToolRegistry#0.3730169166647759] Registering tool: context-analyzer (context, fragmentation, budget)
14
14
 
15
15
  stdout | src/__tests__/cli.test.ts
16
- [ToolRegistry#0.657519876473521] Registering tool: naming-consistency (consistency, naming, standards)
16
+ [ToolRegistry#0.3730169166647759] Registering tool: naming-consistency (consistency, naming, standards)
17
17
 
18
18
  stdout | src/__tests__/cli.test.ts
19
- [ToolRegistry#0.657519876473521] Registering tool: ai-signal-clarity (ai-signal, clarity, hallucination)
19
+ [ToolRegistry#0.3730169166647759] Registering tool: ai-signal-clarity (ai-signal, clarity, hallucination)
20
20
 
21
21
  stdout | src/__tests__/cli.test.ts
22
- [ToolRegistry#0.657519876473521] Registering tool: agent-grounding (agent-grounding, grounding, navigation)
22
+ [ToolRegistry#0.3730169166647759] Registering tool: agent-grounding (agent-grounding, grounding, navigation)
23
23
 
24
24
  stdout | src/__tests__/cli.test.ts
25
- [ToolRegistry#0.657519876473521] Registering tool: testability-index (testability, tests, verification)
25
+ [ToolRegistry#0.3730169166647759] Registering tool: testability-index (testability, tests, verification)
26
26
 
27
27
  stdout | src/__tests__/cli.test.ts
28
- [ToolRegistry#0.657519876473521] Registering tool: doc-drift (doc-drift, docs, jsdoc)
28
+ [ToolRegistry#0.3730169166647759] Registering tool: doc-drift (doc-drift, docs, jsdoc)
29
29
 
30
30
  stdout | src/__tests__/cli.test.ts
31
- [ToolRegistry#0.657519876473521] Registering tool: dependency-health (deps, deps-health, packages)
31
+ [ToolRegistry#0.3730169166647759] Registering tool: dependency-health (deps, deps-health, packages)
32
32
 
33
33
  stdout | src/__tests__/cli.test.ts
34
- [ToolRegistry#0.657519876473521] Registering tool: change-amplification (change-amp, change-amplification, coupling)
34
+ [ToolRegistry#0.3730169166647759] Registering tool: change-amplification (change-amp, change-amplification, coupling)
35
35
 
36
36
  stdout | src/__tests__/cli.test.ts > CLI Unified Analysis > should run unified analysis with both tools
37
- [ToolRegistry#0.657519876473521] Registering tool: pattern-detect (patterns)
38
- [ToolRegistry#0.657519876473521] Registering tool: context-analyzer (context)
37
+ [ToolRegistry#0.3730169166647759] Registering tool: pattern-detect (patterns)
38
+ [ToolRegistry#0.3730169166647759] Registering tool: context-analyzer (context)
39
39
 
40
40
  stdout | src/__tests__/cli.test.ts > CLI Unified Analysis > should run analysis with only patterns tool
41
- [ToolRegistry#0.657519876473521] Registering tool: pattern-detect (patterns)
42
- [ToolRegistry#0.657519876473521] Registering tool: context-analyzer (context)
41
+ [ToolRegistry#0.3730169166647759] Registering tool: pattern-detect (patterns)
42
+ [ToolRegistry#0.3730169166647759] Registering tool: context-analyzer (context)
43
43
 
44
44
  stdout | src/__tests__/cli.test.ts > CLI Unified Analysis > should run analysis with only context tool
45
- [ToolRegistry#0.657519876473521] Registering tool: pattern-detect (patterns)
46
- [ToolRegistry#0.657519876473521] Registering tool: context-analyzer (context)
45
+ [ToolRegistry#0.3730169166647759] Registering tool: pattern-detect (patterns)
46
+ [ToolRegistry#0.3730169166647759] Registering tool: context-analyzer (context)
47
47
 
48
48
  ✓ src/__tests__/cli.test.ts (3 tests) 3ms
49
49
 
50
50
   Test Files  1 passed (1)
51
51
   Tests  3 passed (3)
52
-  Start at  11:12:33
53
-  Duration  443ms (transform 116ms, setup 0ms, import 321ms, tests 3ms, environment 0ms)
52
+  Start at  13:29:35
53
+  Duration  402ms (transform 106ms, setup 0ms, import 320ms, tests 3ms, environment 0ms)
54
54
 
55
55
  [?25h
@@ -0,0 +1,239 @@
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
+ "ai-signal": "@aiready/ai-signal-clarity",
41
+ grounding: "@aiready/agent-grounding",
42
+ testability: "@aiready/testability",
43
+ "deps-health": "@aiready/deps",
44
+ "change-amp": "@aiready/change-amplification"
45
+ };
46
+ async function analyzeUnified(options) {
47
+ const startTime = Date.now();
48
+ const requestedTools = options.tools || [
49
+ "patterns",
50
+ "context",
51
+ "consistency"
52
+ ];
53
+ const result = {
54
+ summary: {
55
+ totalIssues: 0,
56
+ criticalIssues: 0,
57
+ // Added as per instruction
58
+ majorIssues: 0,
59
+ // Added as per instruction
60
+ totalFiles: 0,
61
+ toolsRun: [],
62
+ executionTime: 0,
63
+ config: options
64
+ // Added as per instruction
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 sanitizedConfig = { ...options };
98
+ delete sanitizedConfig.onProgress;
99
+ delete sanitizedConfig.progressCallback;
100
+ const output = await provider.analyze({
101
+ ...options,
102
+ onProgress: (processed, total, message) => {
103
+ if (options.progressCallback) {
104
+ options.progressCallback({
105
+ tool: provider.id,
106
+ processed,
107
+ total,
108
+ message
109
+ });
110
+ }
111
+ }
112
+ });
113
+ if (output.metadata) {
114
+ output.metadata.config = sanitizedConfig;
115
+ }
116
+ if (options.progressCallback) {
117
+ options.progressCallback({ tool: provider.id, data: output });
118
+ }
119
+ result[provider.id] = output;
120
+ result.summary.toolsRun.push(provider.id);
121
+ const toolFiles = output.summary?.totalFiles || output.summary?.filesAnalyzed || 0;
122
+ if (toolFiles > result.summary.totalFiles) {
123
+ result.summary.totalFiles = toolFiles;
124
+ }
125
+ const issueCount = output.results.reduce(
126
+ (sum, file) => sum + (file.issues?.length || 0),
127
+ 0
128
+ );
129
+ result.summary.totalIssues += issueCount;
130
+ if (provider.alias && Array.isArray(provider.alias)) {
131
+ for (const alias of provider.alias) {
132
+ if (!result[alias]) {
133
+ result[alias] = output;
134
+ }
135
+ }
136
+ }
137
+ const camelCaseId = provider.id.replace(
138
+ /-([a-z])/g,
139
+ (g) => g[1].toUpperCase()
140
+ );
141
+ if (camelCaseId !== provider.id && !result[camelCaseId]) {
142
+ result[camelCaseId] = output;
143
+ }
144
+ } catch (err) {
145
+ console.error(`\u274C Error running tool '${provider.id}':`, err);
146
+ }
147
+ }
148
+ result.summary.executionTime = Date.now() - startTime;
149
+ return result;
150
+ }
151
+ async function scoreUnified(results, options) {
152
+ const toolScores = /* @__PURE__ */ new Map();
153
+ for (const toolId of results.summary.toolsRun) {
154
+ const provider = ToolRegistry.get(toolId);
155
+ if (!provider) continue;
156
+ const output = results[toolId];
157
+ if (!output) continue;
158
+ try {
159
+ const toolScore = provider.score(output, options);
160
+ if (!toolScore.tokenBudget) {
161
+ if (toolId === ToolName.PatternDetect && output.duplicates) {
162
+ const wastedTokens = output.duplicates.reduce(
163
+ (sum, d) => sum + (d.tokenCost || 0),
164
+ 0
165
+ );
166
+ toolScore.tokenBudget = calculateTokenBudget({
167
+ totalContextTokens: wastedTokens * 2,
168
+ wastedTokens: {
169
+ duplication: wastedTokens,
170
+ fragmentation: 0,
171
+ chattiness: 0
172
+ }
173
+ });
174
+ } else if (toolId === ToolName.ContextAnalyzer && output.summary) {
175
+ toolScore.tokenBudget = calculateTokenBudget({
176
+ totalContextTokens: output.summary.totalTokens,
177
+ wastedTokens: {
178
+ duplication: 0,
179
+ fragmentation: output.summary.totalPotentialSavings || 0,
180
+ chattiness: 0
181
+ }
182
+ });
183
+ }
184
+ }
185
+ toolScores.set(toolId, toolScore);
186
+ } catch (err) {
187
+ console.error(`\u274C Error scoring tool '${toolId}':`, err);
188
+ }
189
+ }
190
+ if (toolScores.size === 0) {
191
+ return {
192
+ overall: 0,
193
+ rating: "Critical",
194
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
195
+ toolsUsed: [],
196
+ breakdown: [],
197
+ calculation: {
198
+ formula: "0 / 0 = 0",
199
+ weights: {},
200
+ normalized: "0 / 0 = 0"
201
+ }
202
+ };
203
+ }
204
+ return calculateOverallScore(toolScores, options, void 0);
205
+ }
206
+ function generateUnifiedSummary(result) {
207
+ const { summary } = result;
208
+ let output = `\u{1F680} AIReady Analysis Complete
209
+
210
+ `;
211
+ output += `\u{1F4CA} Summary:
212
+ `;
213
+ output += ` Tools run: ${summary.toolsRun.join(", ")}
214
+ `;
215
+ output += ` Total issues found: ${summary.totalIssues}
216
+ `;
217
+ output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
218
+
219
+ `;
220
+ for (const provider of ToolRegistry.getAll()) {
221
+ const toolResult = result[provider.id];
222
+ if (toolResult) {
223
+ const issueCount = toolResult.results.reduce(
224
+ (sum, r) => sum + (r.issues?.length || 0),
225
+ 0
226
+ );
227
+ output += `\u2022 ${provider.id}: ${issueCount} issues
228
+ `;
229
+ }
230
+ }
231
+ return output;
232
+ }
233
+
234
+ export {
235
+ __require,
236
+ analyzeUnified,
237
+ scoreUnified,
238
+ generateUnifiedSummary
239
+ };
package/dist/cli.js CHANGED
@@ -62,18 +62,11 @@ var TOOL_PACKAGE_MAP = {
62
62
  context: "@aiready/context-analyzer",
63
63
  fragmentation: "@aiready/context-analyzer",
64
64
  consistency: "@aiready/consistency",
65
- "naming-consistency": "@aiready/consistency",
66
65
  "ai-signal": "@aiready/ai-signal-clarity",
67
- "ai-signal-clarity": "@aiready/ai-signal-clarity",
68
66
  grounding: "@aiready/agent-grounding",
69
- "agent-grounding": "@aiready/agent-grounding",
70
67
  testability: "@aiready/testability",
71
- "testability-index": "@aiready/testability",
72
- "doc-drift": "@aiready/doc-drift",
73
68
  "deps-health": "@aiready/deps",
74
- "dependency-health": "@aiready/deps",
75
- "change-amp": "@aiready/change-amplification",
76
- "change-amplification": "@aiready/change-amplification"
69
+ "change-amp": "@aiready/change-amplification"
77
70
  };
78
71
  async function analyzeUnified(options) {
79
72
  const startTime = Date.now();
@@ -85,9 +78,15 @@ async function analyzeUnified(options) {
85
78
  const result = {
86
79
  summary: {
87
80
  totalIssues: 0,
81
+ criticalIssues: 0,
82
+ // Added as per instruction
83
+ majorIssues: 0,
84
+ // Added as per instruction
88
85
  totalFiles: 0,
89
86
  toolsRun: [],
90
- executionTime: 0
87
+ executionTime: 0,
88
+ config: options
89
+ // Added as per instruction
91
90
  }
92
91
  };
93
92
  for (const toolName of requestedTools) {
@@ -120,6 +119,9 @@ async function analyzeUnified(options) {
120
119
  continue;
121
120
  }
122
121
  try {
122
+ const sanitizedConfig = { ...options };
123
+ delete sanitizedConfig.onProgress;
124
+ delete sanitizedConfig.progressCallback;
123
125
  const output = await provider.analyze({
124
126
  ...options,
125
127
  onProgress: (processed, total, message) => {
@@ -133,6 +135,9 @@ async function analyzeUnified(options) {
133
135
  }
134
136
  }
135
137
  });
138
+ if (output.metadata) {
139
+ output.metadata.config = sanitizedConfig;
140
+ }
136
141
  if (options.progressCallback) {
137
142
  options.progressCallback({ tool: provider.id, data: output });
138
143
  }
@@ -539,7 +544,7 @@ async function scanAction(directory, options) {
539
544
  process.stdout.write(`\r\x1B[K [${event.tool}] ${event.message}`);
540
545
  return;
541
546
  }
542
- process.stdout.write("\n");
547
+ process.stdout.write("\r\x1B[K");
543
548
  console.log(import_chalk3.default.cyan(`--- ${event.tool.toUpperCase()} RESULTS ---`));
544
549
  const res = event.data;
545
550
  if (res && res.summary) {
@@ -556,11 +561,7 @@ async function scanAction(directory, options) {
556
561
  const results = await analyzeUnified({
557
562
  ...finalOptions,
558
563
  progressCallback,
559
- onProgress: (processed, total, message) => {
560
- process.stdout.write(
561
- `\r\x1B[K [${processed}/${total}] ${message}...`
562
- );
563
- if (processed === total) process.stdout.write("\n");
564
+ onProgress: () => {
564
565
  },
565
566
  suppressToolConfig: true
566
567
  });
package/dist/cli.mjs CHANGED
@@ -3,7 +3,7 @@ import {
3
3
  __require,
4
4
  analyzeUnified,
5
5
  scoreUnified
6
- } from "./chunk-7K3CNS6C.mjs";
6
+ } from "./chunk-L4MJHD72.mjs";
7
7
 
8
8
  // src/cli.ts
9
9
  import { Command } from "commander";
@@ -345,7 +345,7 @@ async function scanAction(directory, options) {
345
345
  process.stdout.write(`\r\x1B[K [${event.tool}] ${event.message}`);
346
346
  return;
347
347
  }
348
- process.stdout.write("\n");
348
+ process.stdout.write("\r\x1B[K");
349
349
  console.log(chalk3.cyan(`--- ${event.tool.toUpperCase()} RESULTS ---`));
350
350
  const res = event.data;
351
351
  if (res && res.summary) {
@@ -362,11 +362,7 @@ async function scanAction(directory, options) {
362
362
  const results = await analyzeUnified({
363
363
  ...finalOptions,
364
364
  progressCallback,
365
- onProgress: (processed, total, message) => {
366
- process.stdout.write(
367
- `\r\x1B[K [${processed}/${total}] ${message}...`
368
- );
369
- if (processed === total) process.stdout.write("\n");
365
+ onProgress: () => {
370
366
  },
371
367
  suppressToolConfig: true
372
368
  });
package/dist/index.js CHANGED
@@ -51,18 +51,11 @@ var TOOL_PACKAGE_MAP = {
51
51
  context: "@aiready/context-analyzer",
52
52
  fragmentation: "@aiready/context-analyzer",
53
53
  consistency: "@aiready/consistency",
54
- "naming-consistency": "@aiready/consistency",
55
54
  "ai-signal": "@aiready/ai-signal-clarity",
56
- "ai-signal-clarity": "@aiready/ai-signal-clarity",
57
55
  grounding: "@aiready/agent-grounding",
58
- "agent-grounding": "@aiready/agent-grounding",
59
56
  testability: "@aiready/testability",
60
- "testability-index": "@aiready/testability",
61
- "doc-drift": "@aiready/doc-drift",
62
57
  "deps-health": "@aiready/deps",
63
- "dependency-health": "@aiready/deps",
64
- "change-amp": "@aiready/change-amplification",
65
- "change-amplification": "@aiready/change-amplification"
58
+ "change-amp": "@aiready/change-amplification"
66
59
  };
67
60
  async function analyzeUnified(options) {
68
61
  const startTime = Date.now();
@@ -74,9 +67,15 @@ async function analyzeUnified(options) {
74
67
  const result = {
75
68
  summary: {
76
69
  totalIssues: 0,
70
+ criticalIssues: 0,
71
+ // Added as per instruction
72
+ majorIssues: 0,
73
+ // Added as per instruction
77
74
  totalFiles: 0,
78
75
  toolsRun: [],
79
- executionTime: 0
76
+ executionTime: 0,
77
+ config: options
78
+ // Added as per instruction
80
79
  }
81
80
  };
82
81
  for (const toolName of requestedTools) {
@@ -109,6 +108,9 @@ async function analyzeUnified(options) {
109
108
  continue;
110
109
  }
111
110
  try {
111
+ const sanitizedConfig = { ...options };
112
+ delete sanitizedConfig.onProgress;
113
+ delete sanitizedConfig.progressCallback;
112
114
  const output = await provider.analyze({
113
115
  ...options,
114
116
  onProgress: (processed, total, message) => {
@@ -122,6 +124,9 @@ async function analyzeUnified(options) {
122
124
  }
123
125
  }
124
126
  });
127
+ if (output.metadata) {
128
+ output.metadata.config = sanitizedConfig;
129
+ }
125
130
  if (options.progressCallback) {
126
131
  options.progressCallback({ tool: provider.id, data: output });
127
132
  }
package/dist/index.mjs CHANGED
@@ -2,7 +2,7 @@ import {
2
2
  analyzeUnified,
3
3
  generateUnifiedSummary,
4
4
  scoreUnified
5
- } from "./chunk-7K3CNS6C.mjs";
5
+ } from "./chunk-L4MJHD72.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.4",
3
+ "version": "0.12.9",
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.4",
15
- "@aiready/consistency": "0.18.4",
16
- "@aiready/context-analyzer": "0.19.4",
17
- "@aiready/core": "0.21.4",
18
- "@aiready/deps": "0.11.4",
19
- "@aiready/doc-drift": "0.11.4",
20
- "@aiready/ai-signal-clarity": "0.11.4",
21
- "@aiready/pattern-detect": "0.14.4",
22
- "@aiready/change-amplification": "0.11.4",
23
- "@aiready/visualizer": "0.4.4",
24
- "@aiready/testability": "0.4.4"
14
+ "@aiready/agent-grounding": "0.11.9",
15
+ "@aiready/consistency": "0.18.9",
16
+ "@aiready/context-analyzer": "0.19.9",
17
+ "@aiready/deps": "0.11.9",
18
+ "@aiready/core": "0.21.9",
19
+ "@aiready/doc-drift": "0.11.9",
20
+ "@aiready/ai-signal-clarity": "0.11.9",
21
+ "@aiready/visualizer": "0.4.9",
22
+ "@aiready/pattern-detect": "0.14.9",
23
+ "@aiready/change-amplification": "0.11.9",
24
+ "@aiready/testability": "0.4.9"
25
25
  },
26
26
  "devDependencies": {
27
27
  "@types/node": "^24.0.0",