@aiready/core 0.23.19 → 0.23.21

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 (96) hide show
  1. package/dist/chunk-2N7ISIKE.mjs +158 -0
  2. package/dist/chunk-ARUIZO7M.mjs +297 -0
  3. package/dist/chunk-CYC5EGEI.mjs +297 -0
  4. package/dist/{chunk-ZB3EHHAG.mjs → chunk-DBOPSRBC.mjs} +88 -26
  5. package/dist/chunk-EZ7ECLAZ.mjs +299 -0
  6. package/dist/chunk-FNPULWG7.mjs +248 -0
  7. package/dist/chunk-FZTFKZUQ.mjs +250 -0
  8. package/dist/chunk-GTS642BQ.mjs +262 -0
  9. package/dist/chunk-IXPY5J4K.mjs +248 -0
  10. package/dist/chunk-JJQLYW6Z.mjs +111 -0
  11. package/dist/chunk-L6BKANJC.mjs +130 -0
  12. package/dist/chunk-LXEO5PG3.mjs +292 -0
  13. package/dist/chunk-LZHO636W.mjs +501 -0
  14. package/dist/chunk-MTK2IIDZ.mjs +262 -0
  15. package/dist/chunk-QDCQETSI.mjs +262 -0
  16. package/dist/chunk-QZNY7B2N.mjs +248 -0
  17. package/dist/chunk-RCZSMGCX.mjs +250 -0
  18. package/dist/chunk-SWZOT67M.mjs +250 -0
  19. package/dist/chunk-U3IY2CFC.mjs +36 -0
  20. package/dist/chunk-UBCM5Y6R.mjs +275 -0
  21. package/dist/chunk-UTCRW3N7.mjs +301 -0
  22. package/dist/{chunk-RMH2TPAT.mjs → chunk-UYLH35LA.mjs} +88 -26
  23. package/dist/{chunk-TJXR2CHZ.mjs → chunk-WVNVC2PP.mjs} +266 -213
  24. package/dist/chunk-WYOW6O3P.mjs +114 -0
  25. package/dist/{chunk-CGOS2J6T.mjs → chunk-YRSSR4KN.mjs} +260 -217
  26. package/dist/client-2xbeKnrg.d.mts +1291 -0
  27. package/dist/client-2xbeKnrg.d.ts +1291 -0
  28. package/dist/client-4HLAGzFg.d.mts +1291 -0
  29. package/dist/client-4HLAGzFg.d.ts +1291 -0
  30. package/dist/client-B4TQwNa7.d.mts +1290 -0
  31. package/dist/client-B4TQwNa7.d.ts +1290 -0
  32. package/dist/client-Bdi4ty0v.d.mts +1294 -0
  33. package/dist/client-Bdi4ty0v.d.ts +1294 -0
  34. package/dist/client-BsKpUH3H.d.mts +1339 -0
  35. package/dist/client-BsKpUH3H.d.ts +1339 -0
  36. package/dist/client-Bv1zOaWF.d.mts +1291 -0
  37. package/dist/client-Bv1zOaWF.d.ts +1291 -0
  38. package/dist/client-Bz9YJMIX.d.mts +1290 -0
  39. package/dist/client-Bz9YJMIX.d.ts +1290 -0
  40. package/dist/client-CBpzm34X.d.mts +1291 -0
  41. package/dist/client-CBpzm34X.d.ts +1291 -0
  42. package/dist/client-CNu_tCZZ.d.mts +1305 -0
  43. package/dist/client-CNu_tCZZ.d.ts +1305 -0
  44. package/dist/client-CmEvxxQu.d.mts +1339 -0
  45. package/dist/client-CmEvxxQu.d.ts +1339 -0
  46. package/dist/client-DGMAxkZc.d.mts +1339 -0
  47. package/dist/client-DGMAxkZc.d.ts +1339 -0
  48. package/dist/client-DZq-CqcD.d.mts +1292 -0
  49. package/dist/client-DZq-CqcD.d.ts +1292 -0
  50. package/dist/{client-WVCAIWdJ.d.mts → client-DcqGfDTt.d.mts} +318 -226
  51. package/dist/{client-WVCAIWdJ.d.ts → client-DcqGfDTt.d.ts} +318 -226
  52. package/dist/{client-DLvFR2qA.d.mts → client-O8RvSRm0.d.mts} +89 -25
  53. package/dist/{client-DLvFR2qA.d.ts → client-O8RvSRm0.d.ts} +89 -25
  54. package/dist/client.d.mts +1 -1
  55. package/dist/client.d.ts +1 -1
  56. package/dist/client.js +53 -27
  57. package/dist/client.mjs +6 -6
  58. package/dist/csharp-parser-4ZKCSX5B.mjs +9 -0
  59. package/dist/csharp-parser-5HKICCRR.mjs +9 -0
  60. package/dist/csharp-parser-JCKXIAJW.mjs +9 -0
  61. package/dist/go-parser-J4KIH4RG.mjs +9 -0
  62. package/dist/go-parser-TKXL3DVH.mjs +9 -0
  63. package/dist/go-parser-XOM232XZ.mjs +9 -0
  64. package/dist/index.d.mts +332 -54
  65. package/dist/index.d.ts +332 -54
  66. package/dist/index.js +3930 -3064
  67. package/dist/index.mjs +933 -2036
  68. package/dist/java-parser-3KHXOXRQ.mjs +9 -0
  69. package/dist/java-parser-MASGS4WB.mjs +9 -0
  70. package/dist/java-parser-T5LXD63J.mjs +9 -0
  71. package/dist/python-parser-FNFK2473.mjs +8 -0
  72. package/dist/typescript-parser-2GGNRNB5.mjs +7 -0
  73. package/dist/typescript-parser-3ENJ6C7H.mjs +7 -0
  74. package/dist/typescript-parser-4GI7DPSW.mjs +7 -0
  75. package/dist/typescript-parser-4H3HUBO4.mjs +7 -0
  76. package/dist/typescript-parser-K63IVZMF.mjs +7 -0
  77. package/dist/typescript-parser-ZJKROMQG.mjs +7 -0
  78. package/package.json +1 -1
  79. package/dist/chunk-5SHLHMH7.mjs +0 -760
  80. package/dist/chunk-Q55AMEFV.mjs +0 -760
  81. package/dist/client-BEoUYNLp.d.mts +0 -1191
  82. package/dist/client-BEoUYNLp.d.ts +0 -1191
  83. package/dist/client-BrIMPk89.d.mts +0 -1214
  84. package/dist/client-BrIMPk89.d.ts +0 -1214
  85. package/dist/client-C5BuGX4F.d.mts +0 -1205
  86. package/dist/client-C5BuGX4F.d.ts +0 -1205
  87. package/dist/client-CKcjnPXt.d.mts +0 -1214
  88. package/dist/client-CKcjnPXt.d.ts +0 -1214
  89. package/dist/client-CLulBnie.d.mts +0 -1182
  90. package/dist/client-CLulBnie.d.ts +0 -1182
  91. package/dist/client-CQwvp8ep.d.mts +0 -1182
  92. package/dist/client-CQwvp8ep.d.ts +0 -1182
  93. package/dist/client-PFPdeo-z.d.mts +0 -1186
  94. package/dist/client-PFPdeo-z.d.ts +0 -1186
  95. package/dist/client-wk2fgk1q.d.mts +0 -1184
  96. package/dist/client-wk2fgk1q.d.ts +0 -1184
@@ -0,0 +1,158 @@
1
+ // src/parsers/tree-sitter-utils.ts
2
+ import * as Parser from "web-tree-sitter";
3
+ import * as path from "path";
4
+ import * as fs from "fs";
5
+ import { fileURLToPath } from "url";
6
+ var getDirname = () => {
7
+ try {
8
+ if (typeof __dirname !== "undefined") return __dirname;
9
+ return path.dirname(fileURLToPath(import.meta.url));
10
+ } catch {
11
+ return process.cwd();
12
+ }
13
+ };
14
+ var __dirname = getDirname();
15
+ var isTreeSitterInitialized = false;
16
+ async function initTreeSitter() {
17
+ if (isTreeSitterInitialized) return;
18
+ try {
19
+ const wasmPath = getWasmPath("web-tree-sitter");
20
+ await Parser.Parser.init({
21
+ locateFile() {
22
+ return wasmPath || "web-tree-sitter.wasm";
23
+ }
24
+ });
25
+ isTreeSitterInitialized = true;
26
+ } catch (error) {
27
+ console.error("Failed to initialize web-tree-sitter:", error);
28
+ isTreeSitterInitialized = true;
29
+ }
30
+ }
31
+ function findInPnpmStore(startDir, fileName, depth = 0) {
32
+ if (depth > 8) return null;
33
+ const pnpmDir = path.join(startDir, "node_modules", ".pnpm");
34
+ if (fs.existsSync(pnpmDir)) {
35
+ return findFileRecursively(pnpmDir, fileName, 0);
36
+ }
37
+ const parent = path.dirname(startDir);
38
+ if (parent === startDir) return null;
39
+ return findInPnpmStore(parent, fileName, depth + 1);
40
+ }
41
+ function findFileRecursively(dir, fileName, depth) {
42
+ if (depth > 6) return null;
43
+ try {
44
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
45
+ for (const entry of entries) {
46
+ if (entry.isFile() && entry.name === fileName) {
47
+ return path.join(dir, entry.name);
48
+ }
49
+ }
50
+ for (const entry of entries) {
51
+ if (entry.isDirectory()) {
52
+ const found = findFileRecursively(
53
+ path.join(dir, entry.name),
54
+ fileName,
55
+ depth + 1
56
+ );
57
+ if (found) return found;
58
+ }
59
+ }
60
+ } catch {
61
+ }
62
+ return null;
63
+ }
64
+ function getWasmPath(language) {
65
+ const wasmFileName = language === "web-tree-sitter" ? "web-tree-sitter.wasm" : `tree-sitter-${language}.wasm`;
66
+ const immediatePaths = [
67
+ path.join(process.cwd(), wasmFileName),
68
+ path.join(__dirname, wasmFileName),
69
+ path.join(__dirname, "assets", wasmFileName)
70
+ ];
71
+ for (const p of immediatePaths) {
72
+ if (fs.existsSync(p)) return p;
73
+ }
74
+ const pnpmPath = findInPnpmStore(__dirname, wasmFileName);
75
+ if (pnpmPath) return pnpmPath;
76
+ const pnpmPathCwd = findInPnpmStore(process.cwd(), wasmFileName);
77
+ if (pnpmPathCwd) return pnpmPathCwd;
78
+ console.warn(
79
+ `[Parser] WASM file for ${language} not found. CWD: ${process.cwd()}, DIR: ${__dirname}`
80
+ );
81
+ return null;
82
+ }
83
+ async function setupParser(language) {
84
+ await initTreeSitter();
85
+ const wasmPath = getWasmPath(language);
86
+ if (!wasmPath) {
87
+ return null;
88
+ }
89
+ try {
90
+ const parser = new Parser.Parser();
91
+ const Lang = await Parser.Language.load(wasmPath);
92
+ parser.setLanguage(Lang);
93
+ return parser;
94
+ } catch {
95
+ return null;
96
+ }
97
+ }
98
+
99
+ // src/parsers/base-parser.ts
100
+ var BaseLanguageParser = class {
101
+ constructor() {
102
+ this.parser = null;
103
+ this.initialized = false;
104
+ }
105
+ /**
106
+ * Initialize the tree-sitter parser
107
+ */
108
+ async initialize() {
109
+ if (this.initialized) return;
110
+ try {
111
+ this.parser = await setupParser(this.getParserName());
112
+ this.initialized = true;
113
+ } catch (error) {
114
+ console.warn(`Failed to initialize ${this.language} parser:`, error);
115
+ }
116
+ }
117
+ async getAST(code, _filePath) {
118
+ void _filePath;
119
+ if (!this.initialized) await this.initialize();
120
+ if (!this.parser) return null;
121
+ return this.parser.parse(code);
122
+ }
123
+ parse(code, filePath) {
124
+ if (!this.initialized || !this.parser) {
125
+ return this.parseRegex(code, filePath);
126
+ }
127
+ try {
128
+ const tree = this.parser.parse(code);
129
+ if (!tree || tree.rootNode.type === "ERROR" || tree.rootNode.hasError) {
130
+ return this.parseRegex(code, filePath);
131
+ }
132
+ const imports = this.extractImportsAST(tree.rootNode);
133
+ const exports = this.extractExportsAST(tree.rootNode, code);
134
+ return {
135
+ exports,
136
+ imports,
137
+ language: this.language,
138
+ warnings: []
139
+ };
140
+ } catch (error) {
141
+ console.warn(
142
+ `AST parsing failed for ${filePath}, falling back to regex: ${error.message}`
143
+ );
144
+ return this.parseRegex(code, filePath);
145
+ }
146
+ }
147
+ canHandle(filePath) {
148
+ const lowerPath = filePath.toLowerCase();
149
+ return this.extensions.some((ext) => lowerPath.endsWith(ext));
150
+ }
151
+ };
152
+
153
+ export {
154
+ initTreeSitter,
155
+ getWasmPath,
156
+ setupParser,
157
+ BaseLanguageParser
158
+ };
@@ -0,0 +1,297 @@
1
+ import {
2
+ ParseError
3
+ } from "./chunk-U3IY2CFC.mjs";
4
+
5
+ // src/parsers/typescript-parser.ts
6
+ import { parse } from "@typescript-eslint/typescript-estree";
7
+ var TypeScriptParser = class {
8
+ constructor() {
9
+ this.language = "typescript" /* TypeScript */;
10
+ this.extensions = [".ts", ".tsx", ".js", ".jsx"];
11
+ }
12
+ async initialize() {
13
+ }
14
+ canHandle(filePath) {
15
+ return this.extensions.some((ext) => filePath.endsWith(ext));
16
+ }
17
+ async getAST(code, filePath) {
18
+ try {
19
+ return parse(code, {
20
+ filePath,
21
+ loc: true,
22
+ range: true,
23
+ tokens: true,
24
+ comment: true,
25
+ jsx: filePath.endsWith("x")
26
+ });
27
+ } catch (error) {
28
+ throw new ParseError(error.message, filePath, {
29
+ line: error.lineNumber || 1,
30
+ column: error.column || 0
31
+ });
32
+ }
33
+ }
34
+ parse(code, filePath) {
35
+ try {
36
+ const ast = parse(code, {
37
+ filePath,
38
+ loc: true,
39
+ range: true,
40
+ tokens: true,
41
+ comment: true,
42
+ jsx: filePath.endsWith("x")
43
+ });
44
+ const imports = this.extractImports(ast);
45
+ const exports = this.extractExports(ast, code, filePath);
46
+ return {
47
+ exports,
48
+ imports,
49
+ language: this.language
50
+ };
51
+ } catch (error) {
52
+ throw new ParseError(error.message, filePath, {
53
+ line: error.lineNumber || 1,
54
+ column: error.column || 0
55
+ });
56
+ }
57
+ }
58
+ getNamingConventions() {
59
+ return {
60
+ variablePattern: /^[a-z][a-zA-Z0-9]*$/,
61
+ functionPattern: /^[a-z][a-zA-Z0-9]*$/,
62
+ classPattern: /^[A-Z][a-zA-Z0-9]*$/,
63
+ constantPattern: /^[A-Z][A-Z0-9_]*$/,
64
+ typePattern: /^[A-Z][a-zA-Z0-9]*$/,
65
+ interfacePattern: /^I?[A-Z][a-zA-Z0-9]*$/
66
+ };
67
+ }
68
+ analyzeMetadata(node, code) {
69
+ if (!code) return {};
70
+ return {
71
+ isPure: this.isLikelyPure(node),
72
+ hasSideEffects: !this.isLikelyPure(node)
73
+ };
74
+ }
75
+ extractImports(ast) {
76
+ const imports = [];
77
+ for (const node of ast.body) {
78
+ if (node.type === "ImportDeclaration") {
79
+ const specifiers = [];
80
+ let isTypeOnly = false;
81
+ if (node.importKind === "type") {
82
+ isTypeOnly = true;
83
+ }
84
+ for (const spec of node.specifiers) {
85
+ if (spec.type === "ImportSpecifier") {
86
+ const imported = spec.imported;
87
+ const name = imported.type === "Identifier" ? imported.name : imported.value;
88
+ specifiers.push(name);
89
+ } else if (spec.type === "ImportDefaultSpecifier") {
90
+ specifiers.push("default");
91
+ } else if (spec.type === "ImportNamespaceSpecifier") {
92
+ specifiers.push("*");
93
+ }
94
+ }
95
+ imports.push({
96
+ source: node.source.value,
97
+ specifiers,
98
+ isTypeOnly,
99
+ loc: node.loc ? {
100
+ start: {
101
+ line: node.loc.start.line,
102
+ column: node.loc.start.column
103
+ },
104
+ end: { line: node.loc.end.line, column: node.loc.end.column }
105
+ } : void 0
106
+ });
107
+ }
108
+ }
109
+ return imports;
110
+ }
111
+ extractExports(ast, code, filePath) {
112
+ const exports = [];
113
+ for (const node of ast.body) {
114
+ if (node.type === "ExportNamedDeclaration") {
115
+ if (node.declaration) {
116
+ const declaration = node.declaration;
117
+ if ((declaration.type === "FunctionDeclaration" || declaration.type === "TSDeclareFunction") && declaration.id) {
118
+ exports.push(
119
+ this.createExport(
120
+ declaration.id.name,
121
+ "function",
122
+ node,
123
+ // Pass the outer ExportNamedDeclaration
124
+ code,
125
+ filePath
126
+ )
127
+ );
128
+ } else if (declaration.type === "ClassDeclaration" && declaration.id) {
129
+ exports.push(
130
+ this.createExport(
131
+ declaration.id.name,
132
+ "class",
133
+ node,
134
+ // Pass the outer ExportNamedDeclaration
135
+ code,
136
+ filePath
137
+ )
138
+ );
139
+ } else if (declaration.type === "TSTypeAliasDeclaration") {
140
+ exports.push(
141
+ this.createExport(
142
+ declaration.id.name,
143
+ "type",
144
+ node,
145
+ // Pass the outer ExportNamedDeclaration
146
+ code,
147
+ filePath
148
+ )
149
+ );
150
+ } else if (declaration.type === "TSInterfaceDeclaration") {
151
+ exports.push(
152
+ this.createExport(
153
+ declaration.id.name,
154
+ "interface",
155
+ node,
156
+ // Pass the outer ExportNamedDeclaration
157
+ code,
158
+ filePath
159
+ )
160
+ );
161
+ } else if (declaration.type === "VariableDeclaration") {
162
+ for (const decl of declaration.declarations) {
163
+ if (decl.id.type === "Identifier") {
164
+ exports.push(
165
+ this.createExport(
166
+ decl.id.name,
167
+ "const",
168
+ node,
169
+ // Pass the outer ExportNamedDeclaration
170
+ code,
171
+ filePath,
172
+ decl.init
173
+ )
174
+ );
175
+ }
176
+ }
177
+ }
178
+ }
179
+ } else if (node.type === "ExportDefaultDeclaration") {
180
+ exports.push(this.createExport("default", "default", node, code, filePath));
181
+ }
182
+ }
183
+ return exports;
184
+ }
185
+ createExport(name, type, node, code, filePath, initializer) {
186
+ const documentation = this.extractDocumentation(node, code);
187
+ let methodCount;
188
+ let propertyCount;
189
+ let parameters;
190
+ let isPrimitive = false;
191
+ let isTyped = false;
192
+ if (initializer) {
193
+ if (initializer.type === "Literal" || initializer.type === "TemplateLiteral" && initializer.expressions.length === 0) {
194
+ isPrimitive = true;
195
+ }
196
+ }
197
+ const structNode = node.type === "ExportNamedDeclaration" ? node.declaration : node.type === "ExportDefaultDeclaration" ? node.declaration : node;
198
+ if (filePath.endsWith(".ts") || filePath.endsWith(".tsx")) {
199
+ if (structNode.type === "TSTypeAliasDeclaration" || structNode.type === "TSInterfaceDeclaration" || structNode.type === "TSEnumDeclaration") {
200
+ isTyped = true;
201
+ } else if (structNode.type === "FunctionDeclaration" || structNode.type === "TSDeclareFunction") {
202
+ const hasReturnType = !!structNode.returnType;
203
+ const allParamsTyped = structNode.params.length === 0 || structNode.params.every((p) => !!p.typeAnnotation);
204
+ isTyped = hasReturnType && allParamsTyped;
205
+ } else if (structNode.type === "VariableDeclaration") {
206
+ isTyped = structNode.declarations.every(
207
+ (d) => !!d.id.typeAnnotation || !!d.init
208
+ );
209
+ } else if (structNode.type === "ClassDeclaration") {
210
+ isTyped = true;
211
+ }
212
+ }
213
+ if (structNode.type === "ClassDeclaration" || structNode.type === "TSInterfaceDeclaration") {
214
+ const body = structNode.type === "ClassDeclaration" ? structNode.body.body : structNode.body.body;
215
+ methodCount = body.filter(
216
+ (m) => m.type === "MethodDefinition" || m.type === "TSMethodSignature"
217
+ ).length;
218
+ propertyCount = body.filter(
219
+ (m) => m.type === "PropertyDefinition" || m.type === "TSPropertySignature"
220
+ ).length;
221
+ if (structNode.type === "ClassDeclaration") {
222
+ const constructor = body.find(
223
+ (m) => m.type === "MethodDefinition" && m.kind === "constructor"
224
+ );
225
+ if (constructor && constructor.value && constructor.value.params) {
226
+ parameters = constructor.value.params.map((p) => {
227
+ if (p.type === "Identifier") return p.name;
228
+ if (p.type === "TSParameterProperty" && p.parameter.type === "Identifier") {
229
+ return p.parameter.name;
230
+ }
231
+ return void 0;
232
+ }).filter(Boolean);
233
+ }
234
+ }
235
+ }
236
+ if (!parameters && (structNode.type === "FunctionDeclaration" || structNode.type === "TSDeclareFunction" || structNode.type === "MethodDefinition")) {
237
+ const funcNode = structNode.type === "MethodDefinition" ? structNode.value : structNode;
238
+ if (funcNode && funcNode.params) {
239
+ parameters = funcNode.params.map((p) => {
240
+ if (p.type === "Identifier") return p.name;
241
+ return void 0;
242
+ }).filter(Boolean);
243
+ }
244
+ }
245
+ return {
246
+ name,
247
+ type,
248
+ isPrimitive,
249
+ loc: node.loc ? {
250
+ start: { line: node.loc.start.line, column: node.loc.start.column },
251
+ end: { line: node.loc.end.line, column: node.loc.end.column }
252
+ } : void 0,
253
+ documentation,
254
+ methodCount,
255
+ propertyCount,
256
+ parameters,
257
+ isPure: this.isLikelyPure(node),
258
+ hasSideEffects: !this.isLikelyPure(node),
259
+ isTyped
260
+ };
261
+ }
262
+ extractDocumentation(node, code) {
263
+ if (node.range) {
264
+ const start = node.range[0];
265
+ const precedingCode = code.substring(0, start);
266
+ const jsdocMatch = precedingCode.match(/\/\*\*([\s\S]*?)\*\/\s*$/);
267
+ if (jsdocMatch) {
268
+ return {
269
+ content: jsdocMatch[1].trim(),
270
+ type: "jsdoc"
271
+ };
272
+ }
273
+ }
274
+ return void 0;
275
+ }
276
+ isLikelyPure(node) {
277
+ const structNode = node.type === "ExportNamedDeclaration" ? node.declaration : node.type === "ExportDefaultDeclaration" ? node.declaration : node;
278
+ if (structNode.type === "VariableDeclaration" && structNode.kind === "const")
279
+ return true;
280
+ if (structNode.type === "FunctionDeclaration" || structNode.type === "TSDeclareFunction" || structNode.type === "MethodDefinition" && structNode.value) {
281
+ const body = structNode.type === "MethodDefinition" ? structNode.value.body : structNode.body;
282
+ if (body && body.type === "BlockStatement") {
283
+ const bodyContent = JSON.stringify(body);
284
+ if (bodyContent.includes('"name":"console"') || bodyContent.includes('"name":"process"') || bodyContent.includes('"type":"AssignmentExpression"')) {
285
+ return false;
286
+ }
287
+ return true;
288
+ }
289
+ return true;
290
+ }
291
+ return false;
292
+ }
293
+ };
294
+
295
+ export {
296
+ TypeScriptParser
297
+ };