memgrid 0.5.0

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/CHANGELOG.md +80 -0
  2. package/LICENSE +21 -0
  3. package/README.md +251 -0
  4. package/dist/index.d.ts +2 -0
  5. package/dist/index.d.ts.map +1 -0
  6. package/dist/index.js +2 -0
  7. package/dist/index.js.map +1 -0
  8. package/dist/learn/index.d.ts +44 -0
  9. package/dist/learn/index.d.ts.map +1 -0
  10. package/dist/learn/index.js +234 -0
  11. package/dist/learn/index.js.map +1 -0
  12. package/dist/memgrid.d.ts +50 -0
  13. package/dist/memgrid.d.ts.map +1 -0
  14. package/dist/memgrid.js +175 -0
  15. package/dist/memgrid.js.map +1 -0
  16. package/dist/retrieve/index.d.ts +27 -0
  17. package/dist/retrieve/index.d.ts.map +1 -0
  18. package/dist/retrieve/index.js +209 -0
  19. package/dist/retrieve/index.js.map +1 -0
  20. package/dist/retrieve/semantic.d.ts +67 -0
  21. package/dist/retrieve/semantic.d.ts.map +1 -0
  22. package/dist/retrieve/semantic.js +240 -0
  23. package/dist/retrieve/semantic.js.map +1 -0
  24. package/dist/scanner/composite.d.ts +27 -0
  25. package/dist/scanner/composite.d.ts.map +1 -0
  26. package/dist/scanner/composite.js +58 -0
  27. package/dist/scanner/composite.js.map +1 -0
  28. package/dist/scanner/config.d.ts +15 -0
  29. package/dist/scanner/config.d.ts.map +1 -0
  30. package/dist/scanner/config.js +167 -0
  31. package/dist/scanner/config.js.map +1 -0
  32. package/dist/scanner/golang.d.ts +19 -0
  33. package/dist/scanner/golang.d.ts.map +1 -0
  34. package/dist/scanner/golang.js +190 -0
  35. package/dist/scanner/golang.js.map +1 -0
  36. package/dist/scanner/index.d.ts +11 -0
  37. package/dist/scanner/index.d.ts.map +1 -0
  38. package/dist/scanner/index.js +10 -0
  39. package/dist/scanner/index.js.map +1 -0
  40. package/dist/scanner/javascript.d.ts +20 -0
  41. package/dist/scanner/javascript.d.ts.map +1 -0
  42. package/dist/scanner/javascript.js +167 -0
  43. package/dist/scanner/javascript.js.map +1 -0
  44. package/dist/scanner/markdown.d.ts +17 -0
  45. package/dist/scanner/markdown.d.ts.map +1 -0
  46. package/dist/scanner/markdown.js +106 -0
  47. package/dist/scanner/markdown.js.map +1 -0
  48. package/dist/scanner/python.d.ts +19 -0
  49. package/dist/scanner/python.d.ts.map +1 -0
  50. package/dist/scanner/python.js +177 -0
  51. package/dist/scanner/python.js.map +1 -0
  52. package/dist/scanner/rules.d.ts +15 -0
  53. package/dist/scanner/rules.d.ts.map +1 -0
  54. package/dist/scanner/rules.js +86 -0
  55. package/dist/scanner/rules.js.map +1 -0
  56. package/dist/scanner/rust.d.ts +18 -0
  57. package/dist/scanner/rust.d.ts.map +1 -0
  58. package/dist/scanner/rust.js +178 -0
  59. package/dist/scanner/rust.js.map +1 -0
  60. package/dist/scanner/scanner.d.ts +33 -0
  61. package/dist/scanner/scanner.d.ts.map +1 -0
  62. package/dist/scanner/scanner.js +2 -0
  63. package/dist/scanner/scanner.js.map +1 -0
  64. package/dist/scanner/typescript.d.ts +28 -0
  65. package/dist/scanner/typescript.d.ts.map +1 -0
  66. package/dist/scanner/typescript.js +522 -0
  67. package/dist/scanner/typescript.js.map +1 -0
  68. package/dist/serve/cli.d.ts +3 -0
  69. package/dist/serve/cli.d.ts.map +1 -0
  70. package/dist/serve/cli.js +145 -0
  71. package/dist/serve/cli.js.map +1 -0
  72. package/dist/serve/mcp-server.d.ts +11 -0
  73. package/dist/serve/mcp-server.d.ts.map +1 -0
  74. package/dist/serve/mcp-server.js +276 -0
  75. package/dist/serve/mcp-server.js.map +1 -0
  76. package/dist/shared/constants.d.ts +2 -0
  77. package/dist/shared/constants.d.ts.map +1 -0
  78. package/dist/shared/constants.js +2 -0
  79. package/dist/shared/constants.js.map +1 -0
  80. package/dist/shared/types.d.ts +99 -0
  81. package/dist/shared/types.d.ts.map +1 -0
  82. package/dist/shared/types.js +3 -0
  83. package/dist/shared/types.js.map +1 -0
  84. package/dist/store/file-store.d.ts +62 -0
  85. package/dist/store/file-store.d.ts.map +1 -0
  86. package/dist/store/file-store.js +241 -0
  87. package/dist/store/file-store.js.map +1 -0
  88. package/dist/store/index.d.ts +3 -0
  89. package/dist/store/index.d.ts.map +1 -0
  90. package/dist/store/index.js +2 -0
  91. package/dist/store/index.js.map +1 -0
  92. package/dist/sync/index.d.ts +56 -0
  93. package/dist/sync/index.d.ts.map +1 -0
  94. package/dist/sync/index.js +580 -0
  95. package/dist/sync/index.js.map +1 -0
  96. package/package.json +51 -0
@@ -0,0 +1,190 @@
1
+ import * as path from 'path';
2
+ import * as fs from 'fs';
3
+ /**
4
+ * Go project scanner.
5
+ * Regex-based: extracts func, type, method declarations.
6
+ */
7
+ export class GoScanner {
8
+ name = 'golang';
9
+ projectRoot;
10
+ constructor(_store, projectRoot) {
11
+ this.projectRoot = projectRoot;
12
+ }
13
+ detect(projectRoot) {
14
+ return fs.existsSync(path.join(projectRoot, 'go.mod'));
15
+ }
16
+ async scan(_options) {
17
+ const units = [];
18
+ const srcDirs = this.findSourceDirs(this.projectRoot);
19
+ // If no src dirs, scan root-level .go files
20
+ if (srcDirs.length === 0) {
21
+ const rootFiles = fs.readdirSync(this.projectRoot)
22
+ .filter((f) => f.endsWith('.go') && !f.endsWith('_test.go'));
23
+ for (const file of rootFiles) {
24
+ try {
25
+ this.parseGoFile(fs.readFileSync(path.join(this.projectRoot, file), 'utf-8'), file, units);
26
+ }
27
+ catch { /* skip */ }
28
+ }
29
+ }
30
+ for (const dir of srcDirs) {
31
+ await this.scanDir(dir, '', units);
32
+ }
33
+ return units;
34
+ }
35
+ async scanDir(dir, relPrefix, units) {
36
+ if (!fs.existsSync(dir))
37
+ return;
38
+ for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
39
+ const abs = path.join(dir, entry.name);
40
+ const rel = relPrefix ? path.join(relPrefix, entry.name) : entry.name;
41
+ if (entry.isDirectory()) {
42
+ if (entry.name.startsWith('.') || entry.name === 'vendor' || entry.name === 'node_modules')
43
+ continue;
44
+ await this.scanDir(abs, rel, units);
45
+ }
46
+ else if (entry.name.endsWith('.go') && !entry.name.endsWith('_test.go')) {
47
+ try {
48
+ const code = fs.readFileSync(abs, 'utf-8');
49
+ this.parseGoFile(code, rel, units);
50
+ }
51
+ catch { /* skip */ }
52
+ }
53
+ }
54
+ }
55
+ parseGoFile(code, file, units) {
56
+ const lines = code.split('\n');
57
+ for (let i = 0; i < lines.length; i++) {
58
+ const line = lines[i].trim();
59
+ // func Name(params) returnType {
60
+ let match = line.match(/^func\s+(\w+)\s*\(([^)]*)\)\s*(\(?[\w\[\]\*\.]+\)?)?\s*\{/);
61
+ if (match) {
62
+ const funcName = match[1];
63
+ if (funcName[0] === funcName[0].toLowerCase() && !this.isStructMethod(line, funcName))
64
+ continue; // skip unexported (unless struct method)
65
+ const params = match[2];
66
+ const ret = match[3] || '';
67
+ units.push({
68
+ id: `method_go_${this.sanitizeId(funcName)}`,
69
+ type: 'method',
70
+ summary: `${funcName}(${params}) ${ret}`.trim(),
71
+ source: { file, lines: `${i + 1}` },
72
+ signatures: [funcName],
73
+ content: {
74
+ description: `Go function ${funcName}`,
75
+ inputs: params || 'none',
76
+ outputs: ret || 'none',
77
+ },
78
+ associations: [],
79
+ meta: {
80
+ created: new Date().toISOString(),
81
+ updated: new Date().toISOString(),
82
+ confidence: 0.7,
83
+ usage_count: 0,
84
+ status: 'active',
85
+ },
86
+ });
87
+ continue;
88
+ }
89
+ // func (receiver Type) methodName(params) returnType {
90
+ match = line.match(/^func\s+\((\w+)\s+\*?(\w+)\)\s+(\w+)\s*\(([^)]*)\)\s*(\(?[\w\[\]\*\.]+\)?)?\s*\{/);
91
+ if (match) {
92
+ const receiverName = match[1];
93
+ const receiverType = match[2];
94
+ const methodName = match[3];
95
+ const params = match[4];
96
+ const ret = match[5] || '';
97
+ units.push({
98
+ id: `method_go_${this.sanitizeId(receiverType + '_' + methodName)}`,
99
+ type: 'method',
100
+ summary: `${receiverType}.${methodName}(${params}) ${ret}`.trim(),
101
+ source: { file, lines: `${i + 1}` },
102
+ signatures: [`${receiverType}.${methodName}`, methodName],
103
+ content: {
104
+ description: `Go method ${receiverType}.${methodName}()`,
105
+ inputs: params || 'none',
106
+ outputs: ret || 'none',
107
+ },
108
+ associations: [],
109
+ meta: {
110
+ created: new Date().toISOString(),
111
+ updated: new Date().toISOString(),
112
+ confidence: 0.75,
113
+ usage_count: 0,
114
+ status: 'active',
115
+ },
116
+ });
117
+ continue;
118
+ }
119
+ // type Name struct {
120
+ match = line.match(/^type\s+(\w+)\s+struct\s*\{/);
121
+ if (match) {
122
+ const structName = match[1];
123
+ if (structName[0] !== structName[0].toUpperCase())
124
+ continue;
125
+ units.push({
126
+ id: `method_go_struct_${this.sanitizeId(structName)}`,
127
+ type: 'method',
128
+ summary: `${structName} (struct)`,
129
+ source: { file, lines: `${i + 1}` },
130
+ signatures: [structName],
131
+ content: { description: `Go struct ${structName}` },
132
+ associations: [],
133
+ meta: {
134
+ created: new Date().toISOString(),
135
+ updated: new Date().toISOString(),
136
+ confidence: 0.65,
137
+ usage_count: 0,
138
+ status: 'active',
139
+ },
140
+ });
141
+ continue;
142
+ }
143
+ // type Name interface {
144
+ match = line.match(/^type\s+(\w+)\s+interface\s*\{/);
145
+ if (match) {
146
+ units.push({
147
+ id: `method_go_iface_${this.sanitizeId(match[1])}`,
148
+ type: 'pattern',
149
+ summary: `${match[1]} (interface)`,
150
+ source: { file, lines: `${i + 1}` },
151
+ signatures: [match[1]],
152
+ content: { description: `Go interface ${match[1]}` },
153
+ associations: [],
154
+ meta: {
155
+ created: new Date().toISOString(),
156
+ updated: new Date().toISOString(),
157
+ confidence: 0.7,
158
+ usage_count: 0,
159
+ status: 'active',
160
+ },
161
+ });
162
+ continue;
163
+ }
164
+ }
165
+ }
166
+ isStructMethod(line, _funcName) {
167
+ // Check if this looks like a struct method (func (r Type) name)
168
+ return /func\s+\(\w+\s+\*?\w+\)/.test(line);
169
+ }
170
+ findSourceDirs(projectRoot) {
171
+ const dirs = [];
172
+ for (const name of ['cmd', 'internal', 'pkg', 'src', 'app']) {
173
+ const abs = path.join(projectRoot, name);
174
+ if (fs.existsSync(abs) && fs.statSync(abs).isDirectory()) {
175
+ dirs.push(abs);
176
+ }
177
+ }
178
+ return dirs;
179
+ }
180
+ sanitizeId(text) {
181
+ return text
182
+ .replace(/\./g, '_')
183
+ .replace(/\*/g, 'ptr_')
184
+ .replace(/[^a-zA-Z0-9_\-]/g, '_')
185
+ .replace(/_+/g, '_')
186
+ .toLowerCase()
187
+ .replace(/^_|_$/g, '');
188
+ }
189
+ }
190
+ //# sourceMappingURL=golang.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"golang.js","sourceRoot":"","sources":["../../src/scanner/golang.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ export type { Scanner } from './scanner.js';
2
+ export { CompositeScanner } from './composite.js';
3
+ export { TypeScriptScanner } from './typescript.js';
4
+ export { JavaScriptScanner } from './javascript.js';
5
+ export { PythonScanner } from './python.js';
6
+ export { GoScanner } from './golang.js';
7
+ export { RustScanner } from './rust.js';
8
+ export { MarkdownScanner } from './markdown.js';
9
+ export { RulesScanner } from './rules.js';
10
+ export { ConfigScanner } from './config.js';
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/scanner/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,10 @@
1
+ export { CompositeScanner } from './composite.js';
2
+ export { TypeScriptScanner } from './typescript.js';
3
+ export { JavaScriptScanner } from './javascript.js';
4
+ export { PythonScanner } from './python.js';
5
+ export { GoScanner } from './golang.js';
6
+ export { RustScanner } from './rust.js';
7
+ export { MarkdownScanner } from './markdown.js';
8
+ export { RulesScanner } from './rules.js';
9
+ export { ConfigScanner } from './config.js';
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/scanner/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,20 @@
1
+ import type { MemoryUnit, ScanOptions } from '../shared/types.js';
2
+ import type { Scanner } from './scanner.js';
3
+ /**
4
+ * JavaScript project scanner (no TypeScript).
5
+ * Regex-based: extracts exported functions, classes, arrow functions.
6
+ */
7
+ export declare class JavaScriptScanner implements Scanner {
8
+ readonly name = "javascript";
9
+ private projectRoot;
10
+ constructor(_store: any, projectRoot: string);
11
+ detect(projectRoot: string): boolean;
12
+ scan(_options: ScanOptions): Promise<MemoryUnit[]>;
13
+ private scanDir;
14
+ private parseJSFile;
15
+ private addFunctionUnit;
16
+ private extractClassMethods;
17
+ private findSourceDirs;
18
+ private hasJSFiles;
19
+ }
20
+ //# sourceMappingURL=javascript.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"javascript.d.ts","sourceRoot":"","sources":["../../src/scanner/javascript.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAClE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAE5C;;;GAGG;AACH,qBAAa,iBAAkB,YAAW,OAAO;IAC/C,QAAQ,CAAC,IAAI,gBAAgB;IAC7B,OAAO,CAAC,WAAW,CAAS;gBAEhB,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM;IAI5C,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;IAc9B,IAAI,CAAC,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;YAW1C,OAAO;IAyBrB,OAAO,CAAC,WAAW;IAsDnB,OAAO,CAAC,eAAe;IA6BvB,OAAO,CAAC,mBAAmB;IAc3B,OAAO,CAAC,cAAc;IAYtB,OAAO,CAAC,UAAU;CAWnB"}
@@ -0,0 +1,167 @@
1
+ import * as path from 'path';
2
+ import * as fs from 'fs';
3
+ /**
4
+ * JavaScript project scanner (no TypeScript).
5
+ * Regex-based: extracts exported functions, classes, arrow functions.
6
+ */
7
+ export class JavaScriptScanner {
8
+ name = 'javascript';
9
+ projectRoot;
10
+ constructor(_store, projectRoot) {
11
+ this.projectRoot = projectRoot;
12
+ }
13
+ detect(projectRoot) {
14
+ const hasTS = fs.existsSync(path.join(projectRoot, 'tsconfig.json'));
15
+ if (hasTS)
16
+ return false; // let TypeScriptScanner handle it
17
+ const hasJS = (fs.existsSync(path.join(projectRoot, 'package.json')) &&
18
+ !hasTS);
19
+ if (!hasJS)
20
+ return false;
21
+ // Quick check: any .js/.mjs/.cjs files?
22
+ return this.findSourceDirs(projectRoot).length > 0;
23
+ }
24
+ async scan(_options) {
25
+ const units = [];
26
+ const srcDirs = this.findSourceDirs(this.projectRoot);
27
+ for (const dir of srcDirs) {
28
+ await this.scanDir(dir, '', units);
29
+ }
30
+ return units;
31
+ }
32
+ async scanDir(dir, relPrefix, units) {
33
+ if (!fs.existsSync(dir))
34
+ return;
35
+ for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
36
+ const abs = path.join(dir, entry.name);
37
+ const rel = relPrefix ? path.join(relPrefix, entry.name) : entry.name;
38
+ if (entry.isDirectory()) {
39
+ if (entry.name.startsWith('.') || entry.name === 'node_modules')
40
+ continue;
41
+ if (entry.name === '__tests__' || entry.name === 'test')
42
+ continue;
43
+ await this.scanDir(abs, rel, units);
44
+ }
45
+ else if ((entry.name.endsWith('.js') || entry.name.endsWith('.mjs') || entry.name.endsWith('.cjs')) &&
46
+ !entry.name.includes('.test.') && !entry.name.includes('.spec.')) {
47
+ try {
48
+ const code = fs.readFileSync(abs, 'utf-8');
49
+ this.parseJSFile(code, rel, units);
50
+ }
51
+ catch {
52
+ // skip
53
+ }
54
+ }
55
+ }
56
+ }
57
+ parseJSFile(code, file, units) {
58
+ const lines = code.split('\n');
59
+ for (let i = 0; i < lines.length; i++) {
60
+ const line = lines[i].trim();
61
+ // export async function name(params)
62
+ let match = line.match(/^export\s+(?:async\s+)?function\s+(\w+)\s*\(([^)]*)\)/);
63
+ if (match) {
64
+ this.addFunctionUnit(match[1], match[2], file, i + 1, units, '');
65
+ continue;
66
+ }
67
+ // export const name = async (params) => {
68
+ match = line.match(/^export\s+const\s+(\w+)\s*=\s*(?:async\s*)?\(([^)]*)\)\s*=>/);
69
+ if (match) {
70
+ this.addFunctionUnit(match[1], match[2], file, i + 1, units, '');
71
+ continue;
72
+ }
73
+ // export const name = async function(params)
74
+ match = line.match(/^export\s+const\s+(\w+)\s*=\s*(?:async\s+)?function\s*\(([^)]*)\)/);
75
+ if (match) {
76
+ this.addFunctionUnit(match[1], match[2], file, i + 1, units, '');
77
+ continue;
78
+ }
79
+ // class ClassName
80
+ match = line.match(/^export\s+(?:default\s+)?class\s+(\w+)/);
81
+ if (match) {
82
+ const methods = this.extractClassMethods(lines, i);
83
+ units.push({
84
+ id: `method_js_${match[1].toLowerCase()}`,
85
+ type: 'method',
86
+ summary: `${match[1]} (class)`,
87
+ source: { file, lines: `${i + 1}` },
88
+ signatures: [match[1]],
89
+ content: {
90
+ description: `JavaScript class ${match[1]}${methods.length ? `. Methods: ${methods.join(', ')}` : ''}`,
91
+ },
92
+ associations: [],
93
+ meta: {
94
+ created: new Date().toISOString(),
95
+ updated: new Date().toISOString(),
96
+ confidence: 0.7,
97
+ usage_count: 0,
98
+ status: 'active',
99
+ },
100
+ });
101
+ continue;
102
+ }
103
+ }
104
+ }
105
+ addFunctionUnit(name, params, file, line, units, extraDesc) {
106
+ units.push({
107
+ id: `method_js_${name.toLowerCase()}`,
108
+ type: 'method',
109
+ summary: `${name}()${extraDesc ? ` — ${extraDesc}` : ''}`,
110
+ source: { file, lines: `${line}` },
111
+ signatures: [name],
112
+ content: {
113
+ description: extraDesc || `${name}()`,
114
+ inputs: params || 'none',
115
+ },
116
+ associations: [],
117
+ meta: {
118
+ created: new Date().toISOString(),
119
+ updated: new Date().toISOString(),
120
+ confidence: 0.65,
121
+ usage_count: 0,
122
+ status: 'active',
123
+ },
124
+ });
125
+ }
126
+ extractClassMethods(lines, classStart) {
127
+ const methods = [];
128
+ // Simple scan for method-like patterns inside the class body
129
+ for (let i = classStart + 1; i < Math.min(classStart + 100, lines.length); i++) {
130
+ const line = lines[i].trim();
131
+ if (line.startsWith('}'))
132
+ break;
133
+ const match = line.match(/^\s*(?:static\s+)?(?:async\s+)?(\w+)\s*\(/);
134
+ if (match && !['if', 'for', 'while', 'switch', 'constructor'].includes(match[1])) {
135
+ methods.push(match[1]);
136
+ }
137
+ }
138
+ return methods.slice(0, 15); // cap
139
+ }
140
+ findSourceDirs(projectRoot) {
141
+ const dirs = [];
142
+ for (const name of ['src', 'lib', 'app', 'dist']) {
143
+ const abs = path.join(projectRoot, name);
144
+ if (!fs.existsSync(abs))
145
+ continue;
146
+ if (fs.statSync(abs).isDirectory() && this.hasJSFiles(abs)) {
147
+ dirs.push(abs);
148
+ }
149
+ }
150
+ return dirs;
151
+ }
152
+ hasJSFiles(dir) {
153
+ try {
154
+ for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
155
+ if (entry.name.endsWith('.js') || entry.name.endsWith('.mjs'))
156
+ return true;
157
+ if (entry.isDirectory() && !entry.name.startsWith('.') && entry.name !== 'node_modules') {
158
+ if (this.hasJSFiles(path.join(dir, entry.name)))
159
+ return true;
160
+ }
161
+ }
162
+ }
163
+ catch { /* permission error */ }
164
+ return false;
165
+ }
166
+ }
167
+ //# sourceMappingURL=javascript.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"javascript.js","sourceRoot":"","sources":["../../src/scanner/javascript.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import type { MemoryUnit, ScanOptions } from '../shared/types.js';
2
+ import type { Scanner } from './scanner.js';
3
+ /**
4
+ * General-purpose Markdown scanner.
5
+ * Scans all .md files in the project (README, docs/, etc.) and creates
6
+ * knowledge units from their headings.
7
+ */
8
+ export declare class MarkdownScanner implements Scanner {
9
+ readonly name = "markdown";
10
+ private projectRoot;
11
+ constructor(projectRoot: string);
12
+ detect(projectRoot: string): boolean;
13
+ scan(_options: ScanOptions): Promise<MemoryUnit[]>;
14
+ scanFiles(files: string[], _options: ScanOptions): Promise<MemoryUnit[]>;
15
+ private findMdFiles;
16
+ }
17
+ //# sourceMappingURL=markdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown.d.ts","sourceRoot":"","sources":["../../src/scanner/markdown.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAClE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAE5C;;;;GAIG;AACH,qBAAa,eAAgB,YAAW,OAAO;IAC7C,QAAQ,CAAC,IAAI,cAAc;IAC3B,OAAO,CAAC,WAAW,CAAS;gBAEhB,WAAW,EAAE,MAAM;IAI/B,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;IAK9B,IAAI,CAAC,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAkElD,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAK9E,OAAO,CAAC,WAAW;CAoBpB"}
@@ -0,0 +1,106 @@
1
+ import * as path from 'path';
2
+ import * as fs from 'fs';
3
+ /**
4
+ * General-purpose Markdown scanner.
5
+ * Scans all .md files in the project (README, docs/, etc.) and creates
6
+ * knowledge units from their headings.
7
+ */
8
+ export class MarkdownScanner {
9
+ name = 'markdown';
10
+ projectRoot;
11
+ constructor(projectRoot) {
12
+ this.projectRoot = projectRoot;
13
+ }
14
+ detect(projectRoot) {
15
+ // Always applicable if there are .md files
16
+ return this.findMdFiles(projectRoot).length > 0;
17
+ }
18
+ async scan(_options) {
19
+ const units = [];
20
+ const mdFiles = this.findMdFiles(this.projectRoot);
21
+ for (const rel of mdFiles) {
22
+ // Skip rules (handled by RulesScanner)
23
+ if (rel.startsWith('.claude/rules/'))
24
+ continue;
25
+ // Skip examples (handled by ExamplesScanner)
26
+ if (rel.startsWith('.claude/examples/'))
27
+ continue;
28
+ try {
29
+ const abs = path.join(this.projectRoot, rel);
30
+ const content = fs.readFileSync(abs, 'utf-8');
31
+ // Extract H1 and H2 headings as knowledge units
32
+ const headings = content.match(/^#{1,2}\s+(.+)$/gm);
33
+ if (!headings || headings.length === 0)
34
+ continue;
35
+ let fileH1 = '';
36
+ for (const heading of headings) {
37
+ const level = heading.match(/^(#+)/)?.[1].length || 1;
38
+ const title = heading.replace(/^#+\s+/, '').trim();
39
+ if (!title)
40
+ continue;
41
+ if (level === 1) {
42
+ fileH1 = title;
43
+ }
44
+ const safeTitle = title
45
+ .replace(/[^a-zA-Z0-9\u4e00-\u9fff\-_\s]/g, '')
46
+ .replace(/\s+/g, '_')
47
+ .slice(0, 60)
48
+ .toLowerCase();
49
+ if (!safeTitle || safeTitle === '_')
50
+ continue;
51
+ const safeFile = path.basename(rel)
52
+ .replace('.md', '')
53
+ .replace(/[^a-zA-Z0-9\-_]/g, '_')
54
+ .slice(0, 30)
55
+ .toLowerCase();
56
+ units.push({
57
+ id: `doc_${safeFile}_${safeTitle}`,
58
+ type: 'pattern',
59
+ summary: `${path.basename(rel)} → ${title}`,
60
+ source: { file: rel },
61
+ signatures: [title, path.basename(rel).replace('.md', '')],
62
+ content: {
63
+ description: `${fileH1 ? fileH1 + ' — ' : ''}${title}`,
64
+ },
65
+ associations: [],
66
+ meta: {
67
+ created: new Date().toISOString(),
68
+ updated: new Date().toISOString(),
69
+ confidence: 0.5, // lower confidence — docs may be stale
70
+ usage_count: 0,
71
+ status: 'active',
72
+ },
73
+ });
74
+ }
75
+ }
76
+ catch { /* skip unreadable */ }
77
+ }
78
+ return units;
79
+ }
80
+ async scanFiles(files, _options) {
81
+ // Could be smarter here — for now, full re-scan is fine
82
+ return this.scan(_options);
83
+ }
84
+ findMdFiles(projectRoot) {
85
+ const files = [];
86
+ const walk = (dir) => {
87
+ if (!fs.existsSync(dir))
88
+ return;
89
+ for (const entry of fs.readdirSync(dir, { withFileTypes: true })) {
90
+ const abs = path.join(dir, entry.name);
91
+ const rel = path.relative(projectRoot, abs);
92
+ if (entry.isDirectory()) {
93
+ if (entry.name.startsWith('.') || entry.name === 'node_modules' || entry.name === 'target')
94
+ continue;
95
+ walk(abs);
96
+ }
97
+ else if (entry.name.endsWith('.md') && !entry.name.startsWith('.')) {
98
+ files.push(rel);
99
+ }
100
+ }
101
+ };
102
+ walk(projectRoot);
103
+ return files;
104
+ }
105
+ }
106
+ //# sourceMappingURL=markdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown.js","sourceRoot":"","sources":["../../src/scanner/markdown.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import type { MemoryUnit, ScanOptions } from '../shared/types.js';
2
+ import type { Scanner } from './scanner.js';
3
+ /**
4
+ * Python project scanner.
5
+ * Extracts functions, classes, methods, decorators via regex-based parsing.
6
+ */
7
+ export declare class PythonScanner implements Scanner {
8
+ readonly name = "python";
9
+ private projectRoot;
10
+ constructor(_store: any, projectRoot: string);
11
+ detect(projectRoot: string): boolean;
12
+ scan(_options: ScanOptions): Promise<MemoryUnit[]>;
13
+ private scanDir;
14
+ private parsePythonFile;
15
+ private extractDoc;
16
+ private findSourceDirs;
17
+ private sanitizeId;
18
+ }
19
+ //# sourceMappingURL=python.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"python.d.ts","sourceRoot":"","sources":["../../src/scanner/python.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAClE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAE5C;;;GAGG;AACH,qBAAa,aAAc,YAAW,OAAO;IAC3C,QAAQ,CAAC,IAAI,YAAY;IACzB,OAAO,CAAC,WAAW,CAAS;gBAEhB,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM;IAI5C,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;IAU9B,IAAI,CAAC,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;YAoB1C,OAAO;IAsBrB,OAAO,CAAC,eAAe;IA6FvB,OAAO,CAAC,UAAU;IAclB,OAAO,CAAC,cAAc;IAWtB,OAAO,CAAC,UAAU;CASnB"}