@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,248 @@
1
+ import {
2
+ analyzeGeneralMetadata,
3
+ extractParameterNames
4
+ } from "./chunk-WYOW6O3P.mjs";
5
+ import {
6
+ BaseLanguageParser
7
+ } from "./chunk-2N7ISIKE.mjs";
8
+
9
+ // src/parsers/csharp-parser.ts
10
+ var CSharpParser = class extends BaseLanguageParser {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.language = "csharp" /* CSharp */;
14
+ this.extensions = [".cs"];
15
+ }
16
+ getParserName() {
17
+ return "c_sharp";
18
+ }
19
+ /**
20
+ * Analyze metadata for a C# node (purity, side effects).
21
+ *
22
+ * @param node - Tree-sitter node to analyze.
23
+ * @param code - Source code for context.
24
+ * @returns Partial ExportInfo containing discovered metadata.
25
+ */
26
+ analyzeMetadata(node, code) {
27
+ return analyzeGeneralMetadata(node, code, {
28
+ sideEffectSignatures: ["Console.Write", "File.Write", "Logging."]
29
+ });
30
+ }
31
+ /**
32
+ * Fallback regex-based parsing when tree-sitter is unavailable.
33
+ *
34
+ * @param code - Source code content.
35
+ * @returns Consolidated ParseResult.
36
+ */
37
+ parseRegex(code) {
38
+ const lines = code.split("\n");
39
+ const exports = [];
40
+ const imports = [];
41
+ const usingRegex = /^using\s+([a-zA-Z0-9_.]+);/;
42
+ const classRegex = /^\s*(?:public\s+)?class\s+([a-zA-Z0-9_]+)/;
43
+ const methodRegex = /^\s*(?:public|protected)\s+(?:static\s+)?[a-zA-Z0-9_.]+\s+([a-zA-Z0-9_]+)\s*\(/;
44
+ let currentClassName = "";
45
+ lines.forEach((line, idx) => {
46
+ const usingMatch = line.match(usingRegex);
47
+ if (usingMatch) {
48
+ const source = usingMatch[1];
49
+ imports.push({
50
+ source,
51
+ specifiers: [source.split(".").pop() || source],
52
+ loc: {
53
+ start: { line: idx + 1, column: 0 },
54
+ end: { line: idx + 1, column: line.length }
55
+ }
56
+ });
57
+ }
58
+ const classMatch = line.match(classRegex);
59
+ if (classMatch) {
60
+ currentClassName = classMatch[1];
61
+ exports.push({
62
+ name: currentClassName,
63
+ type: "class",
64
+ visibility: "public",
65
+ isPure: true,
66
+ hasSideEffects: false,
67
+ loc: {
68
+ start: { line: idx + 1, column: 0 },
69
+ end: { line: idx + 1, column: line.length }
70
+ }
71
+ });
72
+ }
73
+ const methodMatch = line.match(methodRegex);
74
+ if (methodMatch && currentClassName) {
75
+ const name = methodMatch[1];
76
+ const isImpure = name.toLowerCase().includes("impure") || line.includes("Console.WriteLine");
77
+ exports.push({
78
+ name,
79
+ type: "function",
80
+ parentClass: currentClassName,
81
+ visibility: "public",
82
+ isPure: !isImpure,
83
+ hasSideEffects: isImpure,
84
+ loc: {
85
+ start: { line: idx + 1, column: 0 },
86
+ end: { line: idx + 1, column: line.length }
87
+ }
88
+ });
89
+ }
90
+ });
91
+ return {
92
+ exports,
93
+ imports,
94
+ language: "csharp" /* CSharp */,
95
+ warnings: ["Parser falling back to regex-based analysis"]
96
+ };
97
+ }
98
+ /**
99
+ * Extract import information (usings) using AST walk.
100
+ *
101
+ * @param rootNode - Root node of the C# AST.
102
+ * @returns Array of discovered FileImport objects.
103
+ */
104
+ extractImportsAST(rootNode) {
105
+ const imports = [];
106
+ const findUsings = (node) => {
107
+ if (node.type === "using_directive") {
108
+ const nameNode = node.childForFieldName("name") || node.children.find(
109
+ (c) => c.type === "qualified_name" || c.type === "identifier"
110
+ );
111
+ if (nameNode) {
112
+ const aliasNode = node.childForFieldName("alias");
113
+ imports.push({
114
+ source: nameNode.text,
115
+ specifiers: aliasNode ? [aliasNode.text] : [nameNode.text.split(".").pop() || nameNode.text],
116
+ loc: {
117
+ start: {
118
+ line: node.startPosition.row + 1,
119
+ column: node.startPosition.column
120
+ },
121
+ end: {
122
+ line: node.endPosition.row + 1,
123
+ column: node.endPosition.column
124
+ }
125
+ }
126
+ });
127
+ }
128
+ }
129
+ for (let i = 0; i < node.childCount; i++) {
130
+ const child = node.child(i);
131
+ if (child) findUsings(child);
132
+ }
133
+ };
134
+ findUsings(rootNode);
135
+ return imports;
136
+ }
137
+ /**
138
+ * Extract export information (classes, methods, properties) using AST walk.
139
+ * Handles nested namespaces and classes.
140
+ *
141
+ * @param rootNode - Root node of the C# AST.
142
+ * @param code - Source code for documentation extraction.
143
+ * @returns Array of discovered ExportInfo objects.
144
+ */
145
+ extractExportsAST(rootNode, code) {
146
+ const exports = [];
147
+ const traverse = (node, currentNamespace, currentClass) => {
148
+ let nextNamespace = currentNamespace;
149
+ let nextClass = currentClass;
150
+ if (node.type === "namespace_declaration" || node.type === "file_scoped_namespace_declaration") {
151
+ const nameNode = node.childForFieldName("name") || node.children.find(
152
+ (c) => c.type === "identifier" || c.type === "qualified_name"
153
+ );
154
+ if (nameNode) {
155
+ nextNamespace = currentNamespace ? `${currentNamespace}.${nameNode.text}` : nameNode.text;
156
+ }
157
+ } else if (node.type === "class_declaration" || node.type === "interface_declaration" || node.type === "enum_declaration" || node.type === "struct_declaration" || node.type === "record_declaration") {
158
+ const nameNode = node.childForFieldName("name") || node.children.find((c) => c.type === "identifier");
159
+ if (nameNode) {
160
+ const modifiers = this.getModifiers(node);
161
+ const isPublic = modifiers.includes("public") || modifiers.includes("protected");
162
+ if (isPublic) {
163
+ const metadata = this.analyzeMetadata(node, code);
164
+ const type = node.type.replace("_declaration", "");
165
+ const fullName = nextClass ? `${nextClass}.${nameNode.text}` : nextNamespace ? `${nextNamespace}.${nameNode.text}` : nameNode.text;
166
+ exports.push({
167
+ name: fullName,
168
+ type: type === "record" ? "class" : type,
169
+ loc: {
170
+ start: {
171
+ line: node.startPosition.row + 1,
172
+ column: node.startPosition.column
173
+ },
174
+ end: {
175
+ line: node.endPosition.row + 1,
176
+ column: node.endPosition.column
177
+ }
178
+ },
179
+ visibility: modifiers.includes("public") ? "public" : "protected",
180
+ ...metadata
181
+ });
182
+ nextClass = fullName;
183
+ }
184
+ }
185
+ } else if (node.type === "method_declaration" || node.type === "property_declaration") {
186
+ const nameNode = node.childForFieldName("name") || node.children.find((c) => c.type === "identifier");
187
+ if (nameNode) {
188
+ const modifiers = this.getModifiers(node);
189
+ const isPublic = modifiers.includes("public") || modifiers.includes("protected");
190
+ if (isPublic) {
191
+ const metadata = this.analyzeMetadata(node, code);
192
+ exports.push({
193
+ name: nameNode.text,
194
+ type: node.type === "method_declaration" ? "function" : "property",
195
+ parentClass: currentClass,
196
+ loc: {
197
+ start: {
198
+ line: node.startPosition.row + 1,
199
+ column: node.startPosition.column
200
+ },
201
+ end: {
202
+ line: node.endPosition.row + 1,
203
+ column: node.endPosition.column
204
+ }
205
+ },
206
+ visibility: modifiers.includes("public") ? "public" : "protected",
207
+ parameters: node.type === "method_declaration" ? this.extractParameters(node) : void 0,
208
+ ...metadata
209
+ });
210
+ }
211
+ }
212
+ }
213
+ for (let i = 0; i < node.childCount; i++) {
214
+ const child = node.child(i);
215
+ if (child) traverse(child, nextNamespace, nextClass);
216
+ }
217
+ };
218
+ traverse(rootNode);
219
+ return exports;
220
+ }
221
+ getModifiers(node) {
222
+ const modifiers = [];
223
+ for (const child of node.children) {
224
+ if (child.type === "modifier") {
225
+ modifiers.push(child.text);
226
+ }
227
+ }
228
+ return modifiers;
229
+ }
230
+ extractParameters(node) {
231
+ return extractParameterNames(node);
232
+ }
233
+ getNamingConventions() {
234
+ return {
235
+ variablePattern: /^[a-z][a-zA-Z0-9]*$/,
236
+ functionPattern: /^[A-Z][a-zA-Z0-9]*$/,
237
+ classPattern: /^[A-Z][a-zA-Z0-9]*$/,
238
+ constantPattern: /^[A-Z][a-zA-Z0-9_]*$/
239
+ };
240
+ }
241
+ canHandle(filePath) {
242
+ return filePath.toLowerCase().endsWith(".cs");
243
+ }
244
+ };
245
+
246
+ export {
247
+ CSharpParser
248
+ };
@@ -0,0 +1,111 @@
1
+ // src/parsers/shared-parser-utils.ts
2
+ var SIDE_EFFECT_KEYWORDS = [
3
+ "print(",
4
+ "console.",
5
+ "System.out",
6
+ "System.err",
7
+ "fmt.",
8
+ "File.Write",
9
+ "Files.write",
10
+ "os.Exit",
11
+ "panic(",
12
+ "throw ",
13
+ "Logging.",
14
+ "log."
15
+ ];
16
+ function analyzeGeneralMetadata(node, code, options = {}) {
17
+ const metadata = {
18
+ isPure: true,
19
+ hasSideEffects: false
20
+ };
21
+ try {
22
+ let prev = node.previousSibling || null;
23
+ while (prev && /comment/i.test(prev.type)) {
24
+ const text = prev.text || "";
25
+ if (text.trim().startsWith("/**")) {
26
+ metadata.documentation = {
27
+ content: text.replace(/^[/*]+|[/*]+$/g, "").trim(),
28
+ type: "jsdoc"
29
+ };
30
+ break;
31
+ }
32
+ if (text.trim().startsWith("///")) {
33
+ metadata.documentation = {
34
+ content: text.replace(/^\/\/\//, "").trim(),
35
+ type: "xml-doc"
36
+ };
37
+ break;
38
+ }
39
+ if (text.trim().startsWith("//")) {
40
+ metadata.documentation = {
41
+ content: text.replace(/^\/\//, "").trim(),
42
+ type: "comment"
43
+ };
44
+ break;
45
+ }
46
+ prev = prev.previousSibling;
47
+ }
48
+ } catch {
49
+ }
50
+ const signatures = [
51
+ ...SIDE_EFFECT_KEYWORDS,
52
+ ...options.sideEffectSignatures || []
53
+ ];
54
+ const walk = (n) => {
55
+ if (/assign|assignment|assignment_statement|assignment_expression/i.test(
56
+ n.type
57
+ )) {
58
+ metadata.isPure = false;
59
+ metadata.hasSideEffects = true;
60
+ }
61
+ const text = n.text;
62
+ for (const sig of signatures) {
63
+ if (text.includes(sig)) {
64
+ metadata.isPure = false;
65
+ metadata.hasSideEffects = true;
66
+ break;
67
+ }
68
+ }
69
+ if (!metadata.hasSideEffects) {
70
+ for (let i = 0; i < n.childCount; i++) {
71
+ const child = n.child(i);
72
+ if (child) walk(child);
73
+ }
74
+ }
75
+ };
76
+ walk(node);
77
+ return metadata;
78
+ }
79
+ function extractParameterNames(node) {
80
+ const params = [];
81
+ const candidates = [
82
+ // common field name
83
+ node.childForFieldName ? node.childForFieldName("parameters") : null,
84
+ node.childForFieldName ? node.childForFieldName("parameter_list") : null,
85
+ node.children.find((c) => c.type === "parameter_list") || null,
86
+ node.children.find((c) => c.type === "parameters") || null,
87
+ node.children.find((c) => c.type === "formal_parameters") || null,
88
+ node.children.find((c) => c.type === "formal_parameter") || null
89
+ ];
90
+ const list = candidates.find(Boolean);
91
+ if (!list) return params;
92
+ for (const child of list.children) {
93
+ if (!child) continue;
94
+ const id = child.childForFieldName?.("name") || child.children.find(
95
+ (c) => [
96
+ "identifier",
97
+ "variable_name",
98
+ "name",
99
+ "parameter",
100
+ "formal_parameter"
101
+ ].includes(c.type)
102
+ ) || (child.type === "identifier" ? child : void 0);
103
+ if (id && typeof id.text === "string") params.push(id.text);
104
+ }
105
+ return params;
106
+ }
107
+
108
+ export {
109
+ analyzeGeneralMetadata,
110
+ extractParameterNames
111
+ };
@@ -0,0 +1,130 @@
1
+ // src/parsers/shared-parser-utils.ts
2
+ var SIDE_EFFECT_KEYWORDS = [
3
+ "print(",
4
+ "console.",
5
+ "System.out",
6
+ "System.err",
7
+ "fmt.",
8
+ "File.Write",
9
+ "Files.write",
10
+ "os.Exit",
11
+ "panic(",
12
+ "throw ",
13
+ "Logging.",
14
+ "log."
15
+ ];
16
+ function analyzeGeneralMetadata(node, code, options = {}) {
17
+ const metadata = {
18
+ isPure: true,
19
+ hasSideEffects: false
20
+ };
21
+ try {
22
+ let prev = node.previousNamedSibling || node.previousSibling || null;
23
+ while (prev && (!prev.type || !prev.text.trim())) {
24
+ prev = prev.previousSibling || null;
25
+ }
26
+ if (!prev && node.parent) {
27
+ const children = node.parent.children;
28
+ const idx = children.indexOf(node);
29
+ if (idx > 0) {
30
+ prev = children[idx - 1];
31
+ while (prev && idx > 0 && (!prev.type || !prev.text.trim())) {
32
+ prev = children[idx - 2] || null;
33
+ }
34
+ }
35
+ }
36
+ while (prev && /attribute|decorator/i.test(prev.type)) {
37
+ prev = prev.previousNamedSibling || prev.previousSibling || null;
38
+ while (prev && (!prev.type || !prev.text.trim())) {
39
+ prev = prev.previousSibling || null;
40
+ }
41
+ }
42
+ while (prev && (/comment|xml|doc|slash/i.test(prev.type) || prev.text.trim().startsWith("//") || prev.text.trim().startsWith("///"))) {
43
+ const text = prev.text || "";
44
+ if (text.trim().startsWith("/**")) {
45
+ metadata.documentation = {
46
+ content: text.replace(/^[/*]+|[/*]+$/g, "").trim(),
47
+ type: "jsdoc"
48
+ };
49
+ break;
50
+ }
51
+ if (text.trim().startsWith("///")) {
52
+ metadata.documentation = {
53
+ content: text.replace(/^\/\/\//, "").trim(),
54
+ type: "xml-doc"
55
+ };
56
+ break;
57
+ }
58
+ if (text.trim().startsWith("//")) {
59
+ metadata.documentation = {
60
+ content: text.replace(/^\/\//, "").trim(),
61
+ type: "comment"
62
+ };
63
+ break;
64
+ }
65
+ prev = prev.previousSibling || null;
66
+ }
67
+ } catch {
68
+ }
69
+ const signatures = [
70
+ ...SIDE_EFFECT_KEYWORDS,
71
+ ...options.sideEffectSignatures || []
72
+ ];
73
+ const walk = (n) => {
74
+ if (/assign|assignment|assignment_statement|assignment_expression/i.test(
75
+ n.type
76
+ )) {
77
+ metadata.isPure = false;
78
+ metadata.hasSideEffects = true;
79
+ }
80
+ const text = n.text;
81
+ for (const sig of signatures) {
82
+ if (text.includes(sig)) {
83
+ metadata.isPure = false;
84
+ metadata.hasSideEffects = true;
85
+ break;
86
+ }
87
+ }
88
+ if (!metadata.hasSideEffects) {
89
+ for (let i = 0; i < n.childCount; i++) {
90
+ const child = n.child(i);
91
+ if (child) walk(child);
92
+ }
93
+ }
94
+ };
95
+ walk(node);
96
+ return metadata;
97
+ }
98
+ function extractParameterNames(node) {
99
+ const params = [];
100
+ const candidates = [
101
+ // common field name
102
+ node.childForFieldName ? node.childForFieldName("parameters") : null,
103
+ node.childForFieldName ? node.childForFieldName("parameter_list") : null,
104
+ node.children.find((c) => c.type === "parameter_list") || null,
105
+ node.children.find((c) => c.type === "parameters") || null,
106
+ node.children.find((c) => c.type === "formal_parameters") || null,
107
+ node.children.find((c) => c.type === "formal_parameter") || null
108
+ ];
109
+ const list = candidates.find(Boolean);
110
+ if (!list) return params;
111
+ for (const child of list.children) {
112
+ if (!child) continue;
113
+ const id = child.childForFieldName?.("name") || child.children.find(
114
+ (c) => [
115
+ "identifier",
116
+ "variable_name",
117
+ "name",
118
+ "parameter",
119
+ "formal_parameter"
120
+ ].includes(c.type)
121
+ ) || (child.type === "identifier" ? child : void 0);
122
+ if (id && typeof id.text === "string") params.push(id.text);
123
+ }
124
+ return params;
125
+ }
126
+
127
+ export {
128
+ analyzeGeneralMetadata,
129
+ extractParameterNames
130
+ };