file-context-tree 1.0.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 (5) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +120 -0
  3. package/index.d.ts +31 -0
  4. package/index.js +575 -0
  5. package/package.json +120 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Ashutosh Paliwal
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,120 @@
1
+ <div align="center">
2
+
3
+ # ⚡️ F I L E - C O N T E X T - T R E E
4
+
5
+ **The High-Performance AST Scanner for the Modern Web**
6
+
7
+ [![CI Status](https://img.shields.io/github/actions/workflow/status/YOUR_USERNAME/file-context-tree/CI.yml?style=for-the-badge&logo=github&labelColor=18181b&color=22c55e)](https://github.com/YOUR_USERNAME/file-context-tree/actions)
8
+ [![NPM Version](https://img.shields.io/npm/v/file-context-tree?style=for-the-badge&logo=npm&labelColor=18181b&color=cb3030)](https://www.npmjs.com/package/file-context-tree)
9
+ [![Built With Rust](https://img.shields.io/badge/Powered_By-Rust-orange?style=for-the-badge&logo=rust&labelColor=18181b&color=ef4444)](https://www.rust-lang.org/)
10
+ [![License](https://img.shields.io/npm/l/file-context-tree?style=for-the-badge&labelColor=18181b&color=3b82f6)](LICENSE)
11
+
12
+ <br />
13
+
14
+ **Give your AI Agents "Eyes" into your codebase.**
15
+ <br />
16
+ *Scan 10,000 files in seconds. Extract symbols instantly. Zero overhead.*
17
+
18
+ [Report Bug](https://github.com/YOUR_USERNAME/file-context-tree/issues) · [Request Feature](https://github.com/YOUR_USERNAME/file-context-tree/issues)
19
+
20
+ </div>
21
+
22
+ ---
23
+
24
+ ## 🔮 The Problem
25
+ Node.js is fantastic, but it struggles with heavy computation. Trying to parse thousands of TypeScript or Python files in a single thread is slow, fragile, and memory-intensive.
26
+
27
+ ## ⚡️ The Solution: **Code X-Ray**
28
+ We moved the heavy lifting to **Rust**.
29
+ By bridging Node.js with a compiled Rust binary, we bypass the event loop entirely, utilizing **Parallel Computing** to scan your project at the speed of disk I/O.
30
+
31
+ ### 🔥 Why Developers Choose X-Ray
32
+
33
+ | 🚀 Blazing Performance | 🛡️ Bulletproof Safety | 🧠 Intelligent Parsing |
34
+ | :--- | :--- | :--- |
35
+ | Uses `Rayon` to multithread across all CPU cores. Scans **~1.5ms per file**. | Sandboxed file access. Respects `.gitignore` automatically. No crashes. | Powered by **Tree-Sitter**. Understands code structure, not just regex matches. |
36
+
37
+ ---
38
+
39
+ ## 📦 Installation
40
+
41
+ Add it to your project with a single command. It detects your OS (Windows/Linux/Mac) and downloads the correct optimized binary automatically.
42
+
43
+ ```bash
44
+ npm install file-context-tree
45
+
46
+ ```
47
+ 💻 Developer Experience
48
+ We designed Code X-Ray to feel like a native part of your toolchain. It’s fully typed, asynchronous-ready, and zero-config.
49
+
50
+ 1. The "Hello World" Scan
51
+ Get a complete map of your project in 3 lines of code.
52
+
53
+ TypeScript
54
+ ```
55
+ import { scanProject } from 'file-context-tree';
56
+ ```
57
+ ## 🚀 Fire up the engine (scans recursively)
58
+ ```
59
+ console.time("✨ Magic Time");
60
+ const context = scanProject("./src");
61
+ console.timeEnd("✨ Magic Time");
62
+
63
+ console.log(`\n📦 Scanned ${context.files_scanned} files in ${context.duration_ms}ms`);
64
+ ```
65
+
66
+ ### 2. Powerful Filtering
67
+ Don't just scan—understand. Filter the raw AST data to find exactly what you need.
68
+
69
+ TypeScript
70
+ ```
71
+ // Example: Find all 'TODO' comments or specific function definitions
72
+ const context = scanProject("./src");
73
+
74
+ // 🔍 Filter for TypeScript functions only
75
+ const functions = context.files
76
+ .filter(f => f.language === 'TypeScript')
77
+ .flatMap(f => f.symbols)
78
+ .filter(s => s.kind === 'function');
79
+
80
+ console.table(functions.map(fn => ({
81
+ Name: fn.name,
82
+ Location: `L${fn.start.row}:${fn.start.column}`,
83
+ Signature: fn.signature || '(unknown)'
84
+ })));
85
+ ```
86
+ ### 3. The "Context" Payload
87
+ The engine returns a clean, highly-structured JSON object optimized for LLM Context Windows (GPT-4, Claude, Llama 3).
88
+
89
+ <details> <summary><b>👀 Click to view sample JSON Output</b></summary>
90
+
91
+ JSON
92
+ ```
93
+ {
94
+ "root_dir": "./src",
95
+ "stats": {
96
+ "duration_ms": 142.5,
97
+ "files_processed": 45,
98
+ "threads_active": 12
99
+ },
100
+ "files": [
101
+ {
102
+ "path": "src/services/auth.ts",
103
+ "language": "TypeScript",
104
+ "size": 2048,
105
+ "symbols": [
106
+ {
107
+ "name": "authenticateUser",
108
+ "kind": "function",
109
+ "range": {
110
+ "start": { "row": 15, "col": 0 },
111
+ "end": { "row": 25, "col": 1 }
112
+ },
113
+ "signature": "async (token: string) => Promise<User>"
114
+ }
115
+ ]
116
+ }
117
+ ]
118
+ }
119
+ ```
120
+ </details>
package/index.d.ts ADDED
@@ -0,0 +1,31 @@
1
+ /* auto-generated by NAPI-RS */
2
+ /* eslint-disable */
3
+ export interface CodeSymbol {
4
+ name: string
5
+ kind: string
6
+ start: SourceLocation
7
+ end: SourceLocation
8
+ signature: string
9
+ }
10
+
11
+ export interface FileReport {
12
+ path: string
13
+ language: string
14
+ sizeBytes: number
15
+ symbols: Array<CodeSymbol>
16
+ error?: string
17
+ }
18
+
19
+ export declare function scanProject(rootPath: string): ScanResult
20
+
21
+ export interface ScanResult {
22
+ rootDir: string
23
+ durationMs: number
24
+ filesScanned: number
25
+ files: Array<FileReport>
26
+ }
27
+
28
+ export interface SourceLocation {
29
+ row: number
30
+ column: number
31
+ }
package/index.js ADDED
@@ -0,0 +1,575 @@
1
+ // prettier-ignore
2
+ /* eslint-disable */
3
+ // @ts-nocheck
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ const { readFileSync } = require('node:fs')
7
+ let nativeBinding = null
8
+ const loadErrors = []
9
+
10
+ const isMusl = () => {
11
+ let musl = false
12
+ if (process.platform === 'linux') {
13
+ musl = isMuslFromFilesystem()
14
+ if (musl === null) {
15
+ musl = isMuslFromReport()
16
+ }
17
+ if (musl === null) {
18
+ musl = isMuslFromChildProcess()
19
+ }
20
+ }
21
+ return musl
22
+ }
23
+
24
+ const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-')
25
+
26
+ const isMuslFromFilesystem = () => {
27
+ try {
28
+ return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl')
29
+ } catch {
30
+ return null
31
+ }
32
+ }
33
+
34
+ const isMuslFromReport = () => {
35
+ let report = null
36
+ if (typeof process.report?.getReport === 'function') {
37
+ process.report.excludeNetwork = true
38
+ report = process.report.getReport()
39
+ }
40
+ if (!report) {
41
+ return null
42
+ }
43
+ if (report.header && report.header.glibcVersionRuntime) {
44
+ return false
45
+ }
46
+ if (Array.isArray(report.sharedObjects)) {
47
+ if (report.sharedObjects.some(isFileMusl)) {
48
+ return true
49
+ }
50
+ }
51
+ return false
52
+ }
53
+
54
+ const isMuslFromChildProcess = () => {
55
+ try {
56
+ return require('child_process').execSync('ldd --version', { encoding: 'utf8' }).includes('musl')
57
+ } catch (e) {
58
+ // If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false
59
+ return false
60
+ }
61
+ }
62
+
63
+ function requireNative() {
64
+ if (process.env.NAPI_RS_NATIVE_LIBRARY_PATH) {
65
+ try {
66
+ return require(process.env.NAPI_RS_NATIVE_LIBRARY_PATH);
67
+ } catch (err) {
68
+ loadErrors.push(err)
69
+ }
70
+ } else if (process.platform === 'android') {
71
+ if (process.arch === 'arm64') {
72
+ try {
73
+ return require('./file-context-tree.android-arm64.node')
74
+ } catch (e) {
75
+ loadErrors.push(e)
76
+ }
77
+ try {
78
+ const binding = require('file-context-tree-android-arm64')
79
+ const bindingPackageVersion = require('file-context-tree-android-arm64/package.json').version
80
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
81
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
82
+ }
83
+ return binding
84
+ } catch (e) {
85
+ loadErrors.push(e)
86
+ }
87
+ } else if (process.arch === 'arm') {
88
+ try {
89
+ return require('./file-context-tree.android-arm-eabi.node')
90
+ } catch (e) {
91
+ loadErrors.push(e)
92
+ }
93
+ try {
94
+ const binding = require('file-context-tree-android-arm-eabi')
95
+ const bindingPackageVersion = require('file-context-tree-android-arm-eabi/package.json').version
96
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
97
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
98
+ }
99
+ return binding
100
+ } catch (e) {
101
+ loadErrors.push(e)
102
+ }
103
+ } else {
104
+ loadErrors.push(new Error(`Unsupported architecture on Android ${process.arch}`))
105
+ }
106
+ } else if (process.platform === 'win32') {
107
+ if (process.arch === 'x64') {
108
+ if (process.config?.variables?.shlib_suffix === 'dll.a' || process.config?.variables?.node_target_type === 'shared_library') {
109
+ try {
110
+ return require('./file-context-tree.win32-x64-gnu.node')
111
+ } catch (e) {
112
+ loadErrors.push(e)
113
+ }
114
+ try {
115
+ const binding = require('file-context-tree-win32-x64-gnu')
116
+ const bindingPackageVersion = require('file-context-tree-win32-x64-gnu/package.json').version
117
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
118
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
119
+ }
120
+ return binding
121
+ } catch (e) {
122
+ loadErrors.push(e)
123
+ }
124
+ } else {
125
+ try {
126
+ return require('./file-context-tree.win32-x64-msvc.node')
127
+ } catch (e) {
128
+ loadErrors.push(e)
129
+ }
130
+ try {
131
+ const binding = require('file-context-tree-win32-x64-msvc')
132
+ const bindingPackageVersion = require('file-context-tree-win32-x64-msvc/package.json').version
133
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
134
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
135
+ }
136
+ return binding
137
+ } catch (e) {
138
+ loadErrors.push(e)
139
+ }
140
+ }
141
+ } else if (process.arch === 'ia32') {
142
+ try {
143
+ return require('./file-context-tree.win32-ia32-msvc.node')
144
+ } catch (e) {
145
+ loadErrors.push(e)
146
+ }
147
+ try {
148
+ const binding = require('file-context-tree-win32-ia32-msvc')
149
+ const bindingPackageVersion = require('file-context-tree-win32-ia32-msvc/package.json').version
150
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
151
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
152
+ }
153
+ return binding
154
+ } catch (e) {
155
+ loadErrors.push(e)
156
+ }
157
+ } else if (process.arch === 'arm64') {
158
+ try {
159
+ return require('./file-context-tree.win32-arm64-msvc.node')
160
+ } catch (e) {
161
+ loadErrors.push(e)
162
+ }
163
+ try {
164
+ const binding = require('file-context-tree-win32-arm64-msvc')
165
+ const bindingPackageVersion = require('file-context-tree-win32-arm64-msvc/package.json').version
166
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
167
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
168
+ }
169
+ return binding
170
+ } catch (e) {
171
+ loadErrors.push(e)
172
+ }
173
+ } else {
174
+ loadErrors.push(new Error(`Unsupported architecture on Windows: ${process.arch}`))
175
+ }
176
+ } else if (process.platform === 'darwin') {
177
+ try {
178
+ return require('./file-context-tree.darwin-universal.node')
179
+ } catch (e) {
180
+ loadErrors.push(e)
181
+ }
182
+ try {
183
+ const binding = require('file-context-tree-darwin-universal')
184
+ const bindingPackageVersion = require('file-context-tree-darwin-universal/package.json').version
185
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
186
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
187
+ }
188
+ return binding
189
+ } catch (e) {
190
+ loadErrors.push(e)
191
+ }
192
+ if (process.arch === 'x64') {
193
+ try {
194
+ return require('./file-context-tree.darwin-x64.node')
195
+ } catch (e) {
196
+ loadErrors.push(e)
197
+ }
198
+ try {
199
+ const binding = require('file-context-tree-darwin-x64')
200
+ const bindingPackageVersion = require('file-context-tree-darwin-x64/package.json').version
201
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
202
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
203
+ }
204
+ return binding
205
+ } catch (e) {
206
+ loadErrors.push(e)
207
+ }
208
+ } else if (process.arch === 'arm64') {
209
+ try {
210
+ return require('./file-context-tree.darwin-arm64.node')
211
+ } catch (e) {
212
+ loadErrors.push(e)
213
+ }
214
+ try {
215
+ const binding = require('file-context-tree-darwin-arm64')
216
+ const bindingPackageVersion = require('file-context-tree-darwin-arm64/package.json').version
217
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
218
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
219
+ }
220
+ return binding
221
+ } catch (e) {
222
+ loadErrors.push(e)
223
+ }
224
+ } else {
225
+ loadErrors.push(new Error(`Unsupported architecture on macOS: ${process.arch}`))
226
+ }
227
+ } else if (process.platform === 'freebsd') {
228
+ if (process.arch === 'x64') {
229
+ try {
230
+ return require('./file-context-tree.freebsd-x64.node')
231
+ } catch (e) {
232
+ loadErrors.push(e)
233
+ }
234
+ try {
235
+ const binding = require('file-context-tree-freebsd-x64')
236
+ const bindingPackageVersion = require('file-context-tree-freebsd-x64/package.json').version
237
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
238
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
239
+ }
240
+ return binding
241
+ } catch (e) {
242
+ loadErrors.push(e)
243
+ }
244
+ } else if (process.arch === 'arm64') {
245
+ try {
246
+ return require('./file-context-tree.freebsd-arm64.node')
247
+ } catch (e) {
248
+ loadErrors.push(e)
249
+ }
250
+ try {
251
+ const binding = require('file-context-tree-freebsd-arm64')
252
+ const bindingPackageVersion = require('file-context-tree-freebsd-arm64/package.json').version
253
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
254
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
255
+ }
256
+ return binding
257
+ } catch (e) {
258
+ loadErrors.push(e)
259
+ }
260
+ } else {
261
+ loadErrors.push(new Error(`Unsupported architecture on FreeBSD: ${process.arch}`))
262
+ }
263
+ } else if (process.platform === 'linux') {
264
+ if (process.arch === 'x64') {
265
+ if (isMusl()) {
266
+ try {
267
+ return require('./file-context-tree.linux-x64-musl.node')
268
+ } catch (e) {
269
+ loadErrors.push(e)
270
+ }
271
+ try {
272
+ const binding = require('file-context-tree-linux-x64-musl')
273
+ const bindingPackageVersion = require('file-context-tree-linux-x64-musl/package.json').version
274
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
275
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
276
+ }
277
+ return binding
278
+ } catch (e) {
279
+ loadErrors.push(e)
280
+ }
281
+ } else {
282
+ try {
283
+ return require('./file-context-tree.linux-x64-gnu.node')
284
+ } catch (e) {
285
+ loadErrors.push(e)
286
+ }
287
+ try {
288
+ const binding = require('file-context-tree-linux-x64-gnu')
289
+ const bindingPackageVersion = require('file-context-tree-linux-x64-gnu/package.json').version
290
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
291
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
292
+ }
293
+ return binding
294
+ } catch (e) {
295
+ loadErrors.push(e)
296
+ }
297
+ }
298
+ } else if (process.arch === 'arm64') {
299
+ if (isMusl()) {
300
+ try {
301
+ return require('./file-context-tree.linux-arm64-musl.node')
302
+ } catch (e) {
303
+ loadErrors.push(e)
304
+ }
305
+ try {
306
+ const binding = require('file-context-tree-linux-arm64-musl')
307
+ const bindingPackageVersion = require('file-context-tree-linux-arm64-musl/package.json').version
308
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
309
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
310
+ }
311
+ return binding
312
+ } catch (e) {
313
+ loadErrors.push(e)
314
+ }
315
+ } else {
316
+ try {
317
+ return require('./file-context-tree.linux-arm64-gnu.node')
318
+ } catch (e) {
319
+ loadErrors.push(e)
320
+ }
321
+ try {
322
+ const binding = require('file-context-tree-linux-arm64-gnu')
323
+ const bindingPackageVersion = require('file-context-tree-linux-arm64-gnu/package.json').version
324
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
325
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
326
+ }
327
+ return binding
328
+ } catch (e) {
329
+ loadErrors.push(e)
330
+ }
331
+ }
332
+ } else if (process.arch === 'arm') {
333
+ if (isMusl()) {
334
+ try {
335
+ return require('./file-context-tree.linux-arm-musleabihf.node')
336
+ } catch (e) {
337
+ loadErrors.push(e)
338
+ }
339
+ try {
340
+ const binding = require('file-context-tree-linux-arm-musleabihf')
341
+ const bindingPackageVersion = require('file-context-tree-linux-arm-musleabihf/package.json').version
342
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
343
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
344
+ }
345
+ return binding
346
+ } catch (e) {
347
+ loadErrors.push(e)
348
+ }
349
+ } else {
350
+ try {
351
+ return require('./file-context-tree.linux-arm-gnueabihf.node')
352
+ } catch (e) {
353
+ loadErrors.push(e)
354
+ }
355
+ try {
356
+ const binding = require('file-context-tree-linux-arm-gnueabihf')
357
+ const bindingPackageVersion = require('file-context-tree-linux-arm-gnueabihf/package.json').version
358
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
359
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
360
+ }
361
+ return binding
362
+ } catch (e) {
363
+ loadErrors.push(e)
364
+ }
365
+ }
366
+ } else if (process.arch === 'loong64') {
367
+ if (isMusl()) {
368
+ try {
369
+ return require('./file-context-tree.linux-loong64-musl.node')
370
+ } catch (e) {
371
+ loadErrors.push(e)
372
+ }
373
+ try {
374
+ const binding = require('file-context-tree-linux-loong64-musl')
375
+ const bindingPackageVersion = require('file-context-tree-linux-loong64-musl/package.json').version
376
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
377
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
378
+ }
379
+ return binding
380
+ } catch (e) {
381
+ loadErrors.push(e)
382
+ }
383
+ } else {
384
+ try {
385
+ return require('./file-context-tree.linux-loong64-gnu.node')
386
+ } catch (e) {
387
+ loadErrors.push(e)
388
+ }
389
+ try {
390
+ const binding = require('file-context-tree-linux-loong64-gnu')
391
+ const bindingPackageVersion = require('file-context-tree-linux-loong64-gnu/package.json').version
392
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
393
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
394
+ }
395
+ return binding
396
+ } catch (e) {
397
+ loadErrors.push(e)
398
+ }
399
+ }
400
+ } else if (process.arch === 'riscv64') {
401
+ if (isMusl()) {
402
+ try {
403
+ return require('./file-context-tree.linux-riscv64-musl.node')
404
+ } catch (e) {
405
+ loadErrors.push(e)
406
+ }
407
+ try {
408
+ const binding = require('file-context-tree-linux-riscv64-musl')
409
+ const bindingPackageVersion = require('file-context-tree-linux-riscv64-musl/package.json').version
410
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
411
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
412
+ }
413
+ return binding
414
+ } catch (e) {
415
+ loadErrors.push(e)
416
+ }
417
+ } else {
418
+ try {
419
+ return require('./file-context-tree.linux-riscv64-gnu.node')
420
+ } catch (e) {
421
+ loadErrors.push(e)
422
+ }
423
+ try {
424
+ const binding = require('file-context-tree-linux-riscv64-gnu')
425
+ const bindingPackageVersion = require('file-context-tree-linux-riscv64-gnu/package.json').version
426
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
427
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
428
+ }
429
+ return binding
430
+ } catch (e) {
431
+ loadErrors.push(e)
432
+ }
433
+ }
434
+ } else if (process.arch === 'ppc64') {
435
+ try {
436
+ return require('./file-context-tree.linux-ppc64-gnu.node')
437
+ } catch (e) {
438
+ loadErrors.push(e)
439
+ }
440
+ try {
441
+ const binding = require('file-context-tree-linux-ppc64-gnu')
442
+ const bindingPackageVersion = require('file-context-tree-linux-ppc64-gnu/package.json').version
443
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
444
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
445
+ }
446
+ return binding
447
+ } catch (e) {
448
+ loadErrors.push(e)
449
+ }
450
+ } else if (process.arch === 's390x') {
451
+ try {
452
+ return require('./file-context-tree.linux-s390x-gnu.node')
453
+ } catch (e) {
454
+ loadErrors.push(e)
455
+ }
456
+ try {
457
+ const binding = require('file-context-tree-linux-s390x-gnu')
458
+ const bindingPackageVersion = require('file-context-tree-linux-s390x-gnu/package.json').version
459
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
460
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
461
+ }
462
+ return binding
463
+ } catch (e) {
464
+ loadErrors.push(e)
465
+ }
466
+ } else {
467
+ loadErrors.push(new Error(`Unsupported architecture on Linux: ${process.arch}`))
468
+ }
469
+ } else if (process.platform === 'openharmony') {
470
+ if (process.arch === 'arm64') {
471
+ try {
472
+ return require('./file-context-tree.openharmony-arm64.node')
473
+ } catch (e) {
474
+ loadErrors.push(e)
475
+ }
476
+ try {
477
+ const binding = require('file-context-tree-openharmony-arm64')
478
+ const bindingPackageVersion = require('file-context-tree-openharmony-arm64/package.json').version
479
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
480
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
481
+ }
482
+ return binding
483
+ } catch (e) {
484
+ loadErrors.push(e)
485
+ }
486
+ } else if (process.arch === 'x64') {
487
+ try {
488
+ return require('./file-context-tree.openharmony-x64.node')
489
+ } catch (e) {
490
+ loadErrors.push(e)
491
+ }
492
+ try {
493
+ const binding = require('file-context-tree-openharmony-x64')
494
+ const bindingPackageVersion = require('file-context-tree-openharmony-x64/package.json').version
495
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
496
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
497
+ }
498
+ return binding
499
+ } catch (e) {
500
+ loadErrors.push(e)
501
+ }
502
+ } else if (process.arch === 'arm') {
503
+ try {
504
+ return require('./file-context-tree.openharmony-arm.node')
505
+ } catch (e) {
506
+ loadErrors.push(e)
507
+ }
508
+ try {
509
+ const binding = require('file-context-tree-openharmony-arm')
510
+ const bindingPackageVersion = require('file-context-tree-openharmony-arm/package.json').version
511
+ if (bindingPackageVersion !== '1.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
512
+ throw new Error(`Native binding package version mismatch, expected 1.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
513
+ }
514
+ return binding
515
+ } catch (e) {
516
+ loadErrors.push(e)
517
+ }
518
+ } else {
519
+ loadErrors.push(new Error(`Unsupported architecture on OpenHarmony: ${process.arch}`))
520
+ }
521
+ } else {
522
+ loadErrors.push(new Error(`Unsupported OS: ${process.platform}, architecture: ${process.arch}`))
523
+ }
524
+ }
525
+
526
+ nativeBinding = requireNative()
527
+
528
+ if (!nativeBinding || process.env.NAPI_RS_FORCE_WASI) {
529
+ let wasiBinding = null
530
+ let wasiBindingError = null
531
+ try {
532
+ wasiBinding = require('./file-context-tree.wasi.cjs')
533
+ nativeBinding = wasiBinding
534
+ } catch (err) {
535
+ if (process.env.NAPI_RS_FORCE_WASI) {
536
+ wasiBindingError = err
537
+ }
538
+ }
539
+ if (!nativeBinding) {
540
+ try {
541
+ wasiBinding = require('file-context-tree-wasm32-wasi')
542
+ nativeBinding = wasiBinding
543
+ } catch (err) {
544
+ if (process.env.NAPI_RS_FORCE_WASI) {
545
+ wasiBindingError.cause = err
546
+ loadErrors.push(err)
547
+ }
548
+ }
549
+ }
550
+ if (process.env.NAPI_RS_FORCE_WASI === 'error' && !wasiBinding) {
551
+ const error = new Error('WASI binding not found and NAPI_RS_FORCE_WASI is set to error')
552
+ error.cause = wasiBindingError
553
+ throw error
554
+ }
555
+ }
556
+
557
+ if (!nativeBinding) {
558
+ if (loadErrors.length > 0) {
559
+ throw new Error(
560
+ `Cannot find native binding. ` +
561
+ `npm has a bug related to optional dependencies (https://github.com/npm/cli/issues/4828). ` +
562
+ 'Please try `npm i` again after removing both package-lock.json and node_modules directory.',
563
+ {
564
+ cause: loadErrors.reduce((err, cur) => {
565
+ cur.cause = err
566
+ return cur
567
+ }),
568
+ },
569
+ )
570
+ }
571
+ throw new Error(`Failed to load native binding`)
572
+ }
573
+
574
+ module.exports = nativeBinding
575
+ module.exports.scanProject = nativeBinding.scanProject
package/package.json ADDED
@@ -0,0 +1,120 @@
1
+ {
2
+ "name": "file-context-tree",
3
+ "version": "1.0.0",
4
+ "description": "High-performance file context generator for Node.js",
5
+ "main": "index.js",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "https://github.com/ashutoshpaliwal26/file-context-tree.git"
9
+ },
10
+ "license": "MIT",
11
+ "browser": "browser.js",
12
+ "keywords": [
13
+ "napi-rs",
14
+ "NAPI",
15
+ "N-API",
16
+ "Rust",
17
+ "node-addon",
18
+ "ast",
19
+ "parser"
20
+ ],
21
+ "files": [
22
+ "index.d.ts",
23
+ "index.js",
24
+ "browser.js"
25
+ ],
26
+ "napi": {
27
+ "binaryName": "file-context-tree",
28
+ "targets": [
29
+ "x86_64-unknown-linux-gnu",
30
+ "x86_64-pc-windows-msvc",
31
+ "x86_64-apple-darwin",
32
+ "aarch64-apple-darwin"
33
+ ],
34
+ "packageJson": {
35
+ "publishConfig": {
36
+ "access": "public",
37
+ "registry": "https://registry.npmjs.org/"
38
+ }
39
+ }
40
+ },
41
+ "optionalDependencies": {
42
+ "file-context-tree-linux-x64-gnu": "1.0.0",
43
+ "file-context-tree-win32-x64-msvc": "1.0.0",
44
+ "file-context-tree-darwin-x64": "1.0.0",
45
+ "file-context-tree-darwin-arm64": "1.0.0"
46
+ },
47
+ "engines": {
48
+ "node": ">= 10.16.0 < 11 || >= 11.8.0 < 12 || >= 12.0.0"
49
+ },
50
+ "publishConfig": {
51
+ "registry": "https://registry.npmjs.org/",
52
+ "access": "public"
53
+ },
54
+ "scripts": {
55
+ "artifacts": "napi artifacts",
56
+ "bench": "node --import @oxc-node/core/register benchmark/bench.ts",
57
+ "build": "napi build --platform --release",
58
+ "build:debug": "napi build --platform",
59
+ "format": "run-p format:prettier format:rs format:toml",
60
+ "format:prettier": "prettier . -w",
61
+ "format:toml": "taplo format",
62
+ "format:rs": "cargo fmt",
63
+ "lint": "oxlint .",
64
+ "prepublishOnly": "napi prepublish -t npm",
65
+ "test": "ava",
66
+ "preversion": "napi build --platform && git add .",
67
+ "version": "napi version",
68
+ "prepare": "husky"
69
+ },
70
+ "devDependencies": {
71
+ "@emnapi/core": "^1.5.0",
72
+ "@emnapi/runtime": "^1.5.0",
73
+ "@napi-rs/cli": "^3.2.0",
74
+ "@oxc-node/core": "^0.0.35",
75
+ "@taplo/cli": "^0.7.0",
76
+ "@tybys/wasm-util": "^0.10.0",
77
+ "ava": "^6.4.1",
78
+ "chalk": "^5.6.2",
79
+ "husky": "^9.1.7",
80
+ "lint-staged": "^16.1.6",
81
+ "npm-run-all2": "^8.0.4",
82
+ "oxlint": "^1.14.0",
83
+ "prettier": "^3.6.2",
84
+ "tinybench": "^6.0.0",
85
+ "typescript": "^5.9.2"
86
+ },
87
+ "lint-staged": {
88
+ "*.@(js|ts|tsx)": [
89
+ "oxlint --fix"
90
+ ],
91
+ "*.@(js|ts|tsx|yml|yaml|md|json)": [
92
+ "prettier --write"
93
+ ],
94
+ "*.toml": [
95
+ "taplo format"
96
+ ]
97
+ },
98
+ "ava": {
99
+ "extensions": {
100
+ "ts": "module"
101
+ },
102
+ "timeout": "1m",
103
+ "workerThreads": false,
104
+ "environmentVariables": {
105
+ "OXC_TSCONFIG_PATH": "./__test__/tsconfig.json"
106
+ },
107
+ "nodeArguments": [
108
+ "--import",
109
+ "@oxc-node/core/register"
110
+ ]
111
+ },
112
+ "prettier": {
113
+ "printWidth": 120,
114
+ "semi": false,
115
+ "trailingComma": "all",
116
+ "singleQuote": true,
117
+ "arrowParens": "always"
118
+ },
119
+ "packageManager": "yarn@4.12.0"
120
+ }