wrangler-action/node_modules/@changesets/pre/dist/pre.cjs.dev.js

129 lines
3.6 KiB
JavaScript
Raw Normal View History

2023-08-07 22:11:15 +02:00
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var fs = require('fs-extra');
var path = require('path');
var getPackages = require('@manypkg/get-packages');
var errors = require('@changesets/errors');
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
var path__default = /*#__PURE__*/_interopDefault(path);
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
if (enumerableOnly) symbols = symbols.filter(function (sym) {
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
});
keys.push.apply(keys, symbols);
}
return keys;
}
function _objectSpread2(target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i] != null ? arguments[i] : {};
if (i % 2) {
ownKeys(Object(source), true).forEach(function (key) {
_defineProperty(target, key, source[key]);
});
} else if (Object.getOwnPropertyDescriptors) {
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
} else {
ownKeys(Object(source)).forEach(function (key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
}
return target;
}
async function readPreState(cwd) {
let preStatePath = path__default['default'].resolve(cwd, ".changeset", "pre.json"); // TODO: verify that the pre state isn't broken
let preState;
try {
let contents = await fs.readFile(preStatePath, "utf8");
try {
preState = JSON.parse(contents);
} catch (err) {
if (err instanceof SyntaxError) {
console.error("error parsing json:", contents);
}
throw err;
}
} catch (err) {
if (err.code !== "ENOENT") {
throw err;
}
}
return preState;
}
async function exitPre(cwd) {
let preStatePath = path__default['default'].resolve(cwd, ".changeset", "pre.json"); // TODO: verify that the pre state isn't broken
let preState = await readPreState(cwd);
if (preState === undefined) {
throw new errors.PreExitButNotInPreModeError();
}
await fs.outputFile(preStatePath, JSON.stringify(_objectSpread2(_objectSpread2({}, preState), {}, {
mode: "exit"
}), null, 2) + "\n");
}
async function enterPre(cwd, tag) {
var _preState$changesets;
let packages = await getPackages.getPackages(cwd);
let preStatePath = path__default['default'].resolve(packages.root.dir, ".changeset", "pre.json");
let preState = await readPreState(packages.root.dir); // can't reenter if pre mode still exists, but we should allow exited pre mode to be reentered
if ((preState === null || preState === void 0 ? void 0 : preState.mode) === "pre") {
throw new errors.PreEnterButInPreModeError();
}
let newPreState = {
mode: "pre",
tag,
initialVersions: {},
changesets: (_preState$changesets = preState === null || preState === void 0 ? void 0 : preState.changesets) !== null && _preState$changesets !== void 0 ? _preState$changesets : []
};
for (let pkg of packages.packages) {
newPreState.initialVersions[pkg.packageJson.name] = pkg.packageJson.version;
}
await fs.outputFile(preStatePath, JSON.stringify(newPreState, null, 2) + "\n");
}
exports.enterPre = enterPre;
exports.exitPre = exitPre;
exports.readPreState = readPreState;