polydup 0.6.0 → 0.6.2

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 (3) hide show
  1. package/index.d.ts +71 -0
  2. package/index.js +317 -0
  3. package/package.json +7 -7
package/index.d.ts ADDED
@@ -0,0 +1,71 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ /** Represents a duplicate match found by the scanner */
7
+ export interface DuplicateMatch {
8
+ file1: string
9
+ file2: string
10
+ startLine1: number
11
+ startLine2: number
12
+ length: number
13
+ similarity: number
14
+ hash: string
15
+ cloneType: string
16
+ editDistance?: number
17
+ }
18
+ /** Scan statistics */
19
+ export interface ScanStats {
20
+ totalLines: number
21
+ totalTokens: number
22
+ uniqueHashes: number
23
+ durationMs: number
24
+ }
25
+ /** Complete scan report */
26
+ export interface Report {
27
+ filesScanned: number
28
+ functionsAnalyzed: number
29
+ duplicates: Array<DuplicateMatch>
30
+ stats: ScanStats
31
+ }
32
+ /**
33
+ * Find duplicate code across multiple files
34
+ *
35
+ * This function runs asynchronously on a background thread to avoid
36
+ * blocking the Node.js event loop during the CPU-intensive scan operation.
37
+ *
38
+ * # Arguments
39
+ * * `paths` - Array of file or directory paths to scan
40
+ * * `min_block_size` - Minimum code block size in tokens (default: 50)
41
+ * * `threshold` - Similarity threshold 0.0-1.0 (default: 0.85)
42
+ *
43
+ * # Returns
44
+ * Promise that resolves to a Report object containing detected duplicates
45
+ *
46
+ * # Example
47
+ * ```javascript
48
+ * const { findDuplicates } = require('@polydup/core');
49
+ *
50
+ * findDuplicates(['./src', './lib'], 50, 0.85)
51
+ * .then(report => {
52
+ * console.log(`Found ${report.duplicates.length} duplicates`);
53
+ * console.log(`Scanned ${report.filesScanned} files in ${report.stats.durationMs}ms`);
54
+ * })
55
+ * .catch(err => console.error(err));
56
+ * ```
57
+ */
58
+ export declare function findDuplicates(paths: Array<string>, minBlockSize?: number | undefined | null, threshold?: number | undefined | null, enableType3?: boolean | undefined | null, type3Tolerance?: number | undefined | null): Promise<unknown>
59
+ /**
60
+ * Synchronous version of find_duplicates (blocks the event loop - use with caution!)
61
+ *
62
+ * Only use this for small codebases or CLI tools where blocking is acceptable.
63
+ *
64
+ * # Arguments
65
+ * * `paths` - Array of file or directory paths to scan
66
+ * * `min_block_size` - Minimum code block size in tokens (default: 50)
67
+ * * `threshold` - Similarity threshold 0.0-1.0 (default: 0.85)
68
+ */
69
+ export declare function findDuplicatesSync(paths: Array<string>, minBlockSize?: number | undefined | null, threshold?: number | undefined | null, enableType3?: boolean | undefined | null, type3Tolerance?: number | undefined | null): Report
70
+ /** Get the version of the PolyDup library */
71
+ export declare function version(): string
package/index.js ADDED
@@ -0,0 +1,317 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+ /* prettier-ignore */
4
+
5
+ /* auto-generated by NAPI-RS */
6
+
7
+ const { existsSync, readFileSync } = require('fs')
8
+ const { join } = require('path')
9
+
10
+ const { platform, arch } = process
11
+
12
+ let nativeBinding = null
13
+ let localFileExisted = false
14
+ let loadError = null
15
+
16
+ function isMusl() {
17
+ // For Node 10
18
+ if (!process.report || typeof process.report.getReport !== 'function') {
19
+ try {
20
+ const lddPath = require('child_process').execSync('which ldd').toString().trim()
21
+ return readFileSync(lddPath, 'utf8').includes('musl')
22
+ } catch (e) {
23
+ return true
24
+ }
25
+ } else {
26
+ const { glibcVersionRuntime } = process.report.getReport().header
27
+ return !glibcVersionRuntime
28
+ }
29
+ }
30
+
31
+ switch (platform) {
32
+ case 'android':
33
+ switch (arch) {
34
+ case 'arm64':
35
+ localFileExisted = existsSync(join(__dirname, 'polydup-node.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./polydup-node.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('polydup-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'polydup-node.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./polydup-node.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('polydup-android-arm-eabi')
53
+ }
54
+ } catch (e) {
55
+ loadError = e
56
+ }
57
+ break
58
+ default:
59
+ throw new Error(`Unsupported architecture on Android ${arch}`)
60
+ }
61
+ break
62
+ case 'win32':
63
+ switch (arch) {
64
+ case 'x64':
65
+ localFileExisted = existsSync(
66
+ join(__dirname, 'polydup-node.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./polydup-node.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('polydup-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'polydup-node.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./polydup-node.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('polydup-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'polydup-node.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./polydup-node.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('polydup-win32-arm64-msvc')
101
+ }
102
+ } catch (e) {
103
+ loadError = e
104
+ }
105
+ break
106
+ default:
107
+ throw new Error(`Unsupported architecture on Windows: ${arch}`)
108
+ }
109
+ break
110
+ case 'darwin':
111
+ localFileExisted = existsSync(join(__dirname, 'polydup-node.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./polydup-node.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('polydup-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'polydup-node.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./polydup-node.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('polydup-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'polydup-node.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./polydup-node.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('polydup-darwin-arm64')
142
+ }
143
+ } catch (e) {
144
+ loadError = e
145
+ }
146
+ break
147
+ default:
148
+ throw new Error(`Unsupported architecture on macOS: ${arch}`)
149
+ }
150
+ break
151
+ case 'freebsd':
152
+ if (arch !== 'x64') {
153
+ throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
154
+ }
155
+ localFileExisted = existsSync(join(__dirname, 'polydup-node.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./polydup-node.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('polydup-freebsd-x64')
161
+ }
162
+ } catch (e) {
163
+ loadError = e
164
+ }
165
+ break
166
+ case 'linux':
167
+ switch (arch) {
168
+ case 'x64':
169
+ if (isMusl()) {
170
+ localFileExisted = existsSync(
171
+ join(__dirname, 'polydup-node.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./polydup-node.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('polydup-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'polydup-node.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./polydup-node.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('polydup-linux-x64-gnu')
191
+ }
192
+ } catch (e) {
193
+ loadError = e
194
+ }
195
+ }
196
+ break
197
+ case 'arm64':
198
+ if (isMusl()) {
199
+ localFileExisted = existsSync(
200
+ join(__dirname, 'polydup-node.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./polydup-node.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('polydup-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'polydup-node.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./polydup-node.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('polydup-linux-arm64-gnu')
220
+ }
221
+ } catch (e) {
222
+ loadError = e
223
+ }
224
+ }
225
+ break
226
+ case 'arm':
227
+ if (isMusl()) {
228
+ localFileExisted = existsSync(
229
+ join(__dirname, 'polydup-node.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./polydup-node.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('polydup-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'polydup-node.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./polydup-node.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('polydup-linux-arm-gnueabihf')
249
+ }
250
+ } catch (e) {
251
+ loadError = e
252
+ }
253
+ }
254
+ break
255
+ case 'riscv64':
256
+ if (isMusl()) {
257
+ localFileExisted = existsSync(
258
+ join(__dirname, 'polydup-node.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./polydup-node.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('polydup-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'polydup-node.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./polydup-node.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('polydup-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'polydup-node.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./polydup-node.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('polydup-linux-s390x-gnu')
293
+ }
294
+ } catch (e) {
295
+ loadError = e
296
+ }
297
+ break
298
+ default:
299
+ throw new Error(`Unsupported architecture on Linux: ${arch}`)
300
+ }
301
+ break
302
+ default:
303
+ throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
304
+ }
305
+
306
+ if (!nativeBinding) {
307
+ if (loadError) {
308
+ throw loadError
309
+ }
310
+ throw new Error(`Failed to load native binding`)
311
+ }
312
+
313
+ const { findDuplicates, findDuplicatesSync, version } = nativeBinding
314
+
315
+ module.exports.findDuplicates = findDuplicates
316
+ module.exports.findDuplicatesSync = findDuplicatesSync
317
+ module.exports.version = version
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "polydup",
3
- "version": "0.6.0",
3
+ "version": "0.6.2",
4
4
  "description": "Cross-language duplicate code detector - Node.js bindings",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",
@@ -54,10 +54,10 @@
54
54
  "npm/**/*.node"
55
55
  ],
56
56
  "optionalDependencies": {
57
- "polydup-win32-x64-msvc": "0.1.1",
58
- "polydup-darwin-x64": "0.1.1",
59
- "polydup-linux-x64-gnu": "0.1.1",
60
- "polydup-darwin-arm64": "0.1.1",
61
- "polydup-linux-arm64-gnu": "0.1.1"
57
+ "polydup-win32-x64-msvc": "0.6.2",
58
+ "polydup-darwin-x64": "0.6.2",
59
+ "polydup-linux-x64-gnu": "0.6.2",
60
+ "polydup-darwin-arm64": "0.6.2",
61
+ "polydup-linux-arm64-gnu": "0.6.2"
62
62
  }
63
- }
63
+ }