@processfork/sdk 1.0.0 → 1.0.1

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 +53 -0
  2. package/index.js +320 -0
  3. package/package.json +5 -3
package/index.d.ts ADDED
@@ -0,0 +1,53 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ /** `digestOf(bytes: Buffer): string` — SHA-256 of bytes, OCI-style. */
7
+ export declare function digestOf(bytes: Array<number>): string
8
+ /** Plain old JS object for one chat message. */
9
+ export interface Message {
10
+ role: string
11
+ content: string
12
+ }
13
+ /** `snapshotFilesystem(store, agentKind, fsRoot, env, messages): string` */
14
+ export declare function snapshotFilesystem(store: PfStore, agentKind: string, fsRoot: string, env: Record<string, string>, messages: Array<Message>): string
15
+ /**
16
+ * `checkoutFilesystem(store, cid, targetPath): void`. `targetPath` MUST NOT
17
+ * already exist.
18
+ */
19
+ export declare function checkoutFilesystem(store: PfStore, cid: string, targetPath: string): void
20
+ /**
21
+ * `readManifest(store, cid): string` — returns the manifest JSON as a
22
+ * string. The TS wrapper at `ts/index.ts` JSON-parses for callers that
23
+ * want a typed object.
24
+ */
25
+ export declare function readManifest(store: PfStore, cid: string): string
26
+ export interface WorldConflict {
27
+ path: string
28
+ aDigest: string
29
+ bDigest: string
30
+ xDigest?: string
31
+ }
32
+ export interface MergeReport {
33
+ mergedCid: string
34
+ ancestor: string
35
+ overall: string
36
+ worldConflicts: Array<WorldConflict>
37
+ traceSummary: string
38
+ modelAppliedTaskArithmetic: boolean
39
+ }
40
+ export interface MergeOpts {
41
+ alpha?: number
42
+ dareP?: number
43
+ seed?: number
44
+ }
45
+ /** `merge(store, a, b, opts?): MergeReport` — three-way merge B into A. */
46
+ export declare function merge(store: PfStore, a: string, b: string, opts?: MergeOpts | undefined | null): MergeReport
47
+ /** JS-side handle to a `pf_core::store::PfStore`. Cheap to clone (Arc'd). */
48
+ export declare class PfStore {
49
+ /** Open (or create) a ProcessFork store at `path`. `~` is expanded. */
50
+ static open(path: string): PfStore
51
+ /** Total compressed bytes on disk. */
52
+ physicalBytes(): number
53
+ }
package/index.js ADDED
@@ -0,0 +1,320 @@
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, 'processfork.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./processfork.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('@processfork/sdk-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'processfork.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./processfork.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('@processfork/sdk-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, 'processfork.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./processfork.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('@processfork/sdk-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'processfork.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./processfork.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('@processfork/sdk-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'processfork.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./processfork.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('@processfork/sdk-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, 'processfork.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./processfork.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('@processfork/sdk-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'processfork.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./processfork.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('@processfork/sdk-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'processfork.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./processfork.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('@processfork/sdk-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, 'processfork.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./processfork.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('@processfork/sdk-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, 'processfork.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./processfork.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('@processfork/sdk-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'processfork.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./processfork.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('@processfork/sdk-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, 'processfork.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./processfork.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('@processfork/sdk-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'processfork.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./processfork.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('@processfork/sdk-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, 'processfork.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./processfork.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('@processfork/sdk-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'processfork.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./processfork.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('@processfork/sdk-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, 'processfork.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./processfork.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('@processfork/sdk-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'processfork.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./processfork.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('@processfork/sdk-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'processfork.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./processfork.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('@processfork/sdk-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 { digestOf, PfStore, snapshotFilesystem, checkoutFilesystem, readManifest, merge } = nativeBinding
314
+
315
+ module.exports.digestOf = digestOf
316
+ module.exports.PfStore = PfStore
317
+ module.exports.snapshotFilesystem = snapshotFilesystem
318
+ module.exports.checkoutFilesystem = checkoutFilesystem
319
+ module.exports.readManifest = readManifest
320
+ module.exports.merge = merge
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@processfork/sdk",
3
- "version": "1.0.0",
3
+ "version": "1.0.1",
4
4
  "description": "ProcessFork — fork() for AI agents (TypeScript SDK).",
5
5
  "license": "MIT",
6
6
  "homepage": "https://github.com/manav8498/processfork",
@@ -9,9 +9,11 @@
9
9
  "url": "git+https://github.com/manav8498/processfork.git",
10
10
  "directory": "crates/pf-ts"
11
11
  },
12
- "main": "ts/index.js",
13
- "types": "ts/index.d.ts",
12
+ "main": "./index.js",
13
+ "types": "./index.d.ts",
14
14
  "files": [
15
+ "index.js",
16
+ "index.d.ts",
15
17
  "ts/",
16
18
  "*.node"
17
19
  ],