@aiready/core 0.23.20 → 0.23.22

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 (116) 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-REU6OUBT.mjs → chunk-DBOPSRBC.mjs} +47 -22
  5. package/dist/chunk-E55RNGGK.mjs +852 -0
  6. package/dist/chunk-EZ7ECLAZ.mjs +299 -0
  7. package/dist/chunk-FNPULWG7.mjs +248 -0
  8. package/dist/chunk-FZTFKZUQ.mjs +250 -0
  9. package/dist/chunk-GTS642BQ.mjs +262 -0
  10. package/dist/chunk-IXPY5J4K.mjs +248 -0
  11. package/dist/chunk-JJQLYW6Z.mjs +111 -0
  12. package/dist/chunk-L6BKANJC.mjs +130 -0
  13. package/dist/chunk-LXEO5PG3.mjs +292 -0
  14. package/dist/chunk-LZHO636W.mjs +501 -0
  15. package/dist/chunk-MTK2IIDZ.mjs +262 -0
  16. package/dist/chunk-QDCQETSI.mjs +262 -0
  17. package/dist/chunk-QZNY7B2N.mjs +248 -0
  18. package/dist/chunk-RCZSMGCX.mjs +250 -0
  19. package/dist/chunk-SWZOT67M.mjs +250 -0
  20. package/dist/chunk-U3IY2CFC.mjs +36 -0
  21. package/dist/chunk-UBCM5Y6R.mjs +275 -0
  22. package/dist/chunk-UTCRW3N7.mjs +301 -0
  23. package/dist/{chunk-SQHS6PFL.mjs → chunk-UYLH35LA.mjs} +47 -22
  24. package/dist/{chunk-ZB3EHHAG.mjs → chunk-WVNVC2PP.mjs} +90 -60
  25. package/dist/chunk-WYOW6O3P.mjs +114 -0
  26. package/dist/{chunk-RMH2TPAT.mjs → chunk-YRSSR4KN.mjs} +87 -59
  27. package/dist/client/index.d.mts +2 -0
  28. package/dist/client/index.d.ts +2 -0
  29. package/dist/client/index.js +922 -0
  30. package/dist/client/index.mjs +104 -0
  31. package/dist/client-2xbeKnrg.d.mts +1291 -0
  32. package/dist/client-2xbeKnrg.d.ts +1291 -0
  33. package/dist/client-4HLAGzFg.d.mts +1291 -0
  34. package/dist/client-4HLAGzFg.d.ts +1291 -0
  35. package/dist/client-B4TQwNa7.d.mts +1290 -0
  36. package/dist/client-B4TQwNa7.d.ts +1290 -0
  37. package/dist/client-Bdi4ty0v.d.mts +1294 -0
  38. package/dist/client-Bdi4ty0v.d.ts +1294 -0
  39. package/dist/client-BsKpUH3H.d.mts +1339 -0
  40. package/dist/client-BsKpUH3H.d.ts +1339 -0
  41. package/dist/client-Bv1zOaWF.d.mts +1291 -0
  42. package/dist/client-Bv1zOaWF.d.ts +1291 -0
  43. package/dist/client-Bz9YJMIX.d.mts +1290 -0
  44. package/dist/client-Bz9YJMIX.d.ts +1290 -0
  45. package/dist/client-CBpzm34X.d.mts +1291 -0
  46. package/dist/client-CBpzm34X.d.ts +1291 -0
  47. package/dist/client-CNu_tCZZ.d.mts +1305 -0
  48. package/dist/client-CNu_tCZZ.d.ts +1305 -0
  49. package/dist/client-CmEvxxQu.d.mts +1339 -0
  50. package/dist/client-CmEvxxQu.d.ts +1339 -0
  51. package/dist/client-Ctl_0z6F.d.mts +1294 -0
  52. package/dist/client-Ctl_0z6F.d.ts +1294 -0
  53. package/dist/client-DGMAxkZc.d.mts +1339 -0
  54. package/dist/client-DGMAxkZc.d.ts +1339 -0
  55. package/dist/client-DZq-CqcD.d.mts +1292 -0
  56. package/dist/client-DZq-CqcD.d.ts +1292 -0
  57. package/dist/{client-CYz0qxGB.d.mts → client-DcqGfDTt.d.mts} +90 -23
  58. package/dist/{client-CYz0qxGB.d.ts → client-DcqGfDTt.d.ts} +90 -23
  59. package/dist/{client-jGuH6TAG.d.mts → client-O8RvSRm0.d.mts} +18 -1
  60. package/dist/{client-jGuH6TAG.d.ts → client-O8RvSRm0.d.ts} +18 -1
  61. package/dist/client.d.mts +1 -1
  62. package/dist/client.d.ts +1 -1
  63. package/dist/client.js +47 -13
  64. package/dist/client.mjs +6 -4
  65. package/dist/csharp-parser-4ZKCSX5B.mjs +9 -0
  66. package/dist/csharp-parser-5HKICCRR.mjs +9 -0
  67. package/dist/csharp-parser-JCKXIAJW.mjs +9 -0
  68. package/dist/go-parser-J4KIH4RG.mjs +9 -0
  69. package/dist/go-parser-TKXL3DVH.mjs +9 -0
  70. package/dist/go-parser-XOM232XZ.mjs +9 -0
  71. package/dist/index-Ctl_0z6F.d.mts +1294 -0
  72. package/dist/index-Ctl_0z6F.d.ts +1294 -0
  73. package/dist/index.d.mts +372 -165
  74. package/dist/index.d.ts +372 -165
  75. package/dist/index.js +3825 -3123
  76. package/dist/index.mjs +901 -2128
  77. package/dist/java-parser-3KHXOXRQ.mjs +9 -0
  78. package/dist/java-parser-MASGS4WB.mjs +9 -0
  79. package/dist/java-parser-T5LXD63J.mjs +9 -0
  80. package/dist/python-parser-FNFK2473.mjs +8 -0
  81. package/dist/typescript-parser-2GGNRNB5.mjs +7 -0
  82. package/dist/typescript-parser-3ENJ6C7H.mjs +7 -0
  83. package/dist/typescript-parser-4GI7DPSW.mjs +7 -0
  84. package/dist/typescript-parser-4H3HUBO4.mjs +7 -0
  85. package/dist/typescript-parser-K63IVZMF.mjs +7 -0
  86. package/dist/typescript-parser-ZJKROMQG.mjs +7 -0
  87. package/package.json +6 -6
  88. package/dist/chunk-2Y6WZCES.mjs +0 -859
  89. package/dist/chunk-5SHLHMH7.mjs +0 -760
  90. package/dist/chunk-CGOS2J6T.mjs +0 -807
  91. package/dist/chunk-FMNCV4CC.mjs +0 -859
  92. package/dist/chunk-Q55AMEFV.mjs +0 -760
  93. package/dist/chunk-ST75O5C5.mjs +0 -859
  94. package/dist/chunk-TJXR2CHZ.mjs +0 -799
  95. package/dist/client-BEoUYNLp.d.mts +0 -1191
  96. package/dist/client-BEoUYNLp.d.ts +0 -1191
  97. package/dist/client-BrIMPk89.d.mts +0 -1214
  98. package/dist/client-BrIMPk89.d.ts +0 -1214
  99. package/dist/client-C5BuGX4F.d.mts +0 -1205
  100. package/dist/client-C5BuGX4F.d.ts +0 -1205
  101. package/dist/client-CKcjnPXt.d.mts +0 -1214
  102. package/dist/client-CKcjnPXt.d.ts +0 -1214
  103. package/dist/client-CLulBnie.d.mts +0 -1182
  104. package/dist/client-CLulBnie.d.ts +0 -1182
  105. package/dist/client-CQwvp8ep.d.mts +0 -1182
  106. package/dist/client-CQwvp8ep.d.ts +0 -1182
  107. package/dist/client-DLvFR2qA.d.mts +0 -1197
  108. package/dist/client-DLvFR2qA.d.ts +0 -1197
  109. package/dist/client-PFPdeo-z.d.mts +0 -1186
  110. package/dist/client-PFPdeo-z.d.ts +0 -1186
  111. package/dist/client-WVCAIWdJ.d.mts +0 -1192
  112. package/dist/client-WVCAIWdJ.d.ts +0 -1192
  113. package/dist/client-pYldIAg2.d.mts +0 -1209
  114. package/dist/client-pYldIAg2.d.ts +0 -1209
  115. package/dist/client-wk2fgk1q.d.mts +0 -1184
  116. package/dist/client-wk2fgk1q.d.ts +0 -1184
@@ -0,0 +1,262 @@
1
+ import {
2
+ analyzeGeneralMetadata,
3
+ extractParameterNames
4
+ } from "./chunk-WYOW6O3P.mjs";
5
+ import {
6
+ BaseLanguageParser
7
+ } from "./chunk-2N7ISIKE.mjs";
8
+
9
+ // src/parsers/go-parser.ts
10
+ var GoParser = class extends BaseLanguageParser {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.language = "go" /* Go */;
14
+ this.extensions = [".go"];
15
+ }
16
+ getParserName() {
17
+ return "go";
18
+ }
19
+ /**
20
+ * Analyze metadata for a Go 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: ["<-", "fmt.Print", "fmt.Fprintf", "os.Exit"]
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 importRegex = /^import\s+"([^"]+)"/;
42
+ const funcRegex = /^func\s+([A-Z][a-zA-Z0-9_]*)\s*\(/;
43
+ const typeRegex = /^type\s+([A-Z][a-zA-Z0-9_]*)\s+(struct|interface)/;
44
+ lines.forEach((line, idx) => {
45
+ const importMatch = line.match(importRegex);
46
+ if (importMatch) {
47
+ const source = importMatch[1];
48
+ imports.push({
49
+ source,
50
+ specifiers: [source.split("/").pop() || source],
51
+ loc: {
52
+ start: { line: idx + 1, column: 0 },
53
+ end: { line: idx + 1, column: line.length }
54
+ }
55
+ });
56
+ }
57
+ const funcMatch = line.match(funcRegex);
58
+ if (funcMatch) {
59
+ const name = funcMatch[1];
60
+ const isPublic = /^[A-Z]/.test(name);
61
+ let docContent;
62
+ const prevLines = lines.slice(Math.max(0, idx - 3), idx);
63
+ for (let i = prevLines.length - 1; i >= 0; i--) {
64
+ const prevLine = prevLines[i].trim();
65
+ if (prevLine.startsWith("//")) {
66
+ const content = prevLine.slice(2).trim();
67
+ docContent = docContent ? content + "\n" + docContent : content;
68
+ } else if (prevLine.endsWith("*/")) {
69
+ const blockMatch = prevLine.match(/\/\*([\s\S]*)\*\//);
70
+ if (blockMatch) docContent = blockMatch[1].trim();
71
+ break;
72
+ } else if (!prevLine) {
73
+ if (docContent) break;
74
+ } else {
75
+ break;
76
+ }
77
+ }
78
+ const isImpure = name.toLowerCase().includes("impure") || line.includes("fmt.Print");
79
+ exports.push({
80
+ name,
81
+ type: "function",
82
+ visibility: isPublic ? "public" : "private",
83
+ isPure: !isImpure,
84
+ hasSideEffects: isImpure,
85
+ documentation: docContent ? { content: docContent, type: "comment" } : void 0,
86
+ loc: {
87
+ start: { line: idx + 1, column: 0 },
88
+ end: { line: idx + 1, column: line.length }
89
+ }
90
+ });
91
+ }
92
+ const typeMatch = line.match(typeRegex);
93
+ if (typeMatch) {
94
+ exports.push({
95
+ name: typeMatch[1],
96
+ type: typeMatch[2] === "struct" ? "class" : "interface",
97
+ visibility: "public",
98
+ isPure: true,
99
+ hasSideEffects: false,
100
+ loc: {
101
+ start: { line: idx + 1, column: 0 },
102
+ end: { line: idx + 1, column: line.length }
103
+ }
104
+ });
105
+ }
106
+ });
107
+ return {
108
+ exports,
109
+ imports,
110
+ language: "go" /* Go */,
111
+ warnings: ["Parser falling back to regex-based analysis"]
112
+ };
113
+ }
114
+ /**
115
+ * Extract import information using AST walk.
116
+ *
117
+ * @param rootNode - Root node of the Go AST.
118
+ * @returns Array of discovered FileImport objects.
119
+ */
120
+ extractImportsAST(rootNode) {
121
+ const imports = [];
122
+ const findImports = (node) => {
123
+ if (node.type === "import_spec") {
124
+ const pathNode = node.children.find(
125
+ (c) => c.type === "interpreted_string_literal"
126
+ );
127
+ if (pathNode) {
128
+ const source = pathNode.text.replace(/"/g, "");
129
+ imports.push({
130
+ source,
131
+ specifiers: [source.split("/").pop() || source],
132
+ loc: {
133
+ start: {
134
+ line: node.startPosition.row + 1,
135
+ column: node.startPosition.column
136
+ },
137
+ end: {
138
+ line: node.endPosition.row + 1,
139
+ column: node.endPosition.column
140
+ }
141
+ }
142
+ });
143
+ }
144
+ }
145
+ for (let i = 0; i < node.childCount; i++) {
146
+ const child = node.child(i);
147
+ if (child) findImports(child);
148
+ }
149
+ };
150
+ findImports(rootNode);
151
+ return imports;
152
+ }
153
+ /**
154
+ * Extract export information (functions, types, vars) using AST walk.
155
+ *
156
+ * @param rootNode - Root node of the Go AST.
157
+ * @param code - Source code for documentation extraction.
158
+ * @returns Array of discovered ExportInfo objects.
159
+ */
160
+ extractExportsAST(rootNode, code) {
161
+ const exports = [];
162
+ const isExported = (name) => {
163
+ return /^[A-Z]/.test(name);
164
+ };
165
+ const traverse = (node) => {
166
+ if (node.type === "function_declaration" || node.type === "method_declaration") {
167
+ const nameNode = node.childForFieldName("name") || node.children.find((c) => c.type === "identifier");
168
+ if (nameNode && isExported(nameNode.text)) {
169
+ const metadata = this.analyzeMetadata(node, code);
170
+ exports.push({
171
+ name: nameNode.text,
172
+ type: "function",
173
+ loc: {
174
+ start: {
175
+ line: node.startPosition.row + 1,
176
+ column: node.startPosition.column
177
+ },
178
+ end: {
179
+ line: node.endPosition.row + 1,
180
+ column: node.endPosition.column
181
+ }
182
+ },
183
+ visibility: "public",
184
+ parameters: this.extractParameters(node),
185
+ ...metadata
186
+ });
187
+ }
188
+ } else if (node.type === "type_spec") {
189
+ const nameNode = node.childForFieldName("name") || node.children.find((c) => c.type === "type_identifier");
190
+ if (nameNode && isExported(nameNode.text)) {
191
+ const metadata = this.analyzeMetadata(node.parent || node, code);
192
+ const type = node.children.some((c) => c.type === "struct_type") ? "class" : "interface";
193
+ exports.push({
194
+ name: nameNode.text,
195
+ type,
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: "public",
207
+ ...metadata
208
+ });
209
+ }
210
+ } else if (node.type === "var_spec" || node.type === "const_spec") {
211
+ const identifiers = node.children.filter(
212
+ (c) => c.type === "identifier"
213
+ );
214
+ for (const idNode of identifiers) {
215
+ if (isExported(idNode.text)) {
216
+ const metadata = this.analyzeMetadata(node, code);
217
+ exports.push({
218
+ name: idNode.text,
219
+ type: "variable",
220
+ loc: {
221
+ start: {
222
+ line: idNode.startPosition.row + 1,
223
+ column: idNode.startPosition.column
224
+ },
225
+ end: {
226
+ line: idNode.endPosition.row + 1,
227
+ column: idNode.endPosition.column
228
+ }
229
+ },
230
+ visibility: "public",
231
+ ...metadata
232
+ });
233
+ }
234
+ }
235
+ }
236
+ for (let i = 0; i < node.childCount; i++) {
237
+ const child = node.child(i);
238
+ if (child) traverse(child);
239
+ }
240
+ };
241
+ traverse(rootNode);
242
+ return exports;
243
+ }
244
+ extractParameters(node) {
245
+ return extractParameterNames(node);
246
+ }
247
+ getNamingConventions() {
248
+ return {
249
+ variablePattern: /^[a-zA-Z][a-zA-Z0-9]*$/,
250
+ functionPattern: /^[a-zA-Z][a-zA-Z0-9]*$/,
251
+ classPattern: /^[a-zA-Z][a-zA-Z0-9]*$/,
252
+ constantPattern: /^[a-zA-Z_][a-zA-Z0-9_]*$/
253
+ };
254
+ }
255
+ canHandle(filePath) {
256
+ return filePath.toLowerCase().endsWith(".go");
257
+ }
258
+ };
259
+
260
+ export {
261
+ GoParser
262
+ };
@@ -0,0 +1,262 @@
1
+ import {
2
+ analyzeGeneralMetadata,
3
+ extractParameterNames
4
+ } from "./chunk-JJQLYW6Z.mjs";
5
+ import {
6
+ BaseLanguageParser
7
+ } from "./chunk-2N7ISIKE.mjs";
8
+
9
+ // src/parsers/go-parser.ts
10
+ var GoParser = class extends BaseLanguageParser {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.language = "go" /* Go */;
14
+ this.extensions = [".go"];
15
+ }
16
+ getParserName() {
17
+ return "go";
18
+ }
19
+ /**
20
+ * Analyze metadata for a Go 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: ["<-", "fmt.Print", "fmt.Fprintf", "os.Exit"]
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 importRegex = /^import\s+"([^"]+)"/;
42
+ const funcRegex = /^func\s+([A-Z][a-zA-Z0-9_]*)\s*\(/;
43
+ const typeRegex = /^type\s+([A-Z][a-zA-Z0-9_]*)\s+(struct|interface)/;
44
+ lines.forEach((line, idx) => {
45
+ const importMatch = line.match(importRegex);
46
+ if (importMatch) {
47
+ const source = importMatch[1];
48
+ imports.push({
49
+ source,
50
+ specifiers: [source.split("/").pop() || source],
51
+ loc: {
52
+ start: { line: idx + 1, column: 0 },
53
+ end: { line: idx + 1, column: line.length }
54
+ }
55
+ });
56
+ }
57
+ const funcMatch = line.match(funcRegex);
58
+ if (funcMatch) {
59
+ const name = funcMatch[1];
60
+ const isPublic = /^[A-Z]/.test(name);
61
+ let docContent;
62
+ const prevLines = lines.slice(Math.max(0, idx - 3), idx);
63
+ for (let i = prevLines.length - 1; i >= 0; i--) {
64
+ const prevLine = prevLines[i].trim();
65
+ if (prevLine.startsWith("//")) {
66
+ const content = prevLine.slice(2).trim();
67
+ docContent = docContent ? content + "\n" + docContent : content;
68
+ } else if (prevLine.endsWith("*/")) {
69
+ const blockMatch = prevLine.match(/\/\*([\s\S]*)\*\//);
70
+ if (blockMatch) docContent = blockMatch[1].trim();
71
+ break;
72
+ } else if (!prevLine) {
73
+ if (docContent) break;
74
+ } else {
75
+ break;
76
+ }
77
+ }
78
+ const isImpure = name.toLowerCase().includes("impure") || line.includes("fmt.Print");
79
+ exports.push({
80
+ name,
81
+ type: "function",
82
+ visibility: isPublic ? "public" : "private",
83
+ isPure: !isImpure,
84
+ hasSideEffects: isImpure,
85
+ documentation: docContent ? { content: docContent, type: "comment" } : void 0,
86
+ loc: {
87
+ start: { line: idx + 1, column: 0 },
88
+ end: { line: idx + 1, column: line.length }
89
+ }
90
+ });
91
+ }
92
+ const typeMatch = line.match(typeRegex);
93
+ if (typeMatch) {
94
+ exports.push({
95
+ name: typeMatch[1],
96
+ type: typeMatch[2] === "struct" ? "class" : "interface",
97
+ visibility: "public",
98
+ isPure: true,
99
+ hasSideEffects: false,
100
+ loc: {
101
+ start: { line: idx + 1, column: 0 },
102
+ end: { line: idx + 1, column: line.length }
103
+ }
104
+ });
105
+ }
106
+ });
107
+ return {
108
+ exports,
109
+ imports,
110
+ language: "go" /* Go */,
111
+ warnings: ["Parser falling back to regex-based analysis"]
112
+ };
113
+ }
114
+ /**
115
+ * Extract import information using AST walk.
116
+ *
117
+ * @param rootNode - Root node of the Go AST.
118
+ * @returns Array of discovered FileImport objects.
119
+ */
120
+ extractImportsAST(rootNode) {
121
+ const imports = [];
122
+ const findImports = (node) => {
123
+ if (node.type === "import_spec") {
124
+ const pathNode = node.children.find(
125
+ (c) => c.type === "interpreted_string_literal"
126
+ );
127
+ if (pathNode) {
128
+ const source = pathNode.text.replace(/"/g, "");
129
+ imports.push({
130
+ source,
131
+ specifiers: [source.split("/").pop() || source],
132
+ loc: {
133
+ start: {
134
+ line: node.startPosition.row + 1,
135
+ column: node.startPosition.column
136
+ },
137
+ end: {
138
+ line: node.endPosition.row + 1,
139
+ column: node.endPosition.column
140
+ }
141
+ }
142
+ });
143
+ }
144
+ }
145
+ for (let i = 0; i < node.childCount; i++) {
146
+ const child = node.child(i);
147
+ if (child) findImports(child);
148
+ }
149
+ };
150
+ findImports(rootNode);
151
+ return imports;
152
+ }
153
+ /**
154
+ * Extract export information (functions, types, vars) using AST walk.
155
+ *
156
+ * @param rootNode - Root node of the Go AST.
157
+ * @param code - Source code for documentation extraction.
158
+ * @returns Array of discovered ExportInfo objects.
159
+ */
160
+ extractExportsAST(rootNode, code) {
161
+ const exports = [];
162
+ const isExported = (name) => {
163
+ return /^[A-Z]/.test(name);
164
+ };
165
+ const traverse = (node) => {
166
+ if (node.type === "function_declaration" || node.type === "method_declaration") {
167
+ const nameNode = node.childForFieldName("name") || node.children.find((c) => c.type === "identifier");
168
+ if (nameNode && isExported(nameNode.text)) {
169
+ const metadata = this.analyzeMetadata(node, code);
170
+ exports.push({
171
+ name: nameNode.text,
172
+ type: "function",
173
+ loc: {
174
+ start: {
175
+ line: node.startPosition.row + 1,
176
+ column: node.startPosition.column
177
+ },
178
+ end: {
179
+ line: node.endPosition.row + 1,
180
+ column: node.endPosition.column
181
+ }
182
+ },
183
+ visibility: "public",
184
+ parameters: this.extractParameters(node),
185
+ ...metadata
186
+ });
187
+ }
188
+ } else if (node.type === "type_spec") {
189
+ const nameNode = node.childForFieldName("name") || node.children.find((c) => c.type === "type_identifier");
190
+ if (nameNode && isExported(nameNode.text)) {
191
+ const metadata = this.analyzeMetadata(node.parent || node, code);
192
+ const type = node.children.some((c) => c.type === "struct_type") ? "class" : "interface";
193
+ exports.push({
194
+ name: nameNode.text,
195
+ type,
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: "public",
207
+ ...metadata
208
+ });
209
+ }
210
+ } else if (node.type === "var_spec" || node.type === "const_spec") {
211
+ const identifiers = node.children.filter(
212
+ (c) => c.type === "identifier"
213
+ );
214
+ for (const idNode of identifiers) {
215
+ if (isExported(idNode.text)) {
216
+ const metadata = this.analyzeMetadata(node, code);
217
+ exports.push({
218
+ name: idNode.text,
219
+ type: "variable",
220
+ loc: {
221
+ start: {
222
+ line: idNode.startPosition.row + 1,
223
+ column: idNode.startPosition.column
224
+ },
225
+ end: {
226
+ line: idNode.endPosition.row + 1,
227
+ column: idNode.endPosition.column
228
+ }
229
+ },
230
+ visibility: "public",
231
+ ...metadata
232
+ });
233
+ }
234
+ }
235
+ }
236
+ for (let i = 0; i < node.childCount; i++) {
237
+ const child = node.child(i);
238
+ if (child) traverse(child);
239
+ }
240
+ };
241
+ traverse(rootNode);
242
+ return exports;
243
+ }
244
+ extractParameters(node) {
245
+ return extractParameterNames(node);
246
+ }
247
+ getNamingConventions() {
248
+ return {
249
+ variablePattern: /^[a-zA-Z][a-zA-Z0-9]*$/,
250
+ functionPattern: /^[a-zA-Z][a-zA-Z0-9]*$/,
251
+ classPattern: /^[a-zA-Z][a-zA-Z0-9]*$/,
252
+ constantPattern: /^[a-zA-Z_][a-zA-Z0-9_]*$/
253
+ };
254
+ }
255
+ canHandle(filePath) {
256
+ return filePath.toLowerCase().endsWith(".go");
257
+ }
258
+ };
259
+
260
+ export {
261
+ GoParser
262
+ };