@xinleibird/bridge-opencode 0.0.2 → 0.0.3

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.

Potentially problematic release.


This version of @xinleibird/bridge-opencode might be problematic. Click here for more details.

Binary file
package/bridge.ts CHANGED
@@ -1,46 +1,10 @@
1
1
  import type { Plugin } from "@opencode-ai/plugin";
2
2
  import { isAbsolute, join } from "node:path";
3
- import { createRequire } from "node:module";
4
- import { fileURLToPath } from "node:url";
5
-
6
- const _require = createRequire(import.meta.url);
7
- const __dirname = join(fileURLToPath(import.meta.url), "..");
8
-
9
- const TRIPLES = [
10
- `bridge-opencode.${process.platform}-${process.arch}.node`,
11
- "bridge-opencode.node",
12
- ];
13
-
14
- let native: {
15
- checkBuffer(filePath: string): { isCurrent: boolean; hasUnsavedChanges: boolean };
16
- refreshBuffer(filePath: string): void;
17
- getVisualSelections(): Array<{
18
- filePath: string;
19
- startLine: number;
20
- endLine: number;
21
- cwd: string;
22
- content: string;
23
- }>;
24
- sendMessage(message: string): void;
25
- };
26
-
27
- for (const name of TRIPLES) {
28
- try {
29
- native = _require(join(__dirname, name));
30
- break;
31
- } catch {
32
- // try next triple
33
- }
34
- }
35
-
36
- if (!native) {
37
- throw new Error(
38
- "bridge-opencode: native addon not found (tried darwin-arm64 and generic). " +
39
- "Install with `npm install @xinleibird/bridge-opencode` to compile from source.",
40
- );
41
- }
42
-
43
- const { checkBuffer, refreshBuffer, getVisualSelections } = native;
3
+ import {
4
+ checkBuffer,
5
+ refreshBuffer,
6
+ getVisualSelections,
7
+ } from "./index.cjs";
44
8
 
45
9
  type ToolName = "Edit" | "Write";
46
10
 
package/index.cjs ADDED
@@ -0,0 +1,318 @@
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, 'bridge-opencode.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./bridge-opencode.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('@xinleibird/bridge-opencode-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'bridge-opencode.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./bridge-opencode.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./bridge-opencode.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('@xinleibird/bridge-opencode-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'bridge-opencode.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./bridge-opencode.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('@xinleibird/bridge-opencode-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'bridge-opencode.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./bridge-opencode.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./bridge-opencode.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('@xinleibird/bridge-opencode-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'bridge-opencode.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./bridge-opencode.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('@xinleibird/bridge-opencode-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'bridge-opencode.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./bridge-opencode.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./bridge-opencode.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./bridge-opencode.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('@xinleibird/bridge-opencode-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'bridge-opencode.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./bridge-opencode.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./bridge-opencode.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('@xinleibird/bridge-opencode-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'bridge-opencode.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./bridge-opencode.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./bridge-opencode.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('@xinleibird/bridge-opencode-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'bridge-opencode.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./bridge-opencode.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('@xinleibird/bridge-opencode-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, 'bridge-opencode.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./bridge-opencode.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('@xinleibird/bridge-opencode-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'bridge-opencode.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./bridge-opencode.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('@xinleibird/bridge-opencode-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'bridge-opencode.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./bridge-opencode.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('@xinleibird/bridge-opencode-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 { checkBuffer, refreshBuffer, getVisualSelections, sendMessage } = nativeBinding
314
+
315
+ module.exports.checkBuffer = checkBuffer
316
+ module.exports.refreshBuffer = refreshBuffer
317
+ module.exports.getVisualSelections = getVisualSelections
318
+ module.exports.sendMessage = sendMessage
package/index.d.ts ADDED
@@ -0,0 +1,20 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ export interface BufferStatus {
7
+ isCurrent: boolean
8
+ hasUnsavedChanges: boolean
9
+ }
10
+ export interface EditorContext {
11
+ filePath: string
12
+ startLine: number
13
+ endLine: number
14
+ cwd: string
15
+ content: string
16
+ }
17
+ export declare function checkBuffer(filePath: string): BufferStatus
18
+ export declare function refreshBuffer(filePath: string): void
19
+ export declare function getVisualSelections(): Array<EditorContext>
20
+ export declare function sendMessage(message: string): void
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xinleibird/bridge-opencode",
3
- "version": "0.0.2",
3
+ "version": "0.0.3",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -13,7 +13,7 @@
13
13
  }
14
14
  },
15
15
  "scripts": {
16
- "build": "napi build --platform --release"
16
+ "build": "napi build --platform --release --features napi --js index.cjs"
17
17
  },
18
18
  "napi": {
19
19
  "name": "bridge-opencode",
@@ -1,3 +0,0 @@
1
- [alias]
2
- check-all = "check --features napi"
3
- build-release = "build --release --features napi"