@aiready/cli 0.9.47 → 0.10.2

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 (55) hide show
  1. package/.turbo/turbo-build.log +8 -8
  2. package/.turbo/turbo-test.log +6 -7
  3. package/dist/{chunk-6FOVC2OE.mjs → chunk-EQ2HQSTJ.mjs} +83 -61
  4. package/dist/{chunk-MEXEG3IJ.mjs → chunk-VUCNUYI7.mjs} +90 -62
  5. package/dist/cli.js +105 -75
  6. package/dist/cli.mjs +30 -25
  7. package/dist/index.js +86 -61
  8. package/dist/index.mjs +1 -1
  9. package/package.json +12 -12
  10. package/src/.aiready/aiready-report-20260305-153847.json +8015 -0
  11. package/src/.aiready/aiready-report-20260305-154121.json +8015 -0
  12. package/src/.aiready/aiready-report-20260305-160026.json +8015 -0
  13. package/src/.aiready/aiready-report-20260305-160752.json +8015 -0
  14. package/src/.aiready/aiready-report-20260305-163858.json +8015 -0
  15. package/src/.aiready/aiready-report-20260305-171001.json +8317 -0
  16. package/src/.aiready/aiready-report-20260305-201337.json +8317 -0
  17. package/src/__tests__/cli.test.ts +6 -6
  18. package/src/commands/scan.ts +27 -22
  19. package/src/commands/visualize.ts +3 -3
  20. package/src/index.ts +109 -90
  21. package/dist/__tests__/cli.test.d.ts +0 -2
  22. package/dist/__tests__/cli.test.d.ts.map +0 -1
  23. package/dist/__tests__/cli.test.js +0 -52
  24. package/dist/__tests__/cli.test.js.map +0 -1
  25. package/dist/agent-grounding-DAOSU4MF.mjs +0 -7
  26. package/dist/chunk-2LXCBVPN.mjs +0 -109
  27. package/dist/chunk-3SG2GLFJ.mjs +0 -118
  28. package/dist/chunk-5GZDRZ3T.mjs +0 -126
  29. package/dist/chunk-DEZVFBPS.mjs +0 -111
  30. package/dist/chunk-G6SDH7ZS.mjs +0 -126
  31. package/dist/chunk-HLBKROD3.mjs +0 -237
  32. package/dist/chunk-JQG7ZATX.mjs +0 -211
  33. package/dist/chunk-LLJMKNBI.mjs +0 -243
  34. package/dist/chunk-M7O2MEM5.mjs +0 -211
  35. package/dist/chunk-N4SLON5K.mjs +0 -152
  36. package/dist/chunk-OVELUOM6.mjs +0 -112
  37. package/dist/chunk-P3XAXCTK.mjs +0 -110
  38. package/dist/chunk-PDOONNSK.mjs +0 -228
  39. package/dist/chunk-QXQP6BMO.mjs +0 -109
  40. package/dist/chunk-RBWLQRKR.mjs +0 -39
  41. package/dist/chunk-XAF2EW5H.mjs +0 -46
  42. package/dist/chunk-Y6FXYEAI.mjs +0 -10
  43. package/dist/chunk-YIS6WTY5.mjs +0 -35
  44. package/dist/cli.d.mts +0 -1
  45. package/dist/cli.d.ts +0 -3
  46. package/dist/cli.d.ts.map +0 -1
  47. package/dist/cli.js.map +0 -1
  48. package/dist/deps-health-UWVYJ7FZ.mjs +0 -47
  49. package/dist/doc-drift-G7MGAZAE.mjs +0 -47
  50. package/dist/hallucination-risk-XU6E7IGN.mjs +0 -7
  51. package/dist/index.d.mts +0 -33
  52. package/dist/index.d.ts +0 -32
  53. package/dist/index.d.ts.map +0 -1
  54. package/dist/index.js.map +0 -1
  55. package/dist/testability-VDZJZ4MF.mjs +0 -7
@@ -1,109 +0,0 @@
1
- // src/index.ts
2
- import { analyzePatterns } from "@aiready/pattern-detect";
3
- import { analyzeContext } from "@aiready/context-analyzer";
4
- import { analyzeConsistency } from "@aiready/consistency";
5
- var severityOrder = {
6
- critical: 4,
7
- major: 3,
8
- minor: 2,
9
- info: 1
10
- };
11
- function sortBySeverity(results) {
12
- return results.map((file) => {
13
- const sortedIssues = [...file.issues].sort((a, b) => {
14
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
15
- if (severityDiff !== 0) return severityDiff;
16
- return (a.location?.line || 0) - (b.location?.line || 0);
17
- });
18
- return { ...file, issues: sortedIssues };
19
- }).sort((a, b) => {
20
- const aMaxSeverity = Math.max(...a.issues.map((i) => severityOrder[i.severity] || 0), 0);
21
- const bMaxSeverity = Math.max(...b.issues.map((i) => severityOrder[i.severity] || 0), 0);
22
- if (aMaxSeverity !== bMaxSeverity) {
23
- return bMaxSeverity - aMaxSeverity;
24
- }
25
- if (a.issues.length !== b.issues.length) {
26
- return b.issues.length - a.issues.length;
27
- }
28
- return a.fileName.localeCompare(b.fileName);
29
- });
30
- }
31
- async function analyzeUnified(options) {
32
- const startTime = Date.now();
33
- const tools = options.tools || ["patterns", "context", "consistency"];
34
- const result = {
35
- summary: {
36
- totalIssues: 0,
37
- toolsRun: tools,
38
- executionTime: 0
39
- }
40
- };
41
- if (tools.includes("patterns")) {
42
- const patternResult = await analyzePatterns(options);
43
- result.patterns = sortBySeverity(patternResult.results);
44
- result.duplicates = patternResult.duplicates;
45
- result.summary.totalIssues += patternResult.results.reduce(
46
- (sum, file) => sum + file.issues.length,
47
- 0
48
- );
49
- }
50
- if (tools.includes("context")) {
51
- const contextResults = await analyzeContext(options);
52
- result.context = contextResults.sort((a, b) => {
53
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
54
- if (severityDiff !== 0) return severityDiff;
55
- if (a.tokenCost !== b.tokenCost) return b.tokenCost - a.tokenCost;
56
- return b.fragmentationScore - a.fragmentationScore;
57
- });
58
- result.summary.totalIssues += result.context?.length || 0;
59
- }
60
- if (tools.includes("consistency")) {
61
- const consistencyOptions = {
62
- rootDir: options.rootDir,
63
- include: options.include,
64
- exclude: options.exclude,
65
- ...options.consistency || {}
66
- };
67
- const report = await analyzeConsistency(consistencyOptions);
68
- if (report.results) {
69
- report.results = sortBySeverity(report.results);
70
- }
71
- result.consistency = report;
72
- result.summary.totalIssues += report.summary.totalIssues;
73
- }
74
- result.summary.executionTime = Date.now() - startTime;
75
- return result;
76
- }
77
- function generateUnifiedSummary(result) {
78
- const { summary } = result;
79
- let output = `\u{1F680} AIReady Analysis Complete
80
-
81
- `;
82
- output += `\u{1F4CA} Summary:
83
- `;
84
- output += ` Tools run: ${summary.toolsRun.join(", ")}
85
- `;
86
- output += ` Total issues found: ${summary.totalIssues}
87
- `;
88
- output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
89
-
90
- `;
91
- if (result.patterns?.length) {
92
- output += `\u{1F50D} Pattern Analysis: ${result.patterns.length} issues
93
- `;
94
- }
95
- if (result.context?.length) {
96
- output += `\u{1F9E0} Context Analysis: ${result.context.length} issues
97
- `;
98
- }
99
- if (result.consistency) {
100
- output += `\u{1F3F7}\uFE0F Consistency Analysis: ${result.consistency.summary.totalIssues} issues
101
- `;
102
- }
103
- return output;
104
- }
105
-
106
- export {
107
- analyzeUnified,
108
- generateUnifiedSummary
109
- };
@@ -1,118 +0,0 @@
1
- // src/index.ts
2
- import { analyzePatterns } from "@aiready/pattern-detect";
3
- import { analyzeContext } from "@aiready/context-analyzer";
4
- import { analyzeConsistency } from "@aiready/consistency";
5
- var severityOrder = {
6
- critical: 4,
7
- major: 3,
8
- minor: 2,
9
- info: 1
10
- };
11
- function sortBySeverity(results) {
12
- return results.map((file) => {
13
- const sortedIssues = [...file.issues].sort((a, b) => {
14
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
15
- if (severityDiff !== 0) return severityDiff;
16
- return (a.location?.line || 0) - (b.location?.line || 0);
17
- });
18
- return { ...file, issues: sortedIssues };
19
- }).sort((a, b) => {
20
- const aMaxSeverity = Math.max(...a.issues.map((i) => severityOrder[i.severity] || 0), 0);
21
- const bMaxSeverity = Math.max(...b.issues.map((i) => severityOrder[i.severity] || 0), 0);
22
- if (aMaxSeverity !== bMaxSeverity) {
23
- return bMaxSeverity - aMaxSeverity;
24
- }
25
- if (a.issues.length !== b.issues.length) {
26
- return b.issues.length - a.issues.length;
27
- }
28
- return a.fileName.localeCompare(b.fileName);
29
- });
30
- }
31
- async function analyzeUnified(options) {
32
- const startTime = Date.now();
33
- const tools = options.tools || ["patterns", "context", "consistency"];
34
- const result = {
35
- summary: {
36
- totalIssues: 0,
37
- toolsRun: tools,
38
- executionTime: 0
39
- }
40
- };
41
- if (tools.includes("patterns")) {
42
- const patternResult = await analyzePatterns(options);
43
- if (options.progressCallback) {
44
- options.progressCallback({ tool: "patterns", data: patternResult });
45
- }
46
- result.patterns = sortBySeverity(patternResult.results);
47
- result.duplicates = patternResult.duplicates;
48
- result.summary.totalIssues += patternResult.results.reduce(
49
- (sum, file) => sum + file.issues.length,
50
- 0
51
- );
52
- }
53
- if (tools.includes("context")) {
54
- const contextResults = await analyzeContext(options);
55
- if (options.progressCallback) {
56
- options.progressCallback({ tool: "context", data: contextResults });
57
- }
58
- result.context = contextResults.sort((a, b) => {
59
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
60
- if (severityDiff !== 0) return severityDiff;
61
- if (a.tokenCost !== b.tokenCost) return b.tokenCost - a.tokenCost;
62
- return b.fragmentationScore - a.fragmentationScore;
63
- });
64
- result.summary.totalIssues += result.context?.length || 0;
65
- }
66
- if (tools.includes("consistency")) {
67
- const consistencyOptions = {
68
- rootDir: options.rootDir,
69
- include: options.include,
70
- exclude: options.exclude,
71
- ...options.consistency || {}
72
- };
73
- const report = await analyzeConsistency(consistencyOptions);
74
- if (options.progressCallback) {
75
- options.progressCallback({ tool: "consistency", data: report });
76
- }
77
- if (report.results) {
78
- report.results = sortBySeverity(report.results);
79
- }
80
- result.consistency = report;
81
- result.summary.totalIssues += report.summary.totalIssues;
82
- }
83
- result.summary.executionTime = Date.now() - startTime;
84
- return result;
85
- }
86
- function generateUnifiedSummary(result) {
87
- const { summary } = result;
88
- let output = `\u{1F680} AIReady Analysis Complete
89
-
90
- `;
91
- output += `\u{1F4CA} Summary:
92
- `;
93
- output += ` Tools run: ${summary.toolsRun.join(", ")}
94
- `;
95
- output += ` Total issues found: ${summary.totalIssues}
96
- `;
97
- output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
98
-
99
- `;
100
- if (result.patterns) {
101
- output += `\u{1F50D} Pattern Analysis: ${result.patterns.length} issues
102
- `;
103
- }
104
- if (result.context) {
105
- output += `\u{1F9E0} Context Analysis: ${result.context.length} issues
106
- `;
107
- }
108
- if (result.consistency) {
109
- output += `\u{1F3F7}\uFE0F Consistency Analysis: ${result.consistency.summary.totalIssues} issues
110
- `;
111
- }
112
- return output;
113
- }
114
-
115
- export {
116
- analyzeUnified,
117
- generateUnifiedSummary
118
- };
@@ -1,126 +0,0 @@
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 { analyzePatterns } from "@aiready/pattern-detect";
10
- import { analyzeContext } from "@aiready/context-analyzer";
11
- import { analyzeConsistency } from "@aiready/consistency";
12
- var severityOrder = {
13
- critical: 4,
14
- major: 3,
15
- minor: 2,
16
- info: 1
17
- };
18
- function sortBySeverity(results) {
19
- return results.map((file) => {
20
- const sortedIssues = [...file.issues].sort((a, b) => {
21
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
22
- if (severityDiff !== 0) return severityDiff;
23
- return (a.location?.line || 0) - (b.location?.line || 0);
24
- });
25
- return { ...file, issues: sortedIssues };
26
- }).sort((a, b) => {
27
- const aMaxSeverity = Math.max(...a.issues.map((i) => severityOrder[i.severity] || 0), 0);
28
- const bMaxSeverity = Math.max(...b.issues.map((i) => severityOrder[i.severity] || 0), 0);
29
- if (aMaxSeverity !== bMaxSeverity) {
30
- return bMaxSeverity - aMaxSeverity;
31
- }
32
- if (a.issues.length !== b.issues.length) {
33
- return b.issues.length - a.issues.length;
34
- }
35
- return a.fileName.localeCompare(b.fileName);
36
- });
37
- }
38
- async function analyzeUnified(options) {
39
- const startTime = Date.now();
40
- const tools = options.tools || ["patterns", "context", "consistency"];
41
- const result = {
42
- summary: {
43
- totalIssues: 0,
44
- toolsRun: tools,
45
- executionTime: 0
46
- }
47
- };
48
- if (tools.includes("patterns")) {
49
- const patternResult = await analyzePatterns(options);
50
- if (options.progressCallback) {
51
- options.progressCallback({ tool: "patterns", data: patternResult });
52
- }
53
- result.patterns = sortBySeverity(patternResult.results);
54
- result.duplicates = patternResult.duplicates;
55
- result.summary.totalIssues += patternResult.results.reduce(
56
- (sum, file) => sum + file.issues.length,
57
- 0
58
- );
59
- }
60
- if (tools.includes("context")) {
61
- const contextResults = await analyzeContext(options);
62
- if (options.progressCallback) {
63
- options.progressCallback({ tool: "context", data: contextResults });
64
- }
65
- result.context = contextResults.sort((a, b) => {
66
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
67
- if (severityDiff !== 0) return severityDiff;
68
- if (a.tokenCost !== b.tokenCost) return b.tokenCost - a.tokenCost;
69
- return b.fragmentationScore - a.fragmentationScore;
70
- });
71
- result.summary.totalIssues += result.context?.length || 0;
72
- }
73
- if (tools.includes("consistency")) {
74
- const consistencyOptions = {
75
- rootDir: options.rootDir,
76
- include: options.include,
77
- exclude: options.exclude,
78
- ...options.consistency || {}
79
- };
80
- const report = await analyzeConsistency(consistencyOptions);
81
- if (options.progressCallback) {
82
- options.progressCallback({ tool: "consistency", data: report });
83
- }
84
- if (report.results) {
85
- report.results = sortBySeverity(report.results);
86
- }
87
- result.consistency = report;
88
- result.summary.totalIssues += report.summary.totalIssues;
89
- }
90
- result.summary.executionTime = Date.now() - startTime;
91
- return result;
92
- }
93
- function generateUnifiedSummary(result) {
94
- const { summary } = result;
95
- let output = `\u{1F680} AIReady Analysis Complete
96
-
97
- `;
98
- output += `\u{1F4CA} Summary:
99
- `;
100
- output += ` Tools run: ${summary.toolsRun.join(", ")}
101
- `;
102
- output += ` Total issues found: ${summary.totalIssues}
103
- `;
104
- output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
105
-
106
- `;
107
- if (result.patterns) {
108
- output += `\u{1F50D} Pattern Analysis: ${result.patterns.length} issues
109
- `;
110
- }
111
- if (result.context) {
112
- output += `\u{1F9E0} Context Analysis: ${result.context.length} issues
113
- `;
114
- }
115
- if (result.consistency) {
116
- output += `\u{1F3F7}\uFE0F Consistency Analysis: ${result.consistency.summary.totalIssues} issues
117
- `;
118
- }
119
- return output;
120
- }
121
-
122
- export {
123
- __require,
124
- analyzeUnified,
125
- generateUnifiedSummary
126
- };
@@ -1,111 +0,0 @@
1
- // src/index.ts
2
- import { analyzePatterns } from "@aiready/pattern-detect";
3
- import { analyzeContext } from "@aiready/context-analyzer";
4
- import { analyzeConsistency } from "@aiready/consistency";
5
- var severityOrder = {
6
- critical: 4,
7
- major: 3,
8
- minor: 2,
9
- info: 1
10
- };
11
- function sortBySeverity(results) {
12
- return results.map((file) => {
13
- const sortedIssues = [...file.issues].sort((a, b) => {
14
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
15
- if (severityDiff !== 0) return severityDiff;
16
- return (a.location?.line || 0) - (b.location?.line || 0);
17
- });
18
- return { ...file, issues: sortedIssues };
19
- }).sort((a, b) => {
20
- const aMaxSeverity = Math.max(...a.issues.map((i) => severityOrder[i.severity] || 0), 0);
21
- const bMaxSeverity = Math.max(...b.issues.map((i) => severityOrder[i.severity] || 0), 0);
22
- if (aMaxSeverity !== bMaxSeverity) {
23
- return bMaxSeverity - aMaxSeverity;
24
- }
25
- if (a.issues.length !== b.issues.length) {
26
- return b.issues.length - a.issues.length;
27
- }
28
- return a.fileName.localeCompare(b.fileName);
29
- });
30
- }
31
- async function analyzeUnified(options) {
32
- const startTime = Date.now();
33
- const tools = options.tools || ["patterns", "context", "consistency"];
34
- const result = {
35
- summary: {
36
- totalIssues: 0,
37
- toolsRun: tools,
38
- executionTime: 0
39
- }
40
- };
41
- if (tools.includes("patterns")) {
42
- const patternResult = await analyzePatterns(options);
43
- result.patterns = sortBySeverity(patternResult.results);
44
- result.duplicates = patternResult.duplicates;
45
- result.summary.totalIssues += patternResult.results.reduce(
46
- (sum, file) => sum + file.issues.length,
47
- 0
48
- );
49
- }
50
- if (tools.includes("context")) {
51
- const contextResults = await analyzeContext(options);
52
- result.context = contextResults.sort((a, b) => {
53
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
54
- if (severityDiff !== 0) return severityDiff;
55
- if (a.tokenCost !== b.tokenCost) return b.tokenCost - a.tokenCost;
56
- return b.fragmentationScore - a.fragmentationScore;
57
- });
58
- result.summary.totalIssues += result.context?.length || 0;
59
- }
60
- if (tools.includes("consistency")) {
61
- const consistencyOptions = {
62
- rootDir: options.rootDir,
63
- include: options.include,
64
- exclude: options.exclude,
65
- ...options.consistency || {}
66
- };
67
- console.log("[DEBUG] Running consistency analysis with options:", consistencyOptions);
68
- const report = await analyzeConsistency(consistencyOptions);
69
- console.log("[DEBUG] Consistency report:", JSON.stringify(report, null, 2));
70
- if (report.results) {
71
- report.results = sortBySeverity(report.results);
72
- }
73
- result.consistency = report;
74
- result.summary.totalIssues += report.summary.totalIssues;
75
- }
76
- result.summary.executionTime = Date.now() - startTime;
77
- return result;
78
- }
79
- function generateUnifiedSummary(result) {
80
- const { summary } = result;
81
- let output = `\u{1F680} AIReady Analysis Complete
82
-
83
- `;
84
- output += `\u{1F4CA} Summary:
85
- `;
86
- output += ` Tools run: ${summary.toolsRun.join(", ")}
87
- `;
88
- output += ` Total issues found: ${summary.totalIssues}
89
- `;
90
- output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
91
-
92
- `;
93
- if (result.patterns) {
94
- output += `\u{1F50D} Pattern Analysis: ${result.patterns.length} issues
95
- `;
96
- }
97
- if (result.context) {
98
- output += `\u{1F9E0} Context Analysis: ${result.context.length} issues
99
- `;
100
- }
101
- if (result.consistency) {
102
- output += `\u{1F3F7}\uFE0F Consistency Analysis: ${result.consistency.summary.totalIssues} issues
103
- `;
104
- }
105
- return output;
106
- }
107
-
108
- export {
109
- analyzeUnified,
110
- generateUnifiedSummary
111
- };
@@ -1,126 +0,0 @@
1
- // src/index.ts
2
- import { analyzePatterns } from "@aiready/pattern-detect";
3
- import { analyzeContext } from "@aiready/context-analyzer";
4
- import { analyzeConsistency } from "@aiready/consistency";
5
- var severityOrder = {
6
- critical: 4,
7
- major: 3,
8
- minor: 2,
9
- info: 1
10
- };
11
- function sortBySeverity(results) {
12
- return results.map((file) => {
13
- const sortedIssues = [...file.issues].sort((a, b) => {
14
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
15
- if (severityDiff !== 0) return severityDiff;
16
- return (a.location?.line || 0) - (b.location?.line || 0);
17
- });
18
- return { ...file, issues: sortedIssues };
19
- }).sort((a, b) => {
20
- const aMaxSeverity = Math.max(...a.issues.map((i) => severityOrder[i.severity] || 0), 0);
21
- const bMaxSeverity = Math.max(...b.issues.map((i) => severityOrder[i.severity] || 0), 0);
22
- if (aMaxSeverity !== bMaxSeverity) {
23
- return bMaxSeverity - aMaxSeverity;
24
- }
25
- if (a.issues.length !== b.issues.length) {
26
- return b.issues.length - a.issues.length;
27
- }
28
- return a.fileName.localeCompare(b.fileName);
29
- });
30
- }
31
- async function analyzeUnified(options) {
32
- const startTime = Date.now();
33
- const tools = options.tools || ["patterns", "context", "consistency"];
34
- const result = {
35
- summary: {
36
- totalIssues: 0,
37
- toolsRun: tools,
38
- executionTime: 0
39
- }
40
- };
41
- if (tools.includes("patterns")) {
42
- const patternResult = await analyzePatterns(options);
43
- if (options.progressCallback) {
44
- options.progressCallback({ tool: "patterns", data: patternResult });
45
- }
46
- result.patterns = sortBySeverity(patternResult.results);
47
- result.duplicates = patternResult.duplicates;
48
- result.summary.totalIssues += patternResult.results.reduce(
49
- (sum, file) => sum + file.issues.length,
50
- 0
51
- );
52
- }
53
- if (tools.includes("context")) {
54
- const contextResults = await analyzeContext(options);
55
- if (options.progressCallback) {
56
- options.progressCallback({ tool: "context", data: contextResults });
57
- }
58
- result.context = contextResults.sort((a, b) => {
59
- const severityDiff = (severityOrder[b.severity] || 0) - (severityOrder[a.severity] || 0);
60
- if (severityDiff !== 0) return severityDiff;
61
- if (a.tokenCost !== b.tokenCost) return b.tokenCost - a.tokenCost;
62
- return b.fragmentationScore - a.fragmentationScore;
63
- });
64
- result.summary.totalIssues += result.context?.length || 0;
65
- }
66
- if (tools.includes("consistency")) {
67
- const consistencyOptions = {
68
- rootDir: options.rootDir,
69
- include: options.include,
70
- exclude: options.exclude,
71
- ...options.consistency || {}
72
- };
73
- const report = await analyzeConsistency(consistencyOptions);
74
- if (options.progressCallback) {
75
- options.progressCallback({ tool: "consistency", data: report });
76
- }
77
- if (report.results) {
78
- report.results = sortBySeverity(report.results);
79
- }
80
- result.consistency = report;
81
- result.summary.totalIssues += report.summary.totalIssues;
82
- }
83
- result.summary.executionTime = Date.now() - startTime;
84
- return result;
85
- }
86
- function generateUnifiedSummary(result) {
87
- const { summary } = result;
88
- let output = `\u{1F680} AIReady Analysis Complete
89
-
90
- `;
91
- output += `\u{1F4CA} Summary:
92
- `;
93
- output += ` Tools run: ${summary.toolsRun.join(", ")}
94
- `;
95
- output += ` Total issues found: ${summary.totalIssues}
96
- `;
97
- output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
98
-
99
- `;
100
- if (result.patterns) {
101
- output += `\u{1F50D} Pattern Analysis: ${result.patterns.length} issues
102
- `;
103
- }
104
- if (result.context) {
105
- output += `\u{1F9E0} Context Analysis: ${result.context.length} issues
106
- `;
107
- }
108
- if (result.consistency) {
109
- output += `\u{1F3F7}\uFE0F Consistency Analysis: ${result.consistency.summary.totalIssues} issues
110
- `;
111
- }
112
- if (result.docDrift) {
113
- output += `\u{1F4DD} Doc Drift Analysis: ${result.docDrift.issues?.length || 0} issues
114
- `;
115
- }
116
- if (result.deps) {
117
- output += `\u{1F4E6} Dependency Health: ${result.deps.issues?.length || 0} issues
118
- `;
119
- }
120
- return output;
121
- }
122
-
123
- export {
124
- analyzeUnified,
125
- generateUnifiedSummary
126
- };