Son CV dans un terminal web en Javascript!
https://terminal-cv.gregandev.fr
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
180 lines
4.2 KiB
180 lines
4.2 KiB
2 years ago
|
"use strict";
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.Pnpm = void 0;
|
||
|
|
||
|
function _commandExists() {
|
||
|
const data = _interopRequireDefault(require("command-exists"));
|
||
|
|
||
|
_commandExists = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
function _crossSpawn() {
|
||
|
const data = _interopRequireDefault(require("cross-spawn"));
|
||
|
|
||
|
_crossSpawn = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
function _logger() {
|
||
|
const data = _interopRequireDefault(require("@parcel/logger"));
|
||
|
|
||
|
_logger = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
function _split() {
|
||
|
const data = _interopRequireDefault(require("split2"));
|
||
|
|
||
|
_split = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
var _JSONParseStream = _interopRequireDefault(require("./JSONParseStream"));
|
||
|
|
||
|
var _promiseFromProcess = _interopRequireDefault(require("./promiseFromProcess"));
|
||
|
|
||
|
function _core() {
|
||
|
const data = require("@parcel/core");
|
||
|
|
||
|
_core = function () {
|
||
|
return data;
|
||
|
};
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
var _utils = require("./utils");
|
||
|
|
||
|
var _package = _interopRequireDefault(require("../package.json"));
|
||
|
|
||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
|
||
|
// $FlowFixMe
|
||
|
const PNPM_CMD = 'pnpm';
|
||
|
let hasPnpm;
|
||
|
|
||
|
class Pnpm {
|
||
|
static async exists() {
|
||
|
if (hasPnpm != null) {
|
||
|
return hasPnpm;
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
hasPnpm = Boolean(await (0, _commandExists().default)('pnpm'));
|
||
|
} catch (err) {
|
||
|
hasPnpm = false;
|
||
|
}
|
||
|
|
||
|
return hasPnpm;
|
||
|
}
|
||
|
|
||
|
async install({
|
||
|
modules,
|
||
|
cwd,
|
||
|
saveDev = true
|
||
|
}) {
|
||
|
let args = ['add', '--reporter', 'ndjson'];
|
||
|
|
||
|
if (saveDev) {
|
||
|
args.push('-D');
|
||
|
}
|
||
|
|
||
|
args = args.concat(modules.map(_utils.npmSpecifierFromModuleRequest));
|
||
|
let env = {};
|
||
|
|
||
|
for (let key in process.env) {
|
||
|
if (!key.startsWith('npm_') && key !== 'INIT_CWD' && key !== 'NODE_ENV') {
|
||
|
env[key] = process.env[key];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
let addedCount = 0,
|
||
|
removedCount = 0;
|
||
|
let installProcess = (0, _crossSpawn().default)(PNPM_CMD, args, {
|
||
|
cwd,
|
||
|
env
|
||
|
});
|
||
|
installProcess.stdout.pipe((0, _split().default)()).pipe(new _JSONParseStream.default()).on('error', e => {
|
||
|
_logger().default.warn({
|
||
|
origin: '@parcel/package-manager',
|
||
|
message: e.chunk,
|
||
|
stack: e.stack
|
||
|
});
|
||
|
}).on('data', json => {
|
||
|
if (json.level === 'error') {
|
||
|
_logger().default.error({
|
||
|
origin: '@parcel/package-manager',
|
||
|
message: json.err.message,
|
||
|
stack: json.err.stack
|
||
|
});
|
||
|
} else if (json.level === 'info' && typeof json.message === 'string') {
|
||
|
_logger().default.info({
|
||
|
origin: '@parcel/package-manager',
|
||
|
message: prefix(json.message)
|
||
|
});
|
||
|
} else if (json.name === 'pnpm:stats') {
|
||
|
var _json$added, _json$removed;
|
||
|
|
||
|
addedCount += (_json$added = json.added) !== null && _json$added !== void 0 ? _json$added : 0;
|
||
|
removedCount += (_json$removed = json.removed) !== null && _json$removed !== void 0 ? _json$removed : 0;
|
||
|
}
|
||
|
});
|
||
|
let stderr = [];
|
||
|
installProcess.stderr.on('data', str => {
|
||
|
stderr.push(str.toString());
|
||
|
}).on('error', e => {
|
||
|
_logger().default.warn({
|
||
|
origin: '@parcel/package-manager',
|
||
|
message: e.message
|
||
|
});
|
||
|
});
|
||
|
|
||
|
try {
|
||
|
await (0, _promiseFromProcess.default)(installProcess);
|
||
|
|
||
|
if (addedCount > 0 || removedCount > 0) {
|
||
|
_logger().default.log({
|
||
|
origin: '@parcel/package-manager',
|
||
|
message: `Added ${addedCount} and ${removedCount > 0 ? `removed ${removedCount}` : ''} packages via pnpm`
|
||
|
});
|
||
|
} // Since we succeeded, stderr might have useful information not included
|
||
|
// in the json written to stdout. It's also not necessary to log these as
|
||
|
// errors as they often aren't.
|
||
|
|
||
|
|
||
|
for (let message of stderr) {
|
||
|
_logger().default.log({
|
||
|
origin: '@parcel/package-manager',
|
||
|
message
|
||
|
});
|
||
|
}
|
||
|
} catch (e) {
|
||
|
throw new Error('pnpm failed to install modules');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
exports.Pnpm = Pnpm;
|
||
|
|
||
|
function prefix(message) {
|
||
|
return 'pnpm: ' + message;
|
||
|
}
|
||
|
|
||
|
(0, _core().registerSerializableClass)(`${_package.default.version}:Pnpm`, Pnpm);
|