UNPKG

@arkts/project-detector-wasm32-wasi

Version:

A native Rust-based project detector for HarmonyOS/OpenHarmony projects

123 lines (109 loc) 4.21 kB
/* eslint-disable */ /* prettier-ignore */ /* auto-generated by NAPI-RS */ const __nodeFs = require('node:fs') const __nodePath = require('node:path') const { WASI: __nodeWASI } = require('node:wasi') const { Worker } = require('node:worker_threads') const { createOnMessage: __wasmCreateOnMessageForFsProxy, getDefaultContext: __emnapiGetDefaultContext, instantiateNapiModuleSync: __emnapiInstantiateNapiModuleSync, } = require('@napi-rs/wasm-runtime') const __rootDir = __nodePath.parse(process.cwd()).root const __wasi = new __nodeWASI({ version: 'preview1', env: process.env, preopens: { [__rootDir]: __rootDir, } }) const __emnapiContext = __emnapiGetDefaultContext() const __sharedMemory = new WebAssembly.Memory({ initial: 4000, maximum: 65536, shared: true, }) let __wasmFilePath = __nodePath.join(__dirname, 'project-detector.wasm32-wasi.wasm') const __wasmDebugFilePath = __nodePath.join(__dirname, 'project-detector.wasm32-wasi.debug.wasm') if (__nodeFs.existsSync(__wasmDebugFilePath)) { __wasmFilePath = __wasmDebugFilePath } else if (!__nodeFs.existsSync(__wasmFilePath)) { try { __wasmFilePath = __nodePath.resolve('@arkts/project-detector-wasm32-wasi') } catch { throw new Error('Cannot find project-detector.wasm32-wasi.wasm file, and @arkts/project-detector-wasm32-wasi package is not installed.') } } const { instance: __napiInstance, module: __wasiModule, napiModule: __napiModule } = __emnapiInstantiateNapiModuleSync(__nodeFs.readFileSync(__wasmFilePath), { context: __emnapiContext, asyncWorkPoolSize: (function() { const threadsSizeFromEnv = Number(process.env.NAPI_RS_ASYNC_WORK_POOL_SIZE ?? process.env.UV_THREADPOOL_SIZE) // NaN > 0 is false if (threadsSizeFromEnv > 0) { return threadsSizeFromEnv } else { return 4 } })(), reuseWorker: true, wasi: __wasi, onCreateWorker() { const worker = new Worker(__nodePath.join(__dirname, 'wasi-worker.mjs'), { env: process.env, }) worker.onmessage = ({ data }) => { __wasmCreateOnMessageForFsProxy(__nodeFs)(data) } // The main thread of Node.js waits for all the active handles before exiting. // But Rust threads are never waited without `thread::join`. // So here we hack the code of Node.js to prevent the workers from being referenced (active). // According to https://github.com/nodejs/node/blob/19e0d472728c79d418b74bddff588bea70a403d0/lib/internal/worker.js#L415, // a worker is consist of two handles: kPublicPort and kHandle. { const kPublicPort = Object.getOwnPropertySymbols(worker).find(s => s.toString().includes("kPublicPort") ); if (kPublicPort) { worker[kPublicPort].ref = () => {}; } const kHandle = Object.getOwnPropertySymbols(worker).find(s => s.toString().includes("kHandle") ); if (kHandle) { worker[kHandle].ref = () => {}; } worker.unref(); } return worker }, overwriteImports(importObject) { importObject.env = { ...importObject.env, ...importObject.napi, ...importObject.emnapi, memory: __sharedMemory, } return importObject }, beforeInit({ instance }) { for (const name of Object.keys(instance.exports)) { if (name.startsWith('__napi_register__')) { instance.exports[name]() } } }, }) module.exports = __napiModule.exports module.exports.ElementDirectory = __napiModule.exports.ElementDirectory module.exports.ElementJsonFile = __napiModule.exports.ElementJsonFile module.exports.ElementJsonFileReference = __napiModule.exports.ElementJsonFileReference module.exports.Module = __napiModule.exports.Module module.exports.Product = __napiModule.exports.Product module.exports.Project = __napiModule.exports.Project module.exports.ProjectDetector = __napiModule.exports.ProjectDetector module.exports.QualifierUtils = __napiModule.exports.QualifierUtils module.exports.Resource = __napiModule.exports.Resource module.exports.ResourceDirectory = __napiModule.exports.ResourceDirectory module.exports.Uri = __napiModule.exports.Uri module.exports.QualifierType = __napiModule.exports.QualifierType