fix(cli): revert back js-binding file (#1603)

This commit is contained in:
LongYinan 2023-05-27 11:22:44 +08:00 committed by GitHub
parent 85836034ff
commit 82c2113c24
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1,26 +1,29 @@
/* eslint-disable @typescript-eslint/switch-exhaustiveness-check */ export function createJsBinding(localName: string, pkgName: string): string {
return `// prettier-ignore
/* tslint:disable */
/* eslint-disable */
/* auto-generated by NAPI-RS */
function loadNapiModule(binaryName: string, packageName: string) {
const { existsSync, readFileSync } = require('fs') const { existsSync, readFileSync } = require('fs')
const { join } = require('path') const { join } = require('path')
const { platform, arch } = process const { platform, arch } = process
const candidates: string[] = [] let nativeBinding = null
let localFileExisted = false
let loadError = null
function isMusl() { function isMusl() {
// For Node 10 // For Node 10
if (!process.report || typeof process.report.getReport !== 'function') { if (!process.report || typeof process.report.getReport !== 'function') {
try { try {
const lddPath = require('child_process') const lddPath = require('child_process').execSync('which ldd').toString().trim()
.execSync('which ldd')
.toString()
.trim()
return readFileSync(lddPath, 'utf8').includes('musl') return readFileSync(lddPath, 'utf8').includes('musl')
} catch (e) { } catch (e) {
return true return true
} }
} else { } else {
// @ts-expect-error
const { glibcVersionRuntime } = process.report.getReport().header const { glibcVersionRuntime } = process.report.getReport().header
return !glibcVersionRuntime return !glibcVersionRuntime
} }
@ -30,106 +33,225 @@ function loadNapiModule(binaryName: string, packageName: string) {
case 'android': case 'android':
switch (arch) { switch (arch) {
case 'arm64': case 'arm64':
candidates.push('android-arm64') localFileExisted = existsSync(join(__dirname, '${localName}.android-arm64.node'))
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.android-arm64.node')
} else {
nativeBinding = require('${pkgName}-android-arm64')
}
} catch (e) {
loadError = e
}
break break
case 'arm': case 'arm':
candidates.push('android-arm-eabi') localFileExisted = existsSync(join(__dirname, '${localName}.android-arm-eabi.node'))
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.android-arm-eabi.node')
} else {
nativeBinding = require('${pkgName}-android-arm-eabi')
}
} catch (e) {
loadError = e
}
break break
default:
throw new Error(\`Unsupported architecture on Android \${arch}\`)
} }
break break
case 'win32': case 'win32':
switch (arch) { switch (arch) {
case 'x64': case 'x64':
candidates.push('win32-x64-msvc') localFileExisted = existsSync(
join(__dirname, '${localName}.win32-x64-msvc.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.win32-x64-msvc.node')
} else {
nativeBinding = require('${pkgName}-win32-x64-msvc')
}
} catch (e) {
loadError = e
}
break break
case 'ia32': case 'ia32':
candidates.push('win32-ia32-msvc') localFileExisted = existsSync(
join(__dirname, '${localName}.win32-ia32-msvc.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.win32-ia32-msvc.node')
} else {
nativeBinding = require('${pkgName}-win32-ia32-msvc')
}
} catch (e) {
loadError = e
}
break break
case 'arm64': case 'arm64':
candidates.push('win32-arm64-msvc') localFileExisted = existsSync(
join(__dirname, '${localName}.win32-arm64-msvc.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.win32-arm64-msvc.node')
} else {
nativeBinding = require('${pkgName}-win32-arm64-msvc')
}
} catch (e) {
loadError = e
}
break break
default:
throw new Error(\`Unsupported architecture on Windows: \${arch}\`)
} }
break break
case 'darwin': case 'darwin':
candidates.push('darwin-universal') localFileExisted = existsSync(join(__dirname, '${localName}.darwin-universal.node'))
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.darwin-universal.node')
} else {
nativeBinding = require('${pkgName}-darwin-universal')
}
break
} catch {}
switch (arch) { switch (arch) {
case 'x64': case 'x64':
candidates.push('darwin-x64') localFileExisted = existsSync(join(__dirname, '${localName}.darwin-x64.node'))
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.darwin-x64.node')
} else {
nativeBinding = require('${pkgName}-darwin-x64')
}
} catch (e) {
loadError = e
}
break break
case 'arm64': case 'arm64':
candidates.push('darwin-arm64') localFileExisted = existsSync(
join(__dirname, '${localName}.darwin-arm64.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.darwin-arm64.node')
} else {
nativeBinding = require('${pkgName}-darwin-arm64')
}
} catch (e) {
loadError = e
}
break break
default:
throw new Error(\`Unsupported architecture on macOS: \${arch}\`)
} }
break break
case 'freebsd': case 'freebsd':
if (arch === 'x64') { if (arch !== 'x64') {
candidates.push('freebsd-x64') throw new Error(\`Unsupported architecture on FreeBSD: \${arch}\`)
}
localFileExisted = existsSync(join(__dirname, '${localName}.freebsd-x64.node'))
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.freebsd-x64.node')
} else {
nativeBinding = require('${pkgName}-freebsd-x64')
}
} catch (e) {
loadError = e
} }
break break
case 'linux': case 'linux':
switch (arch) { switch (arch) {
case 'x64': case 'x64':
if (isMusl()) { if (isMusl()) {
candidates.push('linux-x64-musl') localFileExisted = existsSync(
join(__dirname, '${localName}.linux-x64-musl.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.linux-x64-musl.node')
} else { } else {
candidates.push('linux-x64-gnu') nativeBinding = require('${pkgName}-linux-x64-musl')
}
} catch (e) {
loadError = e
}
} else {
localFileExisted = existsSync(
join(__dirname, '${localName}.linux-x64-gnu.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.linux-x64-gnu.node')
} else {
nativeBinding = require('${pkgName}-linux-x64-gnu')
}
} catch (e) {
loadError = e
}
} }
break break
case 'arm64': case 'arm64':
if (isMusl()) { if (isMusl()) {
candidates.push('linux-arm64-musl') localFileExisted = existsSync(
} else { join(__dirname, '${localName}.linux-arm64-musl.node')
candidates.push('linux-arm64-gnu') )
}
break
case 'arm':
candidates.push('linux-arm-gnueabihf')
break
// type Architecture doesn't contain riscv64 yet
// @ts-expect-error
case 'riscv64':
candidates.push('linux-riscv64-gnu')
break
}
break
}
let nativeBinding: any
let loadError: any
for (const suffix of candidates) {
const localPath = join(__dirname, `${binaryName}.${suffix}.node`)
const pkgPath = `${packageName}-${suffix}`
try { try {
if (existsSync(localPath)) { if (localFileExisted) {
nativeBinding = require(localPath) nativeBinding = require('./${localName}.linux-arm64-musl.node')
} else { } else {
nativeBinding = require(pkgPath) nativeBinding = require('${pkgName}-linux-arm64-musl')
} }
} catch (e) { } catch (e) {
loadError = e loadError = e
continue
} }
} else {
loadError = null localFileExisted = existsSync(
join(__dirname, '${localName}.linux-arm64-gnu.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.linux-arm64-gnu.node')
} else {
nativeBinding = require('${pkgName}-linux-arm64-gnu')
}
} catch (e) {
loadError = e
}
}
break break
case 'arm':
localFileExisted = existsSync(
join(__dirname, '${localName}.linux-arm-gnueabihf.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./${localName}.linux-arm-gnueabihf.node')
} else {
nativeBinding = require('${pkgName}-linux-arm-gnueabihf')
}
} catch (e) {
loadError = e
}
break
default:
throw new Error(\`Unsupported architecture on Linux: \${arch}\`)
}
break
default:
throw new Error(\`Unsupported OS: \${platform}, architecture: \${arch}\`)
} }
if (!nativeBinding) { if (!nativeBinding) {
if (loadError) { if (loadError) {
throw loadError throw loadError
} }
throw new Error(\`Failed to load native binding\`)
throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
} }
return nativeBinding
}
export function createJsBinding(localName: string, pkgName: string): string {
return `${loadNapiModule.toString()}
module.exports = loadNapiModule('${localName}', '${pkgName}')
` `
} }