@parcel/rust 2.9.4-nightly.2988

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.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2017-present Devon Govett
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/browser.js ADDED
@@ -0,0 +1,30 @@
1
+ /* eslint-disable no-undef */
2
+ const {Environment, napi} = require('napi-wasm');
3
+
4
+ module.exports.Resolver = undefined;
5
+ module.exports.init = async function init(input) {
6
+ if (module.exports.Resolver == null) {
7
+ // input = input ?? new URL('parcel_resolver_node.wasm', import.meta.url);
8
+ // const {instance} = await WebAssembly.instantiateStreaming(fetch(input), {
9
+ // env: napi,
10
+ // });
11
+
12
+ input =
13
+ input ?? require('path').join(__dirname, 'parcel_node_bindings.wasm');
14
+ const {instance} = await WebAssembly.instantiate(
15
+ require('fs').readFileSync(input),
16
+ {
17
+ env: napi,
18
+ },
19
+ );
20
+
21
+ for (let key in instance.exports) {
22
+ if (key.startsWith('__napi_register__')) {
23
+ instance.exports[key]();
24
+ }
25
+ }
26
+
27
+ let env = new Environment(instance);
28
+ Object.assign(module.exports, env.exports);
29
+ }
30
+ };
package/index.d.ts ADDED
@@ -0,0 +1,74 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ export function findAncestorFile(filenames: Array<string>, from: string, root: string): string | null
7
+ export function findFirstFile(names: Array<string>): string | null
8
+ export function findNodeModule(module: string, from: string): string | null
9
+ export function hashString(s: string): string
10
+ export function hashBuffer(buf: Buffer): string
11
+ export function optimizeImage(kind: string, buf: Buffer): Buffer
12
+ export interface JsFileSystemOptions {
13
+ canonicalize: (...args: any[]) => any
14
+ read: (...args: any[]) => any
15
+ isFile: (...args: any[]) => any
16
+ isDir: (...args: any[]) => any
17
+ includeNodeModules?: NapiSideEffectsVariants
18
+ }
19
+ export interface FileSystem {
20
+ fs?: JsFileSystemOptions
21
+ includeNodeModules?: NapiSideEffectsVariants
22
+ conditions?: number
23
+ moduleDirResolver?: (...args: any[]) => any
24
+ mode: number
25
+ entries?: number
26
+ extensions?: Array<string>
27
+ packageExports: boolean
28
+ }
29
+ export interface ResolveOptions {
30
+ filename: string
31
+ specifierType: string
32
+ parent: string
33
+ packageConditions?: Array<string>
34
+ }
35
+ export interface FilePathCreateInvalidation {
36
+ filePath: string
37
+ }
38
+ export interface FileNameCreateInvalidation {
39
+ fileName: string
40
+ aboveFilePath: string
41
+ }
42
+ export interface GlobCreateInvalidation {
43
+ glob: string
44
+ }
45
+ export interface ResolveResult {
46
+ resolution: unknown
47
+ invalidateOnFileChange: Array<string>
48
+ invalidateOnFileCreate: Array<FilePathCreateInvalidation | FileNameCreateInvalidation | GlobCreateInvalidation>
49
+ query?: string
50
+ sideEffects: boolean
51
+ error: unknown
52
+ moduleType: number
53
+ }
54
+ export interface JsInvalidations {
55
+ invalidateOnFileChange: Array<string>
56
+ invalidateOnFileCreate: Array<FilePathCreateInvalidation | FileNameCreateInvalidation | GlobCreateInvalidation>
57
+ invalidateOnStartup: boolean
58
+ }
59
+ export function transform(opts: object): unknown
60
+ export function transformAsync(opts: object): object
61
+ export class Hash {
62
+ constructor()
63
+ writeString(s: string): void
64
+ writeBuffer(buf: Buffer): void
65
+ finish(): string
66
+ }
67
+ export class Resolver {
68
+ constructor(projectRoot: string, options: FileSystem)
69
+ resolve(options: ResolveOptions): ResolveResult
70
+ resolveAsync(): object
71
+ resolveAsync(options: ResolveOptions): object
72
+ getInvalidations(path: string): JsInvalidations
73
+ getInvalidations(path: string): JsInvalidations
74
+ }
package/index.js ADDED
@@ -0,0 +1,266 @@
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, 'parcel-node-bindings.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./parcel-node-bindings.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('@parcel/rust-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'parcel-node-bindings.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./parcel-node-bindings.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('@parcel/rust-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, 'parcel-node-bindings.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./parcel-node-bindings.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('@parcel/rust-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'parcel-node-bindings.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./parcel-node-bindings.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('@parcel/rust-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'parcel-node-bindings.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./parcel-node-bindings.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('@parcel/rust-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, 'parcel-node-bindings.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./parcel-node-bindings.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('@parcel/rust-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'parcel-node-bindings.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./parcel-node-bindings.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('@parcel/rust-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'parcel-node-bindings.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./parcel-node-bindings.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('@parcel/rust-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, 'parcel-node-bindings.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./parcel-node-bindings.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('@parcel/rust-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, 'parcel-node-bindings.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./parcel-node-bindings.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('@parcel/rust-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'parcel-node-bindings.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./parcel-node-bindings.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('@parcel/rust-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, 'parcel-node-bindings.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./parcel-node-bindings.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('@parcel/rust-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'parcel-node-bindings.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./parcel-node-bindings.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('@parcel/rust-linux-arm64-gnu')
220
+ }
221
+ } catch (e) {
222
+ loadError = e
223
+ }
224
+ }
225
+ break
226
+ case 'arm':
227
+ localFileExisted = existsSync(
228
+ join(__dirname, 'parcel-node-bindings.linux-arm-gnueabihf.node')
229
+ )
230
+ try {
231
+ if (localFileExisted) {
232
+ nativeBinding = require('./parcel-node-bindings.linux-arm-gnueabihf.node')
233
+ } else {
234
+ nativeBinding = require('@parcel/rust-linux-arm-gnueabihf')
235
+ }
236
+ } catch (e) {
237
+ loadError = e
238
+ }
239
+ break
240
+ default:
241
+ throw new Error(`Unsupported architecture on Linux: ${arch}`)
242
+ }
243
+ break
244
+ default:
245
+ throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
246
+ }
247
+
248
+ if (!nativeBinding) {
249
+ if (loadError) {
250
+ throw loadError
251
+ }
252
+ throw new Error(`Failed to load native binding`)
253
+ }
254
+
255
+ const { findAncestorFile, findFirstFile, findNodeModule, hashString, hashBuffer, Hash, optimizeImage, Resolver, transform, transformAsync } = nativeBinding
256
+
257
+ module.exports.findAncestorFile = findAncestorFile
258
+ module.exports.findFirstFile = findFirstFile
259
+ module.exports.findNodeModule = findNodeModule
260
+ module.exports.hashString = hashString
261
+ module.exports.hashBuffer = hashBuffer
262
+ module.exports.Hash = Hash
263
+ module.exports.optimizeImage = optimizeImage
264
+ module.exports.Resolver = Resolver
265
+ module.exports.transform = transform
266
+ module.exports.transformAsync = transformAsync
package/index.js.flow ADDED
@@ -0,0 +1,77 @@
1
+ // @flow
2
+ import type {FileCreateInvalidation} from '@parcel/types';
3
+
4
+ declare export var init: void | (() => void);
5
+
6
+ declare export function findAncestorFile(filenames: Array<string>, from: string, root: string): string | null
7
+ declare export function findFirstFile(names: Array<string>): string | null
8
+ declare export function findNodeModule(module: string, from: string): string | null
9
+ declare export function hashString(s: string): string
10
+ declare export function hashBuffer(buf: Buffer): string
11
+ declare export function optimizeImage(kind: string, buf: Buffer): Buffer
12
+ export interface JsFileSystemOptions {
13
+ canonicalize: string => string;
14
+ read: string => Buffer;
15
+ isFile: string => boolean;
16
+ isDir: string => boolean;
17
+ includeNodeModules?: boolean | Array<string> | {|[string]: boolean|};
18
+ }
19
+ export interface FileSystem {
20
+ fs?: JsFileSystemOptions,
21
+ includeNodeModules?: boolean | Array<string> | {|[string]: boolean|};
22
+ conditions?: number,
23
+ moduleDirResolver?: (...args: any[]) => any,
24
+ mode: number,
25
+ entries?: number,
26
+ extensions?: Array<string>,
27
+ packageExports: boolean
28
+ }
29
+ export interface ResolveOptions {
30
+ filename: string;
31
+ specifierType: string;
32
+ parent: string;
33
+ packageConditions?: Array<string>;
34
+ }
35
+ export type Resolution =
36
+ | {|type: 'Path', value: string|}
37
+ | {|type: 'Builtin', value: string|}
38
+ | {|type: 'External'|}
39
+ | {|type: 'Empty'|}
40
+ | {|type: 'Global', value: string|};
41
+
42
+ export interface ResolveResult {
43
+ resolution: Resolution;
44
+ invalidateOnFileChange: Array<string>;
45
+ invalidateOnFileCreate: Array<FileCreateInvalidation>;
46
+ query?: string;
47
+ sideEffects: boolean;
48
+ error: mixed;
49
+ moduleType: number;
50
+ }
51
+ export interface JsInvalidations {
52
+ invalidateOnFileChange: Array<string>;
53
+ invalidateOnFileCreate: Array<FileCreateInvalidation>;
54
+ invalidateOnStartup: boolean;
55
+ }
56
+ declare export function transform(opts: any): any;
57
+ declare export function transformAsync(opts: any): Promise<any>;
58
+ declare export class Hash {
59
+ writeString(s: string): void;
60
+ writeBuffer(b: Buffer): void;
61
+ finish(): string;
62
+ }
63
+ export interface ResolverOptions {
64
+ fs?: JsFileSystemOptions;
65
+ includeNodeModules?: boolean | Array<string> | {|[string]: boolean|};
66
+ conditions?: number;
67
+ moduleDirResolver?: (...args: any[]) => any;
68
+ mode: number;
69
+ entries?: number;
70
+ extensions?: Array<string>;
71
+ }
72
+ declare export class Resolver {
73
+ constructor(projectRoot: string, options: ResolverOptions): Resolver;
74
+ resolve(options: ResolveOptions): ResolveResult;
75
+ resolveAsync(options: ResolveOptions): Promise<ResolveResult>;
76
+ getInvalidations(path: string): JsInvalidations;
77
+ }
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "@parcel/rust",
3
+ "version": "2.9.4-nightly.2988+aaaf22d59",
4
+ "license": "MIT",
5
+ "publishConfig": {
6
+ "access": "public"
7
+ },
8
+ "funding": {
9
+ "type": "opencollective",
10
+ "url": "https://opencollective.com/parcel"
11
+ },
12
+ "repository": {
13
+ "type": "git",
14
+ "url": "https://github.com/parcel-bundler/parcel.git"
15
+ },
16
+ "main": "index.js",
17
+ "browser": "browser.js",
18
+ "napi": {
19
+ "name": "parcel-node-bindings"
20
+ },
21
+ "engines": {
22
+ "node": ">= 12.0.0"
23
+ },
24
+ "files": [
25
+ "native-browser.js",
26
+ "index.d.ts",
27
+ "index.js",
28
+ "index.js.flow",
29
+ "*.node",
30
+ "*.wasm"
31
+ ],
32
+ "devDependencies": {
33
+ "@napi-rs/cli": "^2.15.2",
34
+ "napi-wasm": "^1.0.1"
35
+ },
36
+ "scripts": {
37
+ "build": "napi build --platform --cargo-cwd ../../../crates/node-bindings",
38
+ "build-release": "napi build --platform --release --cargo-cwd ../../../crates/node-bindings",
39
+ "wasm:build": "cargo build -p parcel-node-bindings --target wasm32-unknown-unknown && cp ../../../target/wasm32-unknown-unknown/debug/parcel_node_bindings.wasm .",
40
+ "wasm:build-release": "CARGO_PROFILE_RELEASE_LTO=true cargo build --target wasm32-unknown-unknown --release && wasm-opt --strip-debug -O ../../target/wasm32-unknown-unknown/release/parcel_node_bindings.wasm -o ../../packages/core/rust/parcel_node_bindings.wasm"
41
+ },
42
+ "gitHead": "aaaf22d590ffee11dccf2399704ad37c54a4e01f"
43
+ }