From 9c24bbb9bb928fe5f9ef67d702cec75dc01a9880 Mon Sep 17 00:00:00 2001 From: elrrrrrrr Date: Tue, 14 Nov 2023 23:08:09 +0800 Subject: [PATCH] fix: node gyp scripts (#60) * fix: node gyp scripts * fix: gyp scripts --- .gitignore | 1 - integration/fixtures/gyp/package-lock.json | 47 ++++++++++++++++++++++ integration/fixtures/gyp/package.json | 6 +++ integration/index.2.test.js | 2 +- packages/cli/lib/node-gyp-bin/node-gyp | 2 + packages/cli/lib/node-gyp-bin/node-gyp.cmd | 1 + packages/cli/lib/node-gyp-bin/node-gyp.js | 3 ++ packages/cli/lib/util.js | 2 +- packages/cli/package.json | 3 +- 9 files changed, 63 insertions(+), 4 deletions(-) create mode 100644 integration/fixtures/gyp/package-lock.json create mode 100644 integration/fixtures/gyp/package.json create mode 100755 packages/cli/lib/node-gyp-bin/node-gyp create mode 100755 packages/cli/lib/node-gyp-bin/node-gyp.cmd create mode 100644 packages/cli/lib/node-gyp-bin/node-gyp.js diff --git a/.gitignore b/.gitignore index 33516f7..a13555c 100644 --- a/.gitignore +++ b/.gitignore @@ -113,7 +113,6 @@ bindings/*/index.node .idea packages/cli/test/fixtures/project-scripts/apps/a/1 packages/downloader/test/nginx.conf -package-lock.json # napi-rs generate wrong type ignore for tmp packages/binding/index.d.ts diff --git a/integration/fixtures/gyp/package-lock.json b/integration/fixtures/gyp/package-lock.json new file mode 100644 index 0000000..9abfc50 --- /dev/null +++ b/integration/fixtures/gyp/package-lock.json @@ -0,0 +1,47 @@ +{ + "name": "gyp", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "dependencies": { + "fsevents": "^1.2.13" + } + }, + "node_modules/bindings": { + "version": "1.5.0", + "resolved": "https://registry.antgroup-inc.cn/bindings/-/bindings-1.5.0.tgz", + "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", + "dependencies": { + "file-uri-to-path": "1.0.0" + } + }, + "node_modules/file-uri-to-path": { + "version": "1.0.0", + "resolved": "https://registry.antgroup-inc.cn/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", + "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==" + }, + "node_modules/fsevents": { + "version": "1.2.13", + "resolved": "https://registry.antgroup-inc.cn/fsevents/-/fsevents-1.2.13.tgz", + "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==", + "deprecated": "The v1 package contains DANGEROUS / INSECURE binaries. Upgrade to safe fsevents v2", + "hasInstallScript": true, + "os": [ + "darwin" + ], + "dependencies": { + "bindings": "^1.5.0", + "nan": "^2.12.1" + }, + "engines": { + "node": ">= 4.0" + } + }, + "node_modules/nan": { + "version": "2.18.0", + "resolved": "https://registry.antgroup-inc.cn/nan/-/nan-2.18.0.tgz", + "integrity": "sha512-W7tfG7vMOGtD30sHoZSSc/JVYiyDPEyQVso/Zz+/uQd0B0L46gtC+pHha5FFMRpil6fm/AoEcRWyOVi4+E/f8w==" + } + } +} \ No newline at end of file diff --git a/integration/fixtures/gyp/package.json b/integration/fixtures/gyp/package.json new file mode 100644 index 0000000..2879b28 --- /dev/null +++ b/integration/fixtures/gyp/package.json @@ -0,0 +1,6 @@ +{ + "repository": "git@github.com:cnpm/rapid.git", + "dependencies": { + "fsevents": "^1.2.13" + } +} diff --git a/integration/index.2.test.js b/integration/index.2.test.js index f041d6c..50e9070 100644 --- a/integration/index.2.test.js +++ b/integration/index.2.test.js @@ -171,7 +171,6 @@ describe('test/index.v2.test.js', () => { it('should auto clean when reinstall', async () => { cwd = path.join(__dirname, './fixtures/esbuild'); - await coffee .fork(rapid, [ 'install', @@ -203,4 +202,5 @@ describe('test/index.v2.test.js', () => { const res = await execa.command('mount', { stdio: 'pipe' }); assert(res.stdout.indexOf('integration/fixtures/esbuild/node_modules') === res.stdout.lastIndexOf('integration/fixtures/esbuild/node_modules')); }); + }); diff --git a/packages/cli/lib/node-gyp-bin/node-gyp b/packages/cli/lib/node-gyp-bin/node-gyp new file mode 100755 index 0000000..381931c --- /dev/null +++ b/packages/cli/lib/node-gyp-bin/node-gyp @@ -0,0 +1,2 @@ +#!/usr/bin/env sh +node "`dirname "$0"`/node-gyp.js" "$@" diff --git a/packages/cli/lib/node-gyp-bin/node-gyp.cmd b/packages/cli/lib/node-gyp-bin/node-gyp.cmd new file mode 100755 index 0000000..48fe570 --- /dev/null +++ b/packages/cli/lib/node-gyp-bin/node-gyp.cmd @@ -0,0 +1 @@ +node "%~dp0\node-gyp.js" %* diff --git a/packages/cli/lib/node-gyp-bin/node-gyp.js b/packages/cli/lib/node-gyp-bin/node-gyp.js new file mode 100644 index 0000000..839ef32 --- /dev/null +++ b/packages/cli/lib/node-gyp-bin/node-gyp.js @@ -0,0 +1,3 @@ +'use strict'; + +return require('node-gyp/bin/node-gyp.js'); diff --git a/packages/cli/lib/util.js b/packages/cli/lib/util.js index f475ec4..96cde63 100644 --- a/packages/cli/lib/util.js +++ b/packages/cli/lib/util.js @@ -534,7 +534,7 @@ exports.runScript = async (pkgDir, script, options) => { // ignore error } env.PATH = [ - path.join(__dirname, '../node-gyp-bin'), + path.join(__dirname, './node-gyp-bin'), path.join(options.cwd, 'node_modules', '.bin'), path.join(pkgDir, 'node_modules', '.bin'), process.env.PATH, diff --git a/packages/cli/package.json b/packages/cli/package.json index 0a5ab4e..58804ba 100644 --- a/packages/cli/package.json +++ b/packages/cli/package.json @@ -31,7 +31,8 @@ "semver": "^7.3.8", "urllib": "^3.16.1", "yargs": "^17.7.2", - "yargs-parser": "^9.0.2" + "yargs-parser": "^9.0.2", + "node-gyp": "^9.0.0" }, "homepage": "https://github.com/cnpm/rapid", "repository": {