Skip to content

Commit a9f15fa

Browse files
committed
feat!: bump engines to Node.js 22
BREAKING CHANGE: bumps minimum Node.js version to 22
1 parent 117e620 commit a9f15fa

10 files changed

+185
-746
lines changed

.github/workflows/check-electron-abi.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,7 @@ jobs:
3030
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1
3131
with:
3232
script: |
33-
const nodeAbi = require('node-abi');
33+
import nodeAbi from 'node-abi';
3434
3535
const abi = nodeAbi.getAbi('${{ github.event.inputs.electron-version }}', 'electron');
3636

.github/workflows/release.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ jobs:
2424
- name: Setup Node.js
2525
uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af # v4.1.0
2626
with:
27-
node-version: 20.x
27+
node-version-file: '.nvmrc'
2828
cache: 'yarn'
2929
- name: Install
3030
run: yarn install --frozen-lockfile

.github/workflows/test.yml

+1-7
Original file line numberDiff line numberDiff line change
@@ -17,17 +17,11 @@ jobs:
1717
strategy:
1818
matrix:
1919
node-version:
20-
- '20.10'
21-
- '18.18'
22-
- '16.20'
23-
- '14.21'
20+
- 22.12.x
2421
os:
2522
- macos-latest
2623
- ubuntu-latest
2724
- windows-latest
28-
exclude:
29-
- os: macos-latest
30-
node-version: '14.21'
3125
runs-on: "${{ matrix.os }}"
3226
steps:
3327
- name: Checkout

.github/workflows/update-abi.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ jobs:
1919
token: ${{ steps.generate-token.outputs.token }}
2020
- uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af # v4.1.0
2121
with:
22-
node-version: '20.x'
22+
node-version-file: '.nvmrc'
2323
- name: Get npm cache directory
2424
id: npm-cache
2525
run: |

.nvmrc

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
22.12

index.js

+33-42
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,12 @@
1-
var semver = require('semver')
1+
import fs from 'node:fs';
22

3-
function getNextTarget (runtime, targets) {
3+
import semver from 'semver';
4+
5+
export function _getNextTarget (runtime, targets) {
46
if (targets == null) targets = allTargets
5-
var latest = targets.filter(function (t) { return t.runtime === runtime }).slice(-1)[0]
6-
var increment = runtime === 'electron' ? 'minor' : 'major'
7-
var next = semver.inc(latest.target, increment)
7+
const latest = targets.filter(function (t) { return t.runtime === runtime }).slice(-1)[0]
8+
const increment = runtime === 'electron' ? 'minor' : 'major'
9+
let next = semver.inc(latest.target, increment)
810
// Electron releases appear in the registry in their beta form, sometimes there is
911
// no active beta line. During this time we need to double bump
1012
if (runtime === 'electron' && semver.parse(latest.target).prerelease.length) {
@@ -13,7 +15,7 @@ function getNextTarget (runtime, targets) {
1315
return next
1416
}
1517

16-
function getAbi (target, runtime) {
18+
export function getAbi (target, runtime) {
1719
if (target === String(Number(target))) return target
1820
if (target) target = target.replace(/^v/, '')
1921
if (!runtime) runtime = 'node'
@@ -23,37 +25,37 @@ function getAbi (target, runtime) {
2325
if (target === process.versions.node) return process.versions.modules
2426
}
2527

26-
var abi
27-
var lastTarget
28+
let abi
29+
let lastTarget
2830

29-
for (var i = 0; i < allTargets.length; i++) {
30-
var t = allTargets[i]
31+
for (let i = 0; i < allTargets.length; i++) {
32+
const t = allTargets[i]
3133
if (t.runtime !== runtime) continue
3234
if (semver.lte(t.target, target) && (!lastTarget || semver.gte(t.target, lastTarget))) {
3335
abi = t.abi
3436
lastTarget = t.target
3537
}
3638
}
3739

38-
if (abi && semver.lt(target, getNextTarget(runtime))) return abi
40+
if (abi && semver.lt(target, _getNextTarget(runtime))) return abi
3941
throw new Error('Could not detect abi for version ' + target + ' and runtime ' + runtime + '. Updating "node-abi" might help solve this issue if it is a new release of ' + runtime)
4042
}
4143

42-
function getTarget (abi, runtime) {
44+
export function getTarget (abi, runtime) {
4345
if (abi && abi !== String(Number(abi))) return abi
4446
if (!runtime) runtime = 'node'
4547

4648
if (runtime === 'node' && !abi) return process.versions.node
4749

48-
var match = allTargets
50+
const match = allTargets
4951
.filter(function (t) {
5052
return t.abi === abi && t.runtime === runtime
5153
})
5254
.map(function (t) {
5355
return t.target
5456
})
5557
if (match.length) {
56-
var betaSeparatorIndex = match[0].indexOf("-")
58+
const betaSeparatorIndex = match[0].indexOf("-")
5759
return betaSeparatorIndex > -1
5860
? match[0].substring(0, betaSeparatorIndex)
5961
: match[0]
@@ -63,31 +65,31 @@ function getTarget (abi, runtime) {
6365
}
6466

6567
function sortByTargetFn (a, b) {
66-
var abiComp = Number(a.abi) - Number(b.abi)
68+
const abiComp = Number(a.abi) - Number(b.abi)
6769
if (abiComp !== 0) return abiComp
6870
if (a.target < b.target) return -1
6971
if (a.target > b.target) return 1
7072
return 0
7173
}
7274

7375
function loadGeneratedTargets () {
74-
var registry = require('./abi_registry.json')
75-
var targets = {
76+
const registry = JSON.parse(fs.readFileSync('./abi_registry.json', 'utf8'))
77+
const targets = {
7678
supported: [],
7779
additional: [],
7880
future: []
7981
}
8082

8183
registry.forEach(function (item) {
82-
var target = {
84+
const target = {
8385
runtime: item.runtime,
8486
target: item.target,
8587
abi: item.abi
8688
}
8789
if (item.lts) {
88-
var startDate = new Date(Date.parse(item.lts[0]))
89-
var endDate = new Date(Date.parse(item.lts[1]))
90-
var currentDate = new Date()
90+
const startDate = new Date(Date.parse(item.lts[0]))
91+
const endDate = new Date(Date.parse(item.lts[1]))
92+
const currentDate = new Date()
9193
target.lts = startDate < currentDate && currentDate < endDate
9294
} else {
9395
target.lts = false
@@ -109,9 +111,9 @@ function loadGeneratedTargets () {
109111
return targets
110112
}
111113

112-
var generatedTargets = loadGeneratedTargets()
114+
const generatedTargets = loadGeneratedTargets()
113115

114-
var supportedTargets = [
116+
export const supportedTargets = [
115117
{runtime: 'node', target: '5.0.0', abi: '47', lts: false},
116118
{runtime: 'node', target: '6.0.0', abi: '48', lts: false},
117119
{runtime: 'node', target: '7.0.0', abi: '51', lts: false},
@@ -129,22 +131,20 @@ var supportedTargets = [
129131
{runtime: 'electron', target: '2.0.0', abi: '57', lts: false},
130132
{runtime: 'electron', target: '3.0.0', abi: '64', lts: false},
131133
{runtime: 'electron', target: '4.0.0', abi: '64', lts: false},
132-
{runtime: 'electron', target: '4.0.4', abi: '69', lts: false}
134+
{runtime: 'electron', target: '4.0.4', abi: '69', lts: false},
135+
...generatedTargets.supported
133136
]
134137

135-
supportedTargets.push.apply(supportedTargets, generatedTargets.supported)
136-
137-
var additionalTargets = [
138+
export const additionalTargets = [
138139
{runtime: 'node-webkit', target: '0.13.0', abi: '47', lts: false},
139140
{runtime: 'node-webkit', target: '0.15.0', abi: '48', lts: false},
140141
{runtime: 'node-webkit', target: '0.18.3', abi: '51', lts: false},
141142
{runtime: 'node-webkit', target: '0.23.0', abi: '57', lts: false},
142-
{runtime: 'node-webkit', target: '0.26.5', abi: '59', lts: false}
143+
{runtime: 'node-webkit', target: '0.26.5', abi: '59', lts: false},
144+
...generatedTargets.additional
143145
]
144146

145-
additionalTargets.push.apply(additionalTargets, generatedTargets.additional)
146-
147-
var deprecatedTargets = [
147+
export const deprecatedTargets = [
148148
{runtime: 'node', target: '0.2.0', abi: '1', lts: false},
149149
{runtime: 'node', target: '0.9.1', abi: '0x000A', lts: false},
150150
{runtime: 'node', target: '0.9.9', abi: '0x000B', lts: false},
@@ -162,18 +162,9 @@ var deprecatedTargets = [
162162
{runtime: 'electron', target: '0.33.0', abi: '46', lts: false}
163163
]
164164

165-
var futureTargets = generatedTargets.future
165+
export const futureTargets = generatedTargets.future
166166

167-
var allTargets = deprecatedTargets
167+
export const allTargets = deprecatedTargets
168168
.concat(supportedTargets)
169169
.concat(additionalTargets)
170170
.concat(futureTargets)
171-
172-
exports.getAbi = getAbi
173-
exports.getTarget = getTarget
174-
exports.deprecatedTargets = deprecatedTargets
175-
exports.supportedTargets = supportedTargets
176-
exports.additionalTargets = additionalTargets
177-
exports.futureTargets = futureTargets
178-
exports.allTargets = allTargets
179-
exports._getNextTarget = getNextTarget

package.json

+6-7
Original file line numberDiff line numberDiff line change
@@ -2,9 +2,10 @@
22
"name": "node-abi",
33
"version": "0.0.0-development",
44
"description": "Get the Node ABI for a given target and runtime, and vice versa.",
5-
"main": "index.js",
5+
"type": "module",
6+
"exports": "./index.js",
67
"scripts": {
7-
"test": "tape test/index.js",
8+
"test": "node --test test/index.js",
89
"update-abi-registry": "node --unhandled-rejections=strict scripts/update-abi-registry.js"
910
},
1011
"files": [
@@ -27,14 +28,12 @@
2728
"url": "https://github.com/electron/node-abi/issues"
2829
},
2930
"homepage": "https://github.com/electron/node-abi#readme",
30-
"devDependencies": {
31-
"tape": "^5.3.1"
32-
},
31+
"devDependencies": {},
3332
"dependencies": {
34-
"semver": "^7.3.5"
33+
"semver": "^7.6.3"
3534
},
3635
"engines": {
37-
"node": ">=10"
36+
"node": ">=22.12.0"
3837
},
3938
"publishConfig": {
4039
"provenance": true

scripts/update-abi-registry.js

+5-4
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,8 @@
1-
const { writeFile } = require('node:fs/promises')
2-
const path = require('node:path')
1+
import { writeFile } from 'node:fs/promises'
2+
import path from 'node:path'
3+
import { fileURLToPath } from 'node:url';
34

4-
const semver = require('semver')
5+
import semver from 'semver'
56

67
function sortByElectronVersionFn (a, b) {
78
const modulesComp = Number(a.modules) - Number(b.modules)
@@ -127,7 +128,7 @@ async function main () {
127128
...electronTargets,
128129
]
129130

130-
await writeFile(path.resolve(__dirname, '..', 'abi_registry.json'), JSON.stringify(supportedTargets, null, 2))
131+
await writeFile(path.resolve(path.dirname(fileURLToPath(import.meta.url)), '..', 'abi_registry.json'), JSON.stringify(supportedTargets, null, 2))
131132
}
132133

133134
main()

0 commit comments

Comments
 (0)