diff options
author | Minteck <nekostarfan@gmail.com> | 2021-08-24 14:41:48 +0200 |
---|---|---|
committer | Minteck <nekostarfan@gmail.com> | 2021-08-24 14:41:48 +0200 |
commit | d25e11bee6ca5ca523884da132d18e1400e077b9 (patch) | |
tree | 8af39fde19f7ed640a60fb397c7edd647dff1c4c /node_modules/nexe/lib/steps/bundle.js | |
download | kartik-iridium-d25e11bee6ca5ca523884da132d18e1400e077b9.tar.gz kartik-iridium-d25e11bee6ca5ca523884da132d18e1400e077b9.tar.bz2 kartik-iridium-d25e11bee6ca5ca523884da132d18e1400e077b9.zip |
Initial commit
Diffstat (limited to 'node_modules/nexe/lib/steps/bundle.js')
-rw-r--r-- | node_modules/nexe/lib/steps/bundle.js | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/node_modules/nexe/lib/steps/bundle.js b/node_modules/nexe/lib/steps/bundle.js new file mode 100644 index 0000000..d09f470 --- /dev/null +++ b/node_modules/nexe/lib/steps/bundle.js @@ -0,0 +1,79 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const compiler_1 = require("../compiler"); +const path_1 = require("path"); +const resolve_dependencies_1 = require("resolve-dependencies"); +const util_1 = require("../util"); +function getStdIn(stdin) { + let out = ''; + return new Promise((resolve) => { + stdin + .setEncoding('utf8') + .on('readable', () => { + let current; + while ((current = stdin.read())) { + out += current; + } + }) + .on('end', () => resolve(out.trim())); + setTimeout(() => { + if (!out.trim()) { + resolve(out.trim()); + } + }, 1000); + }); +} +function bundle(compiler, next) { + return __awaiter(this, void 0, void 0, function* () { + const { bundle: doBundle, cwd, input: inputPath } = compiler.options; + let input = inputPath; + compiler.entrypoint = './' + path_1.relative(cwd, input); + if (util_1.semverGt(compiler.target.version, '11.99')) { + compiler.startup = ''; + } + else { + compiler.startup = ';require("module").runMain();'; + } + if (!doBundle) { + yield compiler.addResource(path_1.resolve(cwd, input)); + return next(); + } + let code = ''; + if (typeof doBundle === 'string') { + code = yield require(doBundle).createBundle(compiler.options); + } + if (input === util_1.STDIN_FLAG && (code = code || util_1.dequote(yield getStdIn(process.stdin)))) { + compiler.stdinUsed = true; + compiler.entrypoint = './__nexe_stdin.js'; + yield compiler.addResource(path_1.resolve(cwd, compiler.entrypoint), code); + return next(); + } + if (input === util_1.STDIN_FLAG) { + const maybeInput = resolve_dependencies_1.resolveSync(cwd, '.'); + if (!maybeInput || !maybeInput.absPath) { + throw new compiler_1.NexeError('No valid input detected'); + } + input = maybeInput.absPath; + compiler.entrypoint = './' + path_1.relative(cwd, input); + } + const { files, warnings } = resolve_dependencies_1.default(input, ...Object.keys(compiler.bundle.list).filter((x) => x.endsWith('.js')), { cwd, expand: 'variable', loadContent: false }); + if (warnings.filter((x) => x.startsWith('Error parsing file') && !x.includes('node_modules')).length) { + throw new compiler_1.NexeError('Parsing Error:\n' + warnings.join('\n')); + } + //TODO: warnings.forEach((x) => console.log(x)) + yield Promise.all(Object.entries(files).map(([key, file]) => { + return compiler.addResource(key, file); + })); + return next(); + }); +} +exports.default = bundle; |