wrangler-action/node_modules/@changesets/pre/dist/pre.esm.js
2023-08-07 15:11:15 -05:00

118 lines
3.3 KiB
JavaScript

import { readFile, outputFile } from 'fs-extra';
import path from 'path';
import { getPackages } from '@manypkg/get-packages';
import { PreExitButNotInPreModeError, PreEnterButInPreModeError } from '@changesets/errors';
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.resolve(cwd, ".changeset", "pre.json"); // TODO: verify that the pre state isn't broken
let preState;
try {
let contents = await 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.resolve(cwd, ".changeset", "pre.json"); // TODO: verify that the pre state isn't broken
let preState = await readPreState(cwd);
if (preState === undefined) {
throw new PreExitButNotInPreModeError();
}
await outputFile(preStatePath, JSON.stringify(_objectSpread2(_objectSpread2({}, preState), {}, {
mode: "exit"
}), null, 2) + "\n");
}
async function enterPre(cwd, tag) {
var _preState$changesets;
let packages = await getPackages(cwd);
let preStatePath = path.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 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 outputFile(preStatePath, JSON.stringify(newPreState, null, 2) + "\n");
}
export { enterPre, exitPre, readPreState };