Skip to content

Commit

Permalink
fix: Include binding.js (#36)
Browse files Browse the repository at this point in the history
  • Loading branch information
kdy1 authored Jul 17, 2023
1 parent d6f7456 commit d720627
Show file tree
Hide file tree
Showing 9 changed files with 787 additions and 6 deletions.
3 changes: 2 additions & 1 deletion packages/css/.gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
/*.js
/*.js
!binding.js
260 changes: 260 additions & 0 deletions packages/css/binding.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,260 @@
/* tslint:disable */
/* eslint-disable */
/* prettier-ignore */

/* auto-generated by NAPI-RS */

const { existsSync, readFileSync } = require('fs')
const { join } = require('path')

const { platform, arch } = process

let nativeBinding = null
let localFileExisted = false
let loadError = null

function isMusl() {
// For Node 10
if (!process.report || typeof process.report.getReport !== 'function') {
try {
const lddPath = require('child_process').execSync('which ldd').toString().trim()
return readFileSync(lddPath, 'utf8').includes('musl')
} catch (e) {
return true
}
} else {
const { glibcVersionRuntime } = process.report.getReport().header
return !glibcVersionRuntime
}
}

switch (platform) {
case 'android':
switch (arch) {
case 'arm64':
localFileExisted = existsSync(join(__dirname, 'css.android-arm64.node'))
try {
if (localFileExisted) {
nativeBinding = require('./css.android-arm64.node')
} else {
nativeBinding = require('@swc/css-android-arm64')
}
} catch (e) {
loadError = e
}
break
case 'arm':
localFileExisted = existsSync(join(__dirname, 'css.android-arm-eabi.node'))
try {
if (localFileExisted) {
nativeBinding = require('./css.android-arm-eabi.node')
} else {
nativeBinding = require('@swc/css-android-arm-eabi')
}
} catch (e) {
loadError = e
}
break
default:
throw new Error(`Unsupported architecture on Android ${arch}`)
}
break
case 'win32':
switch (arch) {
case 'x64':
localFileExisted = existsSync(
join(__dirname, 'css.win32-x64-msvc.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.win32-x64-msvc.node')
} else {
nativeBinding = require('@swc/css-win32-x64-msvc')
}
} catch (e) {
loadError = e
}
break
case 'ia32':
localFileExisted = existsSync(
join(__dirname, 'css.win32-ia32-msvc.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.win32-ia32-msvc.node')
} else {
nativeBinding = require('@swc/css-win32-ia32-msvc')
}
} catch (e) {
loadError = e
}
break
case 'arm64':
localFileExisted = existsSync(
join(__dirname, 'css.win32-arm64-msvc.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.win32-arm64-msvc.node')
} else {
nativeBinding = require('@swc/css-win32-arm64-msvc')
}
} catch (e) {
loadError = e
}
break
default:
throw new Error(`Unsupported architecture on Windows: ${arch}`)
}
break
case 'darwin':
localFileExisted = existsSync(join(__dirname, 'css.darwin-universal.node'))
try {
if (localFileExisted) {
nativeBinding = require('./css.darwin-universal.node')
} else {
nativeBinding = require('@swc/css-darwin-universal')
}
break
} catch {}
switch (arch) {
case 'x64':
localFileExisted = existsSync(join(__dirname, 'css.darwin-x64.node'))
try {
if (localFileExisted) {
nativeBinding = require('./css.darwin-x64.node')
} else {
nativeBinding = require('@swc/css-darwin-x64')
}
} catch (e) {
loadError = e
}
break
case 'arm64':
localFileExisted = existsSync(
join(__dirname, 'css.darwin-arm64.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.darwin-arm64.node')
} else {
nativeBinding = require('@swc/css-darwin-arm64')
}
} catch (e) {
loadError = e
}
break
default:
throw new Error(`Unsupported architecture on macOS: ${arch}`)
}
break
case 'freebsd':
if (arch !== 'x64') {
throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
}
localFileExisted = existsSync(join(__dirname, 'css.freebsd-x64.node'))
try {
if (localFileExisted) {
nativeBinding = require('./css.freebsd-x64.node')
} else {
nativeBinding = require('@swc/css-freebsd-x64')
}
} catch (e) {
loadError = e
}
break
case 'linux':
switch (arch) {
case 'x64':
if (isMusl()) {
localFileExisted = existsSync(
join(__dirname, 'css.linux-x64-musl.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.linux-x64-musl.node')
} else {
nativeBinding = require('@swc/css-linux-x64-musl')
}
} catch (e) {
loadError = e
}
} else {
localFileExisted = existsSync(
join(__dirname, 'css.linux-x64-gnu.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.linux-x64-gnu.node')
} else {
nativeBinding = require('@swc/css-linux-x64-gnu')
}
} catch (e) {
loadError = e
}
}
break
case 'arm64':
if (isMusl()) {
localFileExisted = existsSync(
join(__dirname, 'css.linux-arm64-musl.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.linux-arm64-musl.node')
} else {
nativeBinding = require('@swc/css-linux-arm64-musl')
}
} catch (e) {
loadError = e
}
} else {
localFileExisted = existsSync(
join(__dirname, 'css.linux-arm64-gnu.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.linux-arm64-gnu.node')
} else {
nativeBinding = require('@swc/css-linux-arm64-gnu')
}
} catch (e) {
loadError = e
}
}
break
case 'arm':
localFileExisted = existsSync(
join(__dirname, 'css.linux-arm-gnueabihf.node')
)
try {
if (localFileExisted) {
nativeBinding = require('./css.linux-arm-gnueabihf.node')
} else {
nativeBinding = require('@swc/css-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 (loadError) {
throw loadError
}
throw new Error(`Failed to load native binding`)
}

const { minify, minifySync, transform, transformSync } = nativeBinding

module.exports.minify = minify
module.exports.minifySync = minifySync
module.exports.transform = transform
module.exports.transformSync = transformSync
2 changes: 1 addition & 1 deletion packages/css/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@swc/css",
"packageManager": "yarn@3.2.3",
"version": "0.0.24",
"version": "0.0.25",
"description": "Super-fast alternative for postcss",
"homepage": "https://swc.rs",
"main": "./index.js",
Expand Down
3 changes: 2 additions & 1 deletion packages/html/.gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
/*.js
/*.js
!binding.js
Loading

0 comments on commit d720627

Please sign in to comment.