@socketsecurity/cli-with-sentry 1.0.7 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (140) hide show
  1. package/dist/cli.js +41 -31
  2. package/dist/cli.js.map +1 -1
  3. package/dist/constants.js +8 -3
  4. package/dist/constants.js.map +1 -1
  5. package/dist/shadow-npm-bin.js +5 -5
  6. package/dist/shadow-npm-bin.js.map +1 -1
  7. package/dist/socket-completion.bash +23 -7
  8. package/dist/types/commands/fix/cmd-fix.d.mts.map +1 -1
  9. package/dist/types/commands/fix/handle-fix.d.mts +2 -1
  10. package/dist/types/commands/fix/handle-fix.d.mts.map +1 -1
  11. package/dist/types/commands/install/setup-tab-completion.d.mts.map +1 -1
  12. package/dist/types/commands/manifest/cmd-manifest-cdxgen.d.mts.map +1 -1
  13. package/dist/types/commands/npm/cmd-npm.d.mts.map +1 -1
  14. package/dist/types/commands/npx/cmd-npx.d.mts.map +1 -1
  15. package/dist/types/commands/raw-npm/cmd-raw-npm.d.mts.map +1 -1
  16. package/dist/types/commands/raw-npx/cmd-raw-npx.d.mts.map +1 -1
  17. package/dist/types/constants.d.mts.map +1 -1
  18. package/dist/types/utils/alerts-map.d.mts.map +1 -1
  19. package/dist/types/utils/api.d.mts.map +1 -1
  20. package/dist/types/utils/meow-with-subcommands.d.mts +2 -3
  21. package/dist/types/utils/meow-with-subcommands.d.mts.map +1 -1
  22. package/dist/utils.js +34 -45
  23. package/dist/utils.js.map +1 -1
  24. package/dist/vendor.js +27 -24
  25. package/external/@coana-tech/cli/cli.mjs +1 -1
  26. package/external/@socketsecurity/registry/lib/constants/npm-real-exec-path.js +2 -40
  27. package/external/@socketsecurity/registry/lib/npm.js +102 -71
  28. package/external/@socketsecurity/registry/lib/spinner.js +6 -0
  29. package/external/blessed-contrib/lib/widget/charts/bar.js +4 -3
  30. package/external/blessed-contrib/lib/widget/charts/line.js +4 -3
  31. package/external/blessed-contrib/lib/widget/table.js +3 -3
  32. package/package.json +11 -12
  33. package/external/node-gyp/.release-please-manifest.json +0 -3
  34. package/external/node-gyp/CHANGELOG.md +0 -1053
  35. package/external/node-gyp/CODE_OF_CONDUCT.md +0 -4
  36. package/external/node-gyp/CONTRIBUTING.md +0 -34
  37. package/external/node-gyp/LICENSE +0 -24
  38. package/external/node-gyp/README.md +0 -273
  39. package/external/node-gyp/SECURITY.md +0 -2
  40. package/external/node-gyp/addon.gypi +0 -204
  41. package/external/node-gyp/bin/node-gyp.js +0 -137
  42. package/external/node-gyp/eslint.config.js +0 -3
  43. package/external/node-gyp/gyp/.release-please-manifest.json +0 -3
  44. package/external/node-gyp/gyp/LICENSE +0 -28
  45. package/external/node-gyp/gyp/data/ninja/build.ninja +0 -4
  46. package/external/node-gyp/gyp/data/win/large-pdb-shim.cc +0 -12
  47. package/external/node-gyp/gyp/docs/GypVsCMake.md +0 -116
  48. package/external/node-gyp/gyp/docs/Hacking.md +0 -46
  49. package/external/node-gyp/gyp/docs/InputFormatReference.md +0 -1083
  50. package/external/node-gyp/gyp/docs/LanguageSpecification.md +0 -430
  51. package/external/node-gyp/gyp/docs/README.md +0 -27
  52. package/external/node-gyp/gyp/docs/Testing.md +0 -450
  53. package/external/node-gyp/gyp/docs/UserDocumentation.md +0 -965
  54. package/external/node-gyp/gyp/gyp +0 -8
  55. package/external/node-gyp/gyp/gyp.bat +0 -5
  56. package/external/node-gyp/gyp/gyp_main.py +0 -45
  57. package/external/node-gyp/gyp/pylib/gyp/MSVSNew.py +0 -365
  58. package/external/node-gyp/gyp/pylib/gyp/MSVSProject.py +0 -206
  59. package/external/node-gyp/gyp/pylib/gyp/MSVSSettings.py +0 -1272
  60. package/external/node-gyp/gyp/pylib/gyp/MSVSSettings_test.py +0 -1547
  61. package/external/node-gyp/gyp/pylib/gyp/MSVSToolFile.py +0 -59
  62. package/external/node-gyp/gyp/pylib/gyp/MSVSUserFile.py +0 -152
  63. package/external/node-gyp/gyp/pylib/gyp/MSVSUtil.py +0 -270
  64. package/external/node-gyp/gyp/pylib/gyp/MSVSVersion.py +0 -574
  65. package/external/node-gyp/gyp/pylib/gyp/__init__.py +0 -704
  66. package/external/node-gyp/gyp/pylib/gyp/common.py +0 -709
  67. package/external/node-gyp/gyp/pylib/gyp/common_test.py +0 -173
  68. package/external/node-gyp/gyp/pylib/gyp/easy_xml.py +0 -169
  69. package/external/node-gyp/gyp/pylib/gyp/easy_xml_test.py +0 -113
  70. package/external/node-gyp/gyp/pylib/gyp/flock_tool.py +0 -55
  71. package/external/node-gyp/gyp/pylib/gyp/generator/__init__.py +0 -0
  72. package/external/node-gyp/gyp/pylib/gyp/generator/analyzer.py +0 -805
  73. package/external/node-gyp/gyp/pylib/gyp/generator/android.py +0 -1172
  74. package/external/node-gyp/gyp/pylib/gyp/generator/cmake.py +0 -1319
  75. package/external/node-gyp/gyp/pylib/gyp/generator/compile_commands_json.py +0 -128
  76. package/external/node-gyp/gyp/pylib/gyp/generator/dump_dependency_json.py +0 -104
  77. package/external/node-gyp/gyp/pylib/gyp/generator/eclipse.py +0 -462
  78. package/external/node-gyp/gyp/pylib/gyp/generator/gypd.py +0 -89
  79. package/external/node-gyp/gyp/pylib/gyp/generator/gypsh.py +0 -56
  80. package/external/node-gyp/gyp/pylib/gyp/generator/make.py +0 -2745
  81. package/external/node-gyp/gyp/pylib/gyp/generator/msvs.py +0 -3976
  82. package/external/node-gyp/gyp/pylib/gyp/generator/msvs_test.py +0 -44
  83. package/external/node-gyp/gyp/pylib/gyp/generator/ninja.py +0 -2965
  84. package/external/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +0 -67
  85. package/external/node-gyp/gyp/pylib/gyp/generator/xcode.py +0 -1391
  86. package/external/node-gyp/gyp/pylib/gyp/generator/xcode_test.py +0 -26
  87. package/external/node-gyp/gyp/pylib/gyp/input.py +0 -3112
  88. package/external/node-gyp/gyp/pylib/gyp/input_test.py +0 -99
  89. package/external/node-gyp/gyp/pylib/gyp/mac_tool.py +0 -767
  90. package/external/node-gyp/gyp/pylib/gyp/msvs_emulation.py +0 -1260
  91. package/external/node-gyp/gyp/pylib/gyp/ninja_syntax.py +0 -174
  92. package/external/node-gyp/gyp/pylib/gyp/simple_copy.py +0 -61
  93. package/external/node-gyp/gyp/pylib/gyp/win_tool.py +0 -373
  94. package/external/node-gyp/gyp/pylib/gyp/xcode_emulation.py +0 -1939
  95. package/external/node-gyp/gyp/pylib/gyp/xcode_emulation_test.py +0 -54
  96. package/external/node-gyp/gyp/pylib/gyp/xcode_ninja.py +0 -303
  97. package/external/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +0 -3196
  98. package/external/node-gyp/gyp/pylib/gyp/xml_fix.py +0 -65
  99. package/external/node-gyp/gyp/pylib/packaging/LICENSE +0 -3
  100. package/external/node-gyp/gyp/pylib/packaging/LICENSE.APACHE +0 -177
  101. package/external/node-gyp/gyp/pylib/packaging/LICENSE.BSD +0 -23
  102. package/external/node-gyp/gyp/pylib/packaging/__init__.py +0 -15
  103. package/external/node-gyp/gyp/pylib/packaging/_elffile.py +0 -108
  104. package/external/node-gyp/gyp/pylib/packaging/_manylinux.py +0 -252
  105. package/external/node-gyp/gyp/pylib/packaging/_musllinux.py +0 -83
  106. package/external/node-gyp/gyp/pylib/packaging/_parser.py +0 -359
  107. package/external/node-gyp/gyp/pylib/packaging/_structures.py +0 -61
  108. package/external/node-gyp/gyp/pylib/packaging/_tokenizer.py +0 -192
  109. package/external/node-gyp/gyp/pylib/packaging/markers.py +0 -252
  110. package/external/node-gyp/gyp/pylib/packaging/metadata.py +0 -825
  111. package/external/node-gyp/gyp/pylib/packaging/py.typed +0 -0
  112. package/external/node-gyp/gyp/pylib/packaging/requirements.py +0 -90
  113. package/external/node-gyp/gyp/pylib/packaging/specifiers.py +0 -1030
  114. package/external/node-gyp/gyp/pylib/packaging/tags.py +0 -553
  115. package/external/node-gyp/gyp/pylib/packaging/utils.py +0 -172
  116. package/external/node-gyp/gyp/pylib/packaging/version.py +0 -563
  117. package/external/node-gyp/gyp/pyproject.toml +0 -115
  118. package/external/node-gyp/gyp/release-please-config.json +0 -11
  119. package/external/node-gyp/gyp/test_gyp.py +0 -261
  120. package/external/node-gyp/lib/Find-VisualStudio.cs +0 -250
  121. package/external/node-gyp/lib/build.js +0 -230
  122. package/external/node-gyp/lib/clean.js +0 -15
  123. package/external/node-gyp/lib/configure.js +0 -328
  124. package/external/node-gyp/lib/create-config-gypi.js +0 -153
  125. package/external/node-gyp/lib/download.js +0 -41
  126. package/external/node-gyp/lib/find-node-directory.js +0 -63
  127. package/external/node-gyp/lib/find-python.js +0 -310
  128. package/external/node-gyp/lib/find-visualstudio.js +0 -600
  129. package/external/node-gyp/lib/install.js +0 -415
  130. package/external/node-gyp/lib/list.js +0 -26
  131. package/external/node-gyp/lib/log.js +0 -168
  132. package/external/node-gyp/lib/node-gyp.js +0 -188
  133. package/external/node-gyp/lib/process-release.js +0 -148
  134. package/external/node-gyp/lib/rebuild.js +0 -12
  135. package/external/node-gyp/lib/remove.js +0 -43
  136. package/external/node-gyp/lib/util.js +0 -81
  137. package/external/node-gyp/macOS_Catalina_acid_test.sh +0 -21
  138. package/external/node-gyp/package.json +0 -52
  139. package/external/node-gyp/release-please-config.json +0 -40
  140. package/external/node-gyp/src/win_delay_load_hook.cc +0 -41
@@ -1,230 +0,0 @@
1
- 'use strict'
2
-
3
- const gracefulFs = require('graceful-fs')
4
- const fs = gracefulFs.promises
5
- const path = require('path')
6
- const { glob } = require('tinyglobby')
7
- const log = require('./log')
8
- const which = require('which')
9
- const win = process.platform === 'win32'
10
-
11
- async function build (gyp, argv) {
12
- let platformMake = 'make'
13
- if (process.platform === 'aix') {
14
- platformMake = 'gmake'
15
- } else if (process.platform === 'os400') {
16
- platformMake = 'gmake'
17
- } else if (process.platform.indexOf('bsd') !== -1) {
18
- platformMake = 'gmake'
19
- } else if (win && argv.length > 0) {
20
- argv = argv.map(function (target) {
21
- return '/t:' + target
22
- })
23
- }
24
-
25
- const makeCommand = gyp.opts.make || process.env.MAKE || platformMake
26
- let command = win ? 'msbuild' : makeCommand
27
- const jobs = gyp.opts.jobs || process.env.JOBS
28
- let buildType
29
- let config
30
- let arch
31
- let nodeDir
32
- let guessedSolution
33
- let python
34
- let buildBinsDir
35
-
36
- await loadConfigGypi()
37
-
38
- /**
39
- * Load the "config.gypi" file that was generated during "configure".
40
- */
41
-
42
- async function loadConfigGypi () {
43
- let data
44
- try {
45
- const configPath = path.resolve('build', 'config.gypi')
46
- data = await fs.readFile(configPath, 'utf8')
47
- } catch (err) {
48
- if (err.code === 'ENOENT') {
49
- throw new Error('You must run `node-gyp configure` first!')
50
- } else {
51
- throw err
52
- }
53
- }
54
-
55
- config = JSON.parse(data.replace(/#.+\n/, ''))
56
-
57
- // get the 'arch', 'buildType', and 'nodeDir' vars from the config
58
- buildType = config.target_defaults.default_configuration
59
- arch = config.variables.target_arch
60
- nodeDir = config.variables.nodedir
61
- python = config.variables.python
62
-
63
- if ('debug' in gyp.opts) {
64
- buildType = gyp.opts.debug ? 'Debug' : 'Release'
65
- }
66
- if (!buildType) {
67
- buildType = 'Release'
68
- }
69
-
70
- log.verbose('build type', buildType)
71
- log.verbose('architecture', arch)
72
- log.verbose('node dev dir', nodeDir)
73
- log.verbose('python', python)
74
-
75
- if (win) {
76
- await findSolutionFile()
77
- } else {
78
- await doWhich()
79
- }
80
- }
81
-
82
- /**
83
- * On Windows, find the first build/*.sln file.
84
- */
85
-
86
- async function findSolutionFile () {
87
- const files = await glob('build/*.sln', { expandDirectories: false })
88
- if (files.length === 0) {
89
- if (gracefulFs.existsSync('build/Makefile') ||
90
- (await glob('build/*.mk', { expandDirectories: false })).length !== 0) {
91
- command = makeCommand
92
- await doWhich(false)
93
- return
94
- } else {
95
- throw new Error('Could not find *.sln file or Makefile. Did you run "configure"?')
96
- }
97
- }
98
- guessedSolution = files[0]
99
- log.verbose('found first Solution file', guessedSolution)
100
- await doWhich(true)
101
- }
102
-
103
- /**
104
- * Uses node-which to locate the msbuild / make executable.
105
- */
106
-
107
- async function doWhich (msvs) {
108
- // On Windows use msbuild provided by node-gyp configure
109
- if (msvs) {
110
- if (!config.variables.msbuild_path) {
111
- throw new Error('MSBuild is not set, please run `node-gyp configure`.')
112
- }
113
- command = config.variables.msbuild_path
114
- log.verbose('using MSBuild:', command)
115
- await doBuild(msvs)
116
- return
117
- }
118
-
119
- // First make sure we have the build command in the PATH
120
- const execPath = await which(command)
121
- log.verbose('`which` succeeded for `' + command + '`', execPath)
122
- await doBuild(msvs)
123
- }
124
-
125
- /**
126
- * Actually spawn the process and compile the module.
127
- */
128
-
129
- async function doBuild (msvs) {
130
- // Enable Verbose build
131
- const verbose = log.logger.isVisible('verbose')
132
- let j
133
-
134
- if (!msvs && verbose) {
135
- argv.push('V=1')
136
- }
137
-
138
- if (msvs && !verbose) {
139
- argv.push('/clp:Verbosity=minimal')
140
- }
141
-
142
- if (msvs) {
143
- // Turn off the Microsoft logo on Windows
144
- argv.push('/nologo')
145
- // No lingering msbuild processes and open file handles
146
- argv.push('/nodeReuse:false')
147
- }
148
-
149
- // Specify the build type, Release by default
150
- if (msvs) {
151
- // Convert .gypi config target_arch to MSBuild /Platform
152
- // Since there are many ways to state '32-bit Intel', default to it.
153
- // N.B. msbuild's Condition string equality tests are case-insensitive.
154
- const archLower = arch.toLowerCase()
155
- const p = archLower === 'x64'
156
- ? 'x64'
157
- : (archLower === 'arm'
158
- ? 'ARM'
159
- : (archLower === 'arm64' ? 'ARM64' : 'Win32'))
160
- argv.push('/p:Configuration=' + buildType + ';Platform=' + p)
161
- if (jobs) {
162
- j = parseInt(jobs, 10)
163
- if (!isNaN(j) && j > 0) {
164
- argv.push('/m:' + j)
165
- } else if (jobs.toUpperCase() === 'MAX') {
166
- argv.push('/m:' + require('os').cpus().length)
167
- }
168
- }
169
- } else {
170
- argv.push('BUILDTYPE=' + buildType)
171
- // Invoke the Makefile in the 'build' dir.
172
- argv.push('-C')
173
- argv.push('build')
174
- if (jobs) {
175
- j = parseInt(jobs, 10)
176
- if (!isNaN(j) && j > 0) {
177
- argv.push('--jobs')
178
- argv.push(j)
179
- } else if (jobs.toUpperCase() === 'MAX') {
180
- argv.push('--jobs')
181
- argv.push(require('os').cpus().length)
182
- }
183
- }
184
- }
185
-
186
- if (msvs) {
187
- // did the user specify their own .sln file?
188
- const hasSln = argv.some(function (arg) {
189
- return path.extname(arg) === '.sln'
190
- })
191
- if (!hasSln) {
192
- argv.unshift(gyp.opts.solution || guessedSolution)
193
- }
194
- }
195
-
196
- if (!win) {
197
- // Add build-time dependency symlinks (such as Python) to PATH
198
- buildBinsDir = path.resolve('build', 'node_gyp_bins')
199
- process.env.PATH = `${buildBinsDir}:${process.env.PATH}`
200
- await fs.mkdir(buildBinsDir, { recursive: true })
201
- const symlinkDestination = path.join(buildBinsDir, 'python3')
202
- try {
203
- await fs.unlink(symlinkDestination)
204
- } catch (err) {
205
- if (err.code !== 'ENOENT') throw err
206
- }
207
- await fs.symlink(python, symlinkDestination)
208
- log.verbose('bin symlinks', `created symlink to "${python}" in "${buildBinsDir}" and added to PATH`)
209
- }
210
-
211
- const proc = gyp.spawn(command, argv)
212
- await new Promise((resolve, reject) => proc.on('exit', async (code, signal) => {
213
- if (buildBinsDir) {
214
- // Clean up the build-time dependency symlinks:
215
- await fs.rm(buildBinsDir, { recursive: true, maxRetries: 3 })
216
- }
217
-
218
- if (code !== 0) {
219
- return reject(new Error('`' + command + '` failed with exit code: ' + code))
220
- }
221
- if (signal) {
222
- return reject(new Error('`' + command + '` got signal: ' + signal))
223
- }
224
- resolve()
225
- }))
226
- }
227
- }
228
-
229
- module.exports = build
230
- module.exports.usage = 'Invokes `' + (win ? 'msbuild' : 'make') + '` and builds the module'
@@ -1,15 +0,0 @@
1
- 'use strict'
2
-
3
- const fs = require('graceful-fs').promises
4
- const log = require('./log')
5
-
6
- async function clean (gyp, argv) {
7
- // Remove the 'build' dir
8
- const buildDir = 'build'
9
-
10
- log.verbose('clean', 'removing "%s" directory', buildDir)
11
- await fs.rm(buildDir, { recursive: true, force: true, maxRetries: 3 })
12
- }
13
-
14
- module.exports = clean
15
- module.exports.usage = 'Removes any generated build files and the "out" dir'
@@ -1,328 +0,0 @@
1
- 'use strict'
2
-
3
- const { promises: fs, readFileSync } = require('graceful-fs')
4
- const path = require('path')
5
- const log = require('./log')
6
- const os = require('os')
7
- const processRelease = require('./process-release')
8
- const win = process.platform === 'win32'
9
- const findNodeDirectory = require('./find-node-directory')
10
- const { createConfigGypi } = require('./create-config-gypi')
11
- const { format: msgFormat } = require('util')
12
- const { findAccessibleSync } = require('./util')
13
- const { findPython } = require('./find-python')
14
- const { findVisualStudio } = win ? require('./find-visualstudio') : {}
15
-
16
- const majorRe = /^#define NODE_MAJOR_VERSION (\d+)/m
17
- const minorRe = /^#define NODE_MINOR_VERSION (\d+)/m
18
- const patchRe = /^#define NODE_PATCH_VERSION (\d+)/m
19
-
20
- async function configure (gyp, argv) {
21
- const buildDir = path.resolve('build')
22
- const configNames = ['config.gypi', 'common.gypi']
23
- const configs = []
24
- let nodeDir
25
- const release = processRelease(argv, gyp, process.version, process.release)
26
-
27
- const python = await findPython(gyp.opts.python)
28
- return getNodeDir()
29
-
30
- async function getNodeDir () {
31
- // 'python' should be set by now
32
- process.env.PYTHON = python
33
-
34
- if (!gyp.opts.nodedir &&
35
- process.config.variables.use_prefix_to_find_headers) {
36
- // check if the headers can be found using the prefix specified
37
- // at build time. Use them if they match the version expected
38
- const prefix = process.config.variables.node_prefix
39
- let availVersion
40
- try {
41
- const nodeVersionH = readFileSync(path.join(prefix,
42
- 'include', 'node', 'node_version.h'), { encoding: 'utf8' })
43
- const major = nodeVersionH.match(majorRe)[1]
44
- const minor = nodeVersionH.match(minorRe)[1]
45
- const patch = nodeVersionH.match(patchRe)[1]
46
- availVersion = major + '.' + minor + '.' + patch
47
- } catch {}
48
- if (availVersion === release.version) {
49
- // ok version matches, use the headers
50
- gyp.opts.nodedir = prefix
51
- log.verbose('using local node headers based on prefix',
52
- 'setting nodedir to ' + gyp.opts.nodedir)
53
- }
54
- }
55
-
56
- if (gyp.opts.nodedir) {
57
- // --nodedir was specified. use that for the dev files
58
- nodeDir = gyp.opts.nodedir.replace(/^~/, os.homedir())
59
- log.verbose('get node dir', 'compiling against specified --nodedir dev files: %s', nodeDir)
60
- } else {
61
- // if no --nodedir specified, ensure node dependencies are installed
62
- if ('v' + release.version !== process.version) {
63
- // if --target was given, then determine a target version to compile for
64
- log.verbose('get node dir', 'compiling against --target node version: %s', release.version)
65
- } else {
66
- // if no --target was specified then use the current host node version
67
- log.verbose('get node dir', 'no --target version specified, falling back to host node version: %s', release.version)
68
- }
69
-
70
- if (!release.semver) {
71
- // could not parse the version string with semver
72
- throw new Error('Invalid version number: ' + release.version)
73
- }
74
-
75
- // If the tarball option is set, always remove and reinstall the headers
76
- // into devdir. Otherwise only install if they're not already there.
77
- gyp.opts.ensure = !gyp.opts.tarball
78
-
79
- await gyp.commands.install([release.version])
80
-
81
- log.verbose('get node dir', 'target node version installed:', release.versionDir)
82
- nodeDir = path.resolve(gyp.devDir, release.versionDir)
83
- }
84
-
85
- return createBuildDir()
86
- }
87
-
88
- async function createBuildDir () {
89
- log.verbose('build dir', 'attempting to create "build" dir: %s', buildDir)
90
-
91
- const isNew = await fs.mkdir(buildDir, { recursive: true })
92
- log.verbose(
93
- 'build dir', '"build" dir needed to be created?', isNew ? 'Yes' : 'No'
94
- )
95
- if (win) {
96
- let usingMakeGenerator = false
97
- for (let i = argv.length - 1; i >= 0; --i) {
98
- const arg = argv[i]
99
- if (arg === '-f' || arg === '--format') {
100
- const format = argv[i + 1]
101
- if (typeof format === 'string' && format.startsWith('make')) {
102
- usingMakeGenerator = true
103
- break
104
- }
105
- } else if (arg.startsWith('--format=make')) {
106
- usingMakeGenerator = true
107
- break
108
- }
109
- }
110
- let vsInfo = {}
111
- if (!usingMakeGenerator) {
112
- vsInfo = await findVisualStudio(release.semver, gyp.opts['msvs-version'])
113
- }
114
- return createConfigFile(vsInfo)
115
- }
116
- return createConfigFile(null)
117
- }
118
-
119
- async function createConfigFile (vsInfo) {
120
- if (win) {
121
- process.env.GYP_MSVS_VERSION = Math.min(vsInfo.versionYear, 2015)
122
- process.env.GYP_MSVS_OVERRIDE_PATH = vsInfo.path
123
- }
124
- const configPath = await createConfigGypi({ gyp, buildDir, nodeDir, vsInfo, python })
125
- configs.push(configPath)
126
- return findConfigs()
127
- }
128
-
129
- async function findConfigs () {
130
- const name = configNames.shift()
131
- if (!name) {
132
- return runGyp()
133
- }
134
-
135
- const fullPath = path.resolve(name)
136
- log.verbose(name, 'checking for gypi file: %s', fullPath)
137
- try {
138
- await fs.stat(fullPath)
139
- log.verbose(name, 'found gypi file')
140
- configs.push(fullPath)
141
- } catch (err) {
142
- // ENOENT will check next gypi filename
143
- if (err.code !== 'ENOENT') {
144
- throw err
145
- }
146
- }
147
-
148
- return findConfigs()
149
- }
150
-
151
- async function runGyp () {
152
- if (!~argv.indexOf('-f') && !~argv.indexOf('--format')) {
153
- if (win) {
154
- log.verbose('gyp', 'gyp format was not specified; forcing "msvs"')
155
- // force the 'make' target for non-Windows
156
- argv.push('-f', 'msvs')
157
- } else {
158
- log.verbose('gyp', 'gyp format was not specified; forcing "make"')
159
- // force the 'make' target for non-Windows
160
- argv.push('-f', 'make')
161
- }
162
- }
163
-
164
- // include all the ".gypi" files that were found
165
- configs.forEach(function (config) {
166
- argv.push('-I', config)
167
- })
168
-
169
- // For AIX and z/OS we need to set up the path to the exports file
170
- // which contains the symbols needed for linking.
171
- let nodeExpFile
172
- let nodeRootDir
173
- let candidates
174
- let logprefix = 'find exports file'
175
- if (process.platform === 'aix' || process.platform === 'os390' || process.platform === 'os400') {
176
- const ext = process.platform === 'os390' ? 'x' : 'exp'
177
- nodeRootDir = findNodeDirectory()
178
-
179
- if (process.platform === 'aix' || process.platform === 'os400') {
180
- candidates = [
181
- 'include/node/node',
182
- 'out/Release/node',
183
- 'out/Debug/node',
184
- 'node'
185
- ].map(function (file) {
186
- return file + '.' + ext
187
- })
188
- } else {
189
- candidates = [
190
- 'out/Release/lib.target/libnode',
191
- 'out/Debug/lib.target/libnode',
192
- 'out/Release/obj.target/libnode',
193
- 'out/Debug/obj.target/libnode',
194
- 'lib/libnode'
195
- ].map(function (file) {
196
- return file + '.' + ext
197
- })
198
- }
199
-
200
- nodeExpFile = findAccessibleSync(logprefix, nodeRootDir, candidates)
201
- if (nodeExpFile !== undefined) {
202
- log.verbose(logprefix, 'Found exports file: %s', nodeExpFile)
203
- } else {
204
- const msg = msgFormat('Could not find node.%s file in %s', ext, nodeRootDir)
205
- log.error(logprefix, 'Could not find exports file')
206
- throw new Error(msg)
207
- }
208
- }
209
-
210
- // For z/OS we need to set up the path to zoslib include directory,
211
- // which contains headers included in v8config.h.
212
- let zoslibIncDir
213
- if (process.platform === 'os390') {
214
- logprefix = "find zoslib's zos-base.h:"
215
- let msg
216
- let zoslibIncPath = process.env.ZOSLIB_INCLUDES
217
- if (zoslibIncPath) {
218
- zoslibIncPath = findAccessibleSync(logprefix, zoslibIncPath, ['zos-base.h'])
219
- if (zoslibIncPath === undefined) {
220
- msg = msgFormat('Could not find zos-base.h file in the directory set ' +
221
- 'in ZOSLIB_INCLUDES environment variable: %s; set it ' +
222
- 'to the correct path, or unset it to search %s', process.env.ZOSLIB_INCLUDES, nodeRootDir)
223
- }
224
- } else {
225
- candidates = [
226
- 'include/node/zoslib/zos-base.h',
227
- 'include/zoslib/zos-base.h',
228
- 'zoslib/include/zos-base.h',
229
- 'install/include/node/zoslib/zos-base.h'
230
- ]
231
- zoslibIncPath = findAccessibleSync(logprefix, nodeRootDir, candidates)
232
- if (zoslibIncPath === undefined) {
233
- msg = msgFormat('Could not find any of %s in directory %s; set ' +
234
- 'environmant variable ZOSLIB_INCLUDES to the path ' +
235
- 'that contains zos-base.h', candidates.toString(), nodeRootDir)
236
- }
237
- }
238
- if (zoslibIncPath !== undefined) {
239
- zoslibIncDir = path.dirname(zoslibIncPath)
240
- log.verbose(logprefix, "Found zoslib's zos-base.h in: %s", zoslibIncDir)
241
- } else if (release.version.split('.')[0] >= 16) {
242
- // zoslib is only shipped in Node v16 and above.
243
- log.error(logprefix, msg)
244
- throw new Error(msg)
245
- }
246
- }
247
-
248
- // this logic ported from the old `gyp_addon` python file
249
- const gypScript = path.resolve(__dirname, '..', 'gyp', 'gyp_main.py')
250
- const addonGypi = path.resolve(__dirname, '..', 'addon.gypi')
251
- let commonGypi = path.resolve(nodeDir, 'include/node/common.gypi')
252
- try {
253
- await fs.stat(commonGypi)
254
- } catch (err) {
255
- commonGypi = path.resolve(nodeDir, 'common.gypi')
256
- }
257
-
258
- let outputDir = 'build'
259
- if (win) {
260
- // Windows expects an absolute path
261
- outputDir = buildDir
262
- }
263
- const nodeGypDir = path.resolve(__dirname, '..')
264
-
265
- let nodeLibFile = path.join(nodeDir,
266
- !gyp.opts.nodedir ? '<(target_arch)' : '$(Configuration)',
267
- release.name + '.lib')
268
-
269
- argv.push('-I', addonGypi)
270
- argv.push('-I', commonGypi)
271
- argv.push('-Dlibrary=shared_library')
272
- argv.push('-Dvisibility=default')
273
- argv.push('-Dnode_root_dir=' + nodeDir)
274
- if (process.platform === 'aix' || process.platform === 'os390' || process.platform === 'os400') {
275
- argv.push('-Dnode_exp_file=' + nodeExpFile)
276
- if (process.platform === 'os390' && zoslibIncDir) {
277
- argv.push('-Dzoslib_include_dir=' + zoslibIncDir)
278
- }
279
- }
280
- argv.push('-Dnode_gyp_dir=' + nodeGypDir)
281
-
282
- // Do this to keep Cygwin environments happy, else the unescaped '\' gets eaten up,
283
- // resulting in bad paths, Ex c:parentFolderfolderanotherFolder instead of c:\parentFolder\folder\anotherFolder
284
- if (win) {
285
- nodeLibFile = nodeLibFile.replace(/\\/g, '\\\\')
286
- }
287
- argv.push('-Dnode_lib_file=' + nodeLibFile)
288
- argv.push('-Dmodule_root_dir=' + process.cwd())
289
- argv.push('-Dnode_engine=' +
290
- (gyp.opts.node_engine || process.jsEngine || 'v8'))
291
- argv.push('--depth=.')
292
- argv.push('--no-parallel')
293
-
294
- // tell gyp to write the Makefile/Solution files into output_dir
295
- argv.push('--generator-output', outputDir)
296
-
297
- // tell make to write its output into the same dir
298
- argv.push('-Goutput_dir=.')
299
-
300
- // enforce use of the "binding.gyp" file
301
- argv.unshift('binding.gyp')
302
-
303
- // execute `gyp` from the current target nodedir
304
- argv.unshift(gypScript)
305
-
306
- // make sure python uses files that came with this particular node package
307
- const pypath = [path.join(__dirname, '..', 'gyp', 'pylib')]
308
- if (process.env.PYTHONPATH) {
309
- pypath.push(process.env.PYTHONPATH)
310
- }
311
- process.env.PYTHONPATH = pypath.join(win ? ';' : ':')
312
-
313
- await new Promise((resolve, reject) => {
314
- const cp = gyp.spawn(python, argv)
315
- cp.on('exit', (code) => {
316
- if (code !== 0) {
317
- reject(new Error('`gyp` failed with exit code: ' + code))
318
- } else {
319
- // we're done
320
- resolve()
321
- }
322
- })
323
- })
324
- }
325
- }
326
-
327
- module.exports = configure
328
- module.exports.usage = 'Generates ' + (win ? 'MSVC project files' : 'a Makefile') + ' for the current module'