Added support for Streamdeck Pedal and updated UI to better fit the Packed UI style
This commit is contained in:
107
node_modules/pkg-prebuilds/bindings.js
generated
vendored
Normal file
107
node_modules/pkg-prebuilds/bindings.js
generated
vendored
Normal file
@@ -0,0 +1,107 @@
|
||||
const path = require('path')
|
||||
const os = require('os')
|
||||
const { getPrebuildName, isNwjs, isElectron, isAlpine } = require('./lib/prebuild')
|
||||
|
||||
// Jest can allow users to mock 'fs', but we need the real fs
|
||||
const fs = typeof jest !== 'undefined' ? jest.requireActual('fs') : require('fs')
|
||||
|
||||
// Workaround to fix webpack's build warnings: 'the request of a dependency is an expression'
|
||||
const runtimeRequire = typeof __webpack_require__ === 'function' ? __non_webpack_require__ : require // eslint-disable-line
|
||||
|
||||
/**
|
||||
* Find the best path to the binding file
|
||||
* @param {string} basePath - Base path of the module, where binaries will be located
|
||||
* @param {object} options - Describe how the prebuilt binary is named
|
||||
* @param {boolean} verifyPrebuild - True if we are verifying that a prebuild exists
|
||||
* @param {boolean} throwOnMissing - True if an error should be thrown when the binary is missing
|
||||
* @returns
|
||||
*/
|
||||
function resolvePath(basePath, options, verifyPrebuild, throwOnMissing) {
|
||||
if (typeof basePath !== 'string' || !basePath) throw new Error(`Invalid basePath to pkg-prebuilds`)
|
||||
|
||||
if (typeof options !== 'object' || !options) throw new Error(`Invalid options to pkg-prebuilds`)
|
||||
if (typeof options.name !== 'string' || !options.name) throw new Error(`Invalid name to pkg-prebuilds`)
|
||||
|
||||
let isNodeApi = false
|
||||
if (options.napi_versions && Array.isArray(options.napi_versions)) {
|
||||
isNodeApi = true
|
||||
}
|
||||
|
||||
const arch = (verifyPrebuild && process.env.npm_config_arch) || os.arch()
|
||||
const platform = (verifyPrebuild && process.env.npm_config_platform) || os.platform()
|
||||
|
||||
let runtime = 'node'
|
||||
// If node-api, then everything can share the same binary
|
||||
if (!isNodeApi) {
|
||||
if (verifyPrebuild && process.env.npm_config_runtime) {
|
||||
runtime = process.env.npm_config_runtime
|
||||
} else if (isElectron()) {
|
||||
runtime = 'electron'
|
||||
} else if (isNwjs()) {
|
||||
runtime = 'node-webkit'
|
||||
}
|
||||
}
|
||||
|
||||
const candidates = []
|
||||
|
||||
if (!verifyPrebuild) {
|
||||
// Try for a locally built binding
|
||||
candidates.push(
|
||||
path.join(basePath, 'build', 'Debug', `${options.name}.node`),
|
||||
path.join(basePath, 'build', 'Release', `${options.name}.node`)
|
||||
)
|
||||
}
|
||||
|
||||
let libc = undefined
|
||||
if (isAlpine(platform)) libc = 'musl'
|
||||
|
||||
// Look for prebuilds
|
||||
if (isNodeApi) {
|
||||
// Look for node-api versioned builds
|
||||
for (const ver of options.napi_versions) {
|
||||
const prebuildName = getPrebuildName({
|
||||
name: options.name,
|
||||
platform,
|
||||
arch,
|
||||
libc,
|
||||
napi_version: ver,
|
||||
runtime,
|
||||
// armv: options.armv ? (arch === 'arm64' ? '8' : vars.arm_version) : null,
|
||||
})
|
||||
candidates.push(path.join(basePath, 'prebuilds', prebuildName))
|
||||
}
|
||||
} else {
|
||||
throw new Error('Not implemented for NAN!')
|
||||
}
|
||||
|
||||
let foundPath = null
|
||||
|
||||
for (const candidate of candidates) {
|
||||
if (fs.existsSync(candidate)) {
|
||||
const stat = fs.statSync(candidate)
|
||||
if (stat.isFile()) {
|
||||
foundPath = candidate
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!foundPath && throwOnMissing) {
|
||||
const candidatesStr = candidates.map((cand) => ` - ${cand}`).join('\n')
|
||||
throw new Error(`Failed to find binding for ${options.name}\nTried paths:\n${candidatesStr}`)
|
||||
}
|
||||
|
||||
return foundPath
|
||||
}
|
||||
|
||||
function loadBinding(basePath, options) {
|
||||
const foundPath = resolvePath(basePath, options, false, true)
|
||||
|
||||
// Note: this error should not be hit, as resolvePath will throw if the binding is missing
|
||||
if (!foundPath) throw new Error(`Failed to find binding for ${options.name}`)
|
||||
|
||||
return runtimeRequire(foundPath)
|
||||
}
|
||||
loadBinding.resolve = resolvePath
|
||||
|
||||
module.exports = loadBinding
|
||||
Reference in New Issue
Block a user