Socket
Socket
Sign inDemoInstall

patch-package

Package Overview
Dependencies
Maintainers
1
Versions
95
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

patch-package - npm Package Compare versions

Comparing version 8.0.0-canary.2 to 8.0.0-canary.3

dist/rebase.js

8

CHANGELOG.md
# Changelog
## 7.0.0
## 7.0.2
- Bump semver again (contribution from @rsanchez in #477)
## 7.0.1
- Bump semver (contribution from @stianjensen in #466)
### Breaking changes

@@ -6,0 +12,0 @@

318

dist/applyPatches.js

@@ -6,3 +6,3 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
exports.applyPatch = exports.applyPatchesForApp = void 0;
exports.applyPatch = exports.applyPatchesForPackage = exports.applyPatchesForApp = void 0;
const chalk_1 = __importDefault(require("chalk"));

@@ -13,2 +13,3 @@ const fs_extra_1 = require("fs-extra");

const hash_1 = require("./hash");
const makePatch_1 = require("./makePatch");
const packageIsDevDependency_1 = require("./packageIsDevDependency");

@@ -66,120 +67,11 @@ const apply_1 = require("./patch/apply");

const warnings = [...groupedPatches.warnings];
for (const [pathSpecifier, patches] of Object.entries(groupedPatches.pathSpecifierToPatchFiles)) {
const state = patches.length > 1 ? stateFile_1.getPatchApplicationState(patches[0]) : null;
const unappliedPatches = patches.slice(0);
const newState = patches.length > 1 ? [] : null;
// if there are multiple patches to apply, we can't rely on the reverse-patch-dry-run behavior to make this operation
// idempotent, so instead we need to check the state file to see whether we have already applied any of the patches
// todo: once this is battle tested we might want to use the same approach for single patches as well, but it's not biggie since the dry run thing is fast
if (unappliedPatches && state) {
for (let i = 0; i < state.patches.length; i++) {
const patchThatWasApplied = state.patches[i];
const patchToApply = unappliedPatches[0];
const currentPatchHash = hash_1.hashFile(path_2.join(appPath, patchDir, patchToApply.patchFilename));
if (patchThatWasApplied.patchContentHash === currentPatchHash) {
// this patch was applied we can skip it
unappliedPatches.shift();
}
else {
console.error(chalk_1.default.red("Error:"), `The patches for ${chalk_1.default.bold(pathSpecifier)} have changed.`, `You should reinstall your node_modules folder to make sure the package is up to date`);
process.exit(1);
}
}
}
if (unappliedPatches.length === 0) {
// all patches have already been applied
patches.forEach(logPatchApplication);
continue;
}
packageLoop: for (const patchDetails of patches) {
try {
const { name, version, path, isDevOnly, patchFilename } = patchDetails;
const installedPackageVersion = getInstalledPackageVersion({
appPath,
path,
pathSpecifier,
isDevOnly: isDevOnly ||
// check for direct-dependents in prod
(process.env.NODE_ENV === "production" &&
packageIsDevDependency_1.packageIsDevDependency({
appPath,
patchDetails,
})),
patchFilename,
});
if (!installedPackageVersion) {
// it's ok we're in production mode and this is a dev only package
console.log(`Skipping dev-only ${chalk_1.default.bold(pathSpecifier)}@${version} ${chalk_1.default.blue("✔")}`);
continue;
}
if (applyPatch({
patchFilePath: path_2.resolve(patchesDirectory, patchFilename),
reverse,
patchDetails,
patchDir,
cwd: process.cwd(),
})) {
newState === null || newState === void 0 ? void 0 : newState.push({
patchFilename,
patchContentHash: hash_1.hashFile(path_2.join(appPath, patchDir, patchFilename)),
didApply: true,
});
// yay patch was applied successfully
// print warning if version mismatch
if (installedPackageVersion !== version) {
warnings.push(createVersionMismatchWarning({
packageName: name,
actualVersion: installedPackageVersion,
originalVersion: version,
pathSpecifier,
path,
}));
}
logPatchApplication(patchDetails);
}
else if (installedPackageVersion === version) {
// completely failed to apply patch
// TODO: propagate useful error messages from patch application
errors.push(createBrokenPatchFileError({
packageName: name,
patchFilename,
pathSpecifier,
path,
}));
// in case the package has multiple patches, we need to break out of this inner loop
// because we don't want to apply more patches on top of the broken state
break packageLoop;
}
else {
errors.push(createPatchApplicationFailureError({
packageName: name,
actualVersion: installedPackageVersion,
originalVersion: version,
patchFilename,
path,
pathSpecifier,
}));
// in case the package has multiple patches, we need to break out of this inner loop
// because we don't want to apply more patches on top of the broken state
break packageLoop;
}
}
catch (error) {
if (error instanceof PatchApplicationError) {
errors.push(error.message);
}
else {
errors.push(createUnexpectedError({
filename: patchDetails.patchFilename,
error: error,
}));
}
// in case the package has multiple patches, we need to break out of this inner loop
// because we don't want to apply more patches on top of the broken state
break packageLoop;
}
}
if (newState) {
stateFile_1.savePatchApplicationState(patches[0], newState);
}
for (const patches of Object.values(groupedPatches.pathSpecifierToPatchFiles)) {
applyPatchesForPackage({
patches,
appPath,
patchDir,
reverse,
warnings,
errors,
});
}

@@ -212,2 +104,184 @@ for (const warning of warnings) {

exports.applyPatchesForApp = applyPatchesForApp;
function applyPatchesForPackage({ patches, appPath, patchDir, reverse, warnings, errors, }) {
const pathSpecifier = patches[0].pathSpecifier;
const state = patches.length > 1 ? stateFile_1.getPatchApplicationState(patches[0]) : null;
const unappliedPatches = patches.slice(0);
const appliedPatches = [];
// if there are multiple patches to apply, we can't rely on the reverse-patch-dry-run behavior to make this operation
// idempotent, so instead we need to check the state file to see whether we have already applied any of the patches
// todo: once this is battle tested we might want to use the same approach for single patches as well, but it's not biggie since the dry run thing is fast
if (unappliedPatches && state) {
for (let i = 0; i < state.patches.length; i++) {
const patchThatWasApplied = state.patches[i];
const patchToApply = unappliedPatches[0];
const currentPatchHash = hash_1.hashFile(path_2.join(appPath, patchDir, patchToApply.patchFilename));
if (patchThatWasApplied.patchContentHash === currentPatchHash) {
// this patch was applied we can skip it
appliedPatches.push(unappliedPatches.shift());
}
else {
console.error(chalk_1.default.red("Error:"), `The patches for ${chalk_1.default.bold(pathSpecifier)} have changed.`, `You should reinstall your node_modules folder to make sure the package is up to date`);
process.exit(1);
}
}
}
if (reverse && state) {
// if we are reversing the patches we need to make the unappliedPatches array
// be the reversed version of the appliedPatches array.
// The applied patches array should then be empty because it is used differently
// when outputting the state file.
unappliedPatches.length = 0;
unappliedPatches.push(...appliedPatches);
unappliedPatches.reverse();
appliedPatches.length = 0;
}
if (appliedPatches.length) {
// some patches have already been applied
appliedPatches.forEach(logPatchApplication);
}
if (!unappliedPatches.length) {
return;
}
let failedPatch = null;
packageLoop: for (const patchDetails of unappliedPatches) {
try {
const { name, version, path, isDevOnly, patchFilename } = patchDetails;
const installedPackageVersion = getInstalledPackageVersion({
appPath,
path,
pathSpecifier,
isDevOnly: isDevOnly ||
// check for direct-dependents in prod
(process.env.NODE_ENV === "production" &&
packageIsDevDependency_1.packageIsDevDependency({
appPath,
patchDetails,
})),
patchFilename,
});
if (!installedPackageVersion) {
// it's ok we're in production mode and this is a dev only package
console.log(`Skipping dev-only ${chalk_1.default.bold(pathSpecifier)}@${version} ${chalk_1.default.blue("✔")}`);
continue;
}
if (applyPatch({
patchFilePath: path_2.join(appPath, patchDir, patchFilename),
reverse,
patchDetails,
patchDir,
cwd: process.cwd(),
})) {
appliedPatches.push(patchDetails);
// yay patch was applied successfully
// print warning if version mismatch
if (installedPackageVersion !== version) {
warnings.push(createVersionMismatchWarning({
packageName: name,
actualVersion: installedPackageVersion,
originalVersion: version,
pathSpecifier,
path,
}));
}
logPatchApplication(patchDetails);
}
else if (patches.length > 1) {
makePatch_1.logPatchSequenceError({ patchDetails });
// in case the package has multiple patches, we need to break out of this inner loop
// because we don't want to apply more patches on top of the broken state
failedPatch = patchDetails;
break packageLoop;
}
else if (installedPackageVersion === version) {
// completely failed to apply patch
// TODO: propagate useful error messages from patch application
errors.push(createBrokenPatchFileError({
packageName: name,
patchFilename,
pathSpecifier,
path,
}));
break packageLoop;
}
else {
errors.push(createPatchApplicationFailureError({
packageName: name,
actualVersion: installedPackageVersion,
originalVersion: version,
patchFilename,
path,
pathSpecifier,
}));
// in case the package has multiple patches, we need to break out of this inner loop
// because we don't want to apply more patches on top of the broken state
break packageLoop;
}
}
catch (error) {
if (error instanceof PatchApplicationError) {
errors.push(error.message);
}
else {
errors.push(createUnexpectedError({
filename: patchDetails.patchFilename,
error: error,
}));
}
// in case the package has multiple patches, we need to break out of this inner loop
// because we don't want to apply more patches on top of the broken state
break packageLoop;
}
}
if (patches.length > 1) {
if (reverse) {
if (!state) {
throw new Error("unexpected state: no state file found while reversing");
}
// if we removed all the patches that were previously applied we can delete the state file
if (appliedPatches.length === patches.length) {
stateFile_1.clearPatchApplicationState(patches[0]);
}
else {
// We failed while reversing patches and some are still in the applied state.
// We need to update the state file to reflect that.
// appliedPatches is currently the patches that were successfully reversed, in the order they were reversed
// So we need to find the index of the last reversed patch in the original patches array
// and then remove all the patches after that. Sorry for the confusing code.
const lastReversedPatchIndex = patches.indexOf(appliedPatches[appliedPatches.length - 1]);
if (lastReversedPatchIndex === -1) {
throw new Error("unexpected state: failed to find last reversed patch in original patches array");
}
stateFile_1.savePatchApplicationState({
packageDetails: patches[0],
patches: patches.slice(0, lastReversedPatchIndex).map((patch) => ({
didApply: true,
patchContentHash: hash_1.hashFile(path_2.join(appPath, patchDir, patch.patchFilename)),
patchFilename: patch.patchFilename,
})),
isRebasing: false,
});
}
}
else {
const nextState = appliedPatches.map((patch) => ({
didApply: true,
patchContentHash: hash_1.hashFile(path_2.join(appPath, patchDir, patch.patchFilename)),
patchFilename: patch.patchFilename,
}));
if (failedPatch) {
nextState.push({
didApply: false,
patchContentHash: hash_1.hashFile(path_2.join(appPath, patchDir, failedPatch.patchFilename)),
patchFilename: failedPatch.patchFilename,
});
}
stateFile_1.savePatchApplicationState({
packageDetails: patches[0],
patches: nextState,
isRebasing: !!failedPatch,
});
}
}
}
exports.applyPatchesForPackage = applyPatchesForPackage;
function applyPatch({ patchFilePath, reverse, patchDetails, patchDir, cwd, }) {

@@ -221,2 +295,6 @@ const patch = read_1.readPatch({

apply_1.executeEffects(reverse ? reverse_1.reversePatch(patch) : patch, {
dryRun: true,
cwd,
});
apply_1.executeEffects(reverse ? reverse_1.reversePatch(patch) : patch, {
dryRun: false,

@@ -328,2 +406,2 @@ cwd,

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"applyPatches.js","sourceRoot":"","sources":["../src/applyPatches.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\"\nimport { existsSync } from \"fs-extra\"\nimport { posix } from \"path\"\nimport semver from \"semver\"\nimport { hashFile } from \"./hash\"\nimport { PackageDetails, PatchedPackageDetails } from \"./PackageDetails\"\nimport { packageIsDevDependency } from \"./packageIsDevDependency\"\nimport { executeEffects } from \"./patch/apply\"\nimport { readPatch } from \"./patch/read\"\nimport { reversePatch } from \"./patch/reverse\"\nimport { getGroupedPatches } from \"./patchFs\"\nimport { join, relative, resolve } from \"./path\"\nimport {\n  getPatchApplicationState,\n  PatchState,\n  savePatchApplicationState,\n} from \"./stateFile\"\n\nclass PatchApplicationError extends Error {\n  constructor(msg: string) {\n    super(msg)\n  }\n}\n\nfunction getInstalledPackageVersion({\n  appPath,\n  path,\n  pathSpecifier,\n  isDevOnly,\n  patchFilename,\n}: {\n  appPath: string\n  path: string\n  pathSpecifier: string\n  isDevOnly: boolean\n  patchFilename: string\n}): null | string {\n  const packageDir = join(appPath, path)\n  if (!existsSync(packageDir)) {\n    if (process.env.NODE_ENV === \"production\" && isDevOnly) {\n      return null\n    }\n\n    let err =\n      `${chalk.red(\"Error:\")} Patch file found for package ${posix.basename(\n        pathSpecifier,\n      )}` + ` which is not present at ${relative(\".\", packageDir)}`\n\n    if (!isDevOnly && process.env.NODE_ENV === \"production\") {\n      err += `\n\n  If this package is a dev dependency, rename the patch file to\n  \n    ${chalk.bold(patchFilename.replace(\".patch\", \".dev.patch\"))}\n`\n    }\n    throw new PatchApplicationError(err)\n  }\n\n  const { version } = require(join(packageDir, \"package.json\"))\n  // normalize version for `npm ci`\n  const result = semver.valid(version)\n  if (result === null) {\n    throw new PatchApplicationError(\n      `${chalk.red(\n        \"Error:\",\n      )} Version string '${version}' cannot be parsed from ${join(\n        packageDir,\n        \"package.json\",\n      )}`,\n    )\n  }\n\n  return result as string\n}\n\nfunction logPatchApplication(patchDetails: PatchedPackageDetails) {\n  const sequenceString =\n    patchDetails.sequenceNumber != null\n      ? ` (${patchDetails.sequenceNumber}${\n          patchDetails.sequenceName ? \" \" + patchDetails.sequenceName : \"\"\n        })`\n      : \"\"\n  console.log(\n    `${chalk.bold(patchDetails.pathSpecifier)}@${\n      patchDetails.version\n    }${sequenceString} ${chalk.green(\"✔\")}`,\n  )\n}\n\nexport function applyPatchesForApp({\n  appPath,\n  reverse,\n  patchDir,\n  shouldExitWithError,\n  shouldExitWithWarning,\n}: {\n  appPath: string\n  reverse: boolean\n  patchDir: string\n  shouldExitWithError: boolean\n  shouldExitWithWarning: boolean\n}): void {\n  const patchesDirectory = join(appPath, patchDir)\n  const groupedPatches = getGroupedPatches(patchesDirectory)\n\n  if (groupedPatches.numPatchFiles === 0) {\n    console.error(chalk.blueBright(\"No patch files found\"))\n    return\n  }\n\n  const errors: string[] = []\n  const warnings: string[] = [...groupedPatches.warnings]\n\n  for (const [pathSpecifier, patches] of Object.entries(\n    groupedPatches.pathSpecifierToPatchFiles,\n  )) {\n    const state =\n      patches.length > 1 ? getPatchApplicationState(patches[0]) : null\n    const unappliedPatches = patches.slice(0)\n    const newState: PatchState[] | null = patches.length > 1 ? [] : null\n    // if there are multiple patches to apply, we can't rely on the reverse-patch-dry-run behavior to make this operation\n    // idempotent, so instead we need to check the state file to see whether we have already applied any of the patches\n    // todo: once this is battle tested we might want to use the same approach for single patches as well, but it's not biggie since the dry run thing is fast\n    if (unappliedPatches && state) {\n      for (let i = 0; i < state.patches.length; i++) {\n        const patchThatWasApplied = state.patches[i]\n        const patchToApply = unappliedPatches[0]\n        const currentPatchHash = hashFile(\n          join(appPath, patchDir, patchToApply.patchFilename),\n        )\n        if (patchThatWasApplied.patchContentHash === currentPatchHash) {\n          // this patch was applied we can skip it\n          unappliedPatches.shift()\n        } else {\n          console.error(\n            chalk.red(\"Error:\"),\n            `The patches for ${chalk.bold(pathSpecifier)} have changed.`,\n            `You should reinstall your node_modules folder to make sure the package is up to date`,\n          )\n          process.exit(1)\n        }\n      }\n    }\n    if (unappliedPatches.length === 0) {\n      // all patches have already been applied\n      patches.forEach(logPatchApplication)\n      continue\n    }\n    packageLoop: for (const patchDetails of patches) {\n      try {\n        const { name, version, path, isDevOnly, patchFilename } = patchDetails\n\n        const installedPackageVersion = getInstalledPackageVersion({\n          appPath,\n          path,\n          pathSpecifier,\n          isDevOnly:\n            isDevOnly ||\n            // check for direct-dependents in prod\n            (process.env.NODE_ENV === \"production\" &&\n              packageIsDevDependency({\n                appPath,\n                patchDetails,\n              })),\n          patchFilename,\n        })\n        if (!installedPackageVersion) {\n          // it's ok we're in production mode and this is a dev only package\n          console.log(\n            `Skipping dev-only ${chalk.bold(\n              pathSpecifier,\n            )}@${version} ${chalk.blue(\"✔\")}`,\n          )\n          continue\n        }\n\n        if (\n          applyPatch({\n            patchFilePath: resolve(patchesDirectory, patchFilename) as string,\n            reverse,\n            patchDetails,\n            patchDir,\n            cwd: process.cwd(),\n          })\n        ) {\n          newState?.push({\n            patchFilename,\n            patchContentHash: hashFile(join(appPath, patchDir, patchFilename)),\n            didApply: true,\n          })\n          // yay patch was applied successfully\n          // print warning if version mismatch\n          if (installedPackageVersion !== version) {\n            warnings.push(\n              createVersionMismatchWarning({\n                packageName: name,\n                actualVersion: installedPackageVersion,\n                originalVersion: version,\n                pathSpecifier,\n                path,\n              }),\n            )\n          }\n          logPatchApplication(patchDetails)\n        } else if (installedPackageVersion === version) {\n          // completely failed to apply patch\n          // TODO: propagate useful error messages from patch application\n          errors.push(\n            createBrokenPatchFileError({\n              packageName: name,\n              patchFilename,\n              pathSpecifier,\n              path,\n            }),\n          )\n          // in case the package has multiple patches, we need to break out of this inner loop\n          // because we don't want to apply more patches on top of the broken state\n          break packageLoop\n        } else {\n          errors.push(\n            createPatchApplicationFailureError({\n              packageName: name,\n              actualVersion: installedPackageVersion,\n              originalVersion: version,\n              patchFilename,\n              path,\n              pathSpecifier,\n            }),\n          )\n          // in case the package has multiple patches, we need to break out of this inner loop\n          // because we don't want to apply more patches on top of the broken state\n          break packageLoop\n        }\n      } catch (error) {\n        if (error instanceof PatchApplicationError) {\n          errors.push(error.message)\n        } else {\n          errors.push(\n            createUnexpectedError({\n              filename: patchDetails.patchFilename,\n              error: error as Error,\n            }),\n          )\n        }\n        // in case the package has multiple patches, we need to break out of this inner loop\n        // because we don't want to apply more patches on top of the broken state\n        break packageLoop\n      }\n    }\n\n    if (newState) {\n      savePatchApplicationState(patches[0], newState)\n    }\n  }\n\n  for (const warning of warnings) {\n    console.warn(warning)\n  }\n  for (const error of errors) {\n    console.error(error)\n  }\n\n  const problemsSummary = []\n  if (warnings.length) {\n    problemsSummary.push(chalk.yellow(`${warnings.length} warning(s)`))\n  }\n  if (errors.length) {\n    problemsSummary.push(chalk.red(`${errors.length} error(s)`))\n  }\n\n  if (problemsSummary.length) {\n    console.error(\"---\")\n    console.error(\n      \"patch-package finished with\",\n      problemsSummary.join(\", \") + \".\",\n    )\n  }\n\n  if (errors.length && shouldExitWithError) {\n    process.exit(1)\n  }\n\n  if (warnings.length && shouldExitWithWarning) {\n    process.exit(1)\n  }\n\n  process.exit(0)\n}\n\nexport function applyPatch({\n  patchFilePath,\n  reverse,\n  patchDetails,\n  patchDir,\n  cwd,\n}: {\n  patchFilePath: string\n  reverse: boolean\n  patchDetails: PackageDetails\n  patchDir: string\n  cwd: string\n}): boolean {\n  const patch = readPatch({\n    patchFilePath,\n    patchDetails,\n    patchDir,\n  })\n  try {\n    executeEffects(reverse ? reversePatch(patch) : patch, {\n      dryRun: false,\n      cwd,\n    })\n  } catch (e) {\n    try {\n      executeEffects(reverse ? patch : reversePatch(patch), {\n        dryRun: true,\n        cwd,\n      })\n    } catch (e) {\n      return false\n    }\n  }\n\n  return true\n}\n\nfunction createVersionMismatchWarning({\n  packageName,\n  actualVersion,\n  originalVersion,\n  pathSpecifier,\n  path,\n}: {\n  packageName: string\n  actualVersion: string\n  originalVersion: string\n  pathSpecifier: string\n  path: string\n}) {\n  return `\n${chalk.yellow(\"Warning:\")} patch-package detected a patch file version mismatch\n\n  Don't worry! This is probably fine. The patch was still applied\n  successfully. Here's the deets:\n\n  Patch file created for\n\n    ${packageName}@${chalk.bold(originalVersion)}\n\n  applied to\n\n    ${packageName}@${chalk.bold(actualVersion)}\n  \n  At path\n  \n    ${path}\n\n  This warning is just to give you a heads-up. There is a small chance of\n  breakage even though the patch was applied successfully. Make sure the package\n  still behaves like you expect (you wrote tests, right?) and then run\n\n    ${chalk.bold(`patch-package ${pathSpecifier}`)}\n\n  to update the version in the patch file name and make this warning go away.\n`\n}\n\nfunction createBrokenPatchFileError({\n  packageName,\n  patchFilename,\n  path,\n  pathSpecifier,\n}: {\n  packageName: string\n  patchFilename: string\n  path: string\n  pathSpecifier: string\n}) {\n  return `\n${chalk.red.bold(\"**ERROR**\")} ${chalk.red(\n    `Failed to apply patch for package ${chalk.bold(packageName)} at path`,\n  )}\n  \n    ${path}\n\n  This error was caused because patch-package cannot apply the following patch file:\n\n    patches/${patchFilename}\n\n  Try removing node_modules and trying again. If that doesn't work, maybe there was\n  an accidental change made to the patch file? Try recreating it by manually\n  editing the appropriate files and running:\n  \n    patch-package ${pathSpecifier}\n  \n  If that doesn't work, then it's a bug in patch-package, so please submit a bug\n  report. Thanks!\n\n    https://github.com/ds300/patch-package/issues\n    \n`\n}\n\nfunction createPatchApplicationFailureError({\n  packageName,\n  actualVersion,\n  originalVersion,\n  patchFilename,\n  path,\n  pathSpecifier,\n}: {\n  packageName: string\n  actualVersion: string\n  originalVersion: string\n  patchFilename: string\n  path: string\n  pathSpecifier: string\n}) {\n  return `\n${chalk.red.bold(\"**ERROR**\")} ${chalk.red(\n    `Failed to apply patch for package ${chalk.bold(packageName)} at path`,\n  )}\n  \n    ${path}\n\n  This error was caused because ${chalk.bold(packageName)} has changed since you\n  made the patch file for it. This introduced conflicts with your patch,\n  just like a merge conflict in Git when separate incompatible changes are\n  made to the same piece of code.\n\n  Maybe this means your patch file is no longer necessary, in which case\n  hooray! Just delete it!\n\n  Otherwise, you need to generate a new patch file.\n\n  To generate a new one, just repeat the steps you made to generate the first\n  one.\n\n  i.e. manually make the appropriate file changes, then run \n\n    patch-package ${pathSpecifier}\n\n  Info:\n    Patch file: patches/${patchFilename}\n    Patch was made for version: ${chalk.green.bold(originalVersion)}\n    Installed version: ${chalk.red.bold(actualVersion)}\n`\n}\n\nfunction createUnexpectedError({\n  filename,\n  error,\n}: {\n  filename: string\n  error: Error\n}) {\n  return `\n${chalk.red.bold(\"**ERROR**\")} ${chalk.red(\n    `Failed to apply patch file ${chalk.bold(filename)}`,\n  )}\n  \n${error.stack}\n\n  `\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"applyPatches.js","sourceRoot":"","sources":["../src/applyPatches.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\"\nimport { existsSync } from \"fs-extra\"\nimport { posix } from \"path\"\nimport semver from \"semver\"\nimport { hashFile } from \"./hash\"\nimport { logPatchSequenceError } from \"./makePatch\"\nimport { PackageDetails, PatchedPackageDetails } from \"./PackageDetails\"\nimport { packageIsDevDependency } from \"./packageIsDevDependency\"\nimport { executeEffects } from \"./patch/apply\"\nimport { readPatch } from \"./patch/read\"\nimport { reversePatch } from \"./patch/reverse\"\nimport { getGroupedPatches } from \"./patchFs\"\nimport { join, relative } from \"./path\"\nimport {\n  clearPatchApplicationState,\n  getPatchApplicationState,\n  PatchState,\n  savePatchApplicationState,\n} from \"./stateFile\"\n\nclass PatchApplicationError extends Error {\n  constructor(msg: string) {\n    super(msg)\n  }\n}\n\nfunction getInstalledPackageVersion({\n  appPath,\n  path,\n  pathSpecifier,\n  isDevOnly,\n  patchFilename,\n}: {\n  appPath: string\n  path: string\n  pathSpecifier: string\n  isDevOnly: boolean\n  patchFilename: string\n}): null | string {\n  const packageDir = join(appPath, path)\n  if (!existsSync(packageDir)) {\n    if (process.env.NODE_ENV === \"production\" && isDevOnly) {\n      return null\n    }\n\n    let err =\n      `${chalk.red(\"Error:\")} Patch file found for package ${posix.basename(\n        pathSpecifier,\n      )}` + ` which is not present at ${relative(\".\", packageDir)}`\n\n    if (!isDevOnly && process.env.NODE_ENV === \"production\") {\n      err += `\n\n  If this package is a dev dependency, rename the patch file to\n  \n    ${chalk.bold(patchFilename.replace(\".patch\", \".dev.patch\"))}\n`\n    }\n    throw new PatchApplicationError(err)\n  }\n\n  const { version } = require(join(packageDir, \"package.json\"))\n  // normalize version for `npm ci`\n  const result = semver.valid(version)\n  if (result === null) {\n    throw new PatchApplicationError(\n      `${chalk.red(\n        \"Error:\",\n      )} Version string '${version}' cannot be parsed from ${join(\n        packageDir,\n        \"package.json\",\n      )}`,\n    )\n  }\n\n  return result as string\n}\n\nfunction logPatchApplication(patchDetails: PatchedPackageDetails) {\n  const sequenceString =\n    patchDetails.sequenceNumber != null\n      ? ` (${patchDetails.sequenceNumber}${\n          patchDetails.sequenceName ? \" \" + patchDetails.sequenceName : \"\"\n        })`\n      : \"\"\n  console.log(\n    `${chalk.bold(patchDetails.pathSpecifier)}@${\n      patchDetails.version\n    }${sequenceString} ${chalk.green(\"✔\")}`,\n  )\n}\n\nexport function applyPatchesForApp({\n  appPath,\n  reverse,\n  patchDir,\n  shouldExitWithError,\n  shouldExitWithWarning,\n}: {\n  appPath: string\n  reverse: boolean\n  patchDir: string\n  shouldExitWithError: boolean\n  shouldExitWithWarning: boolean\n}): void {\n  const patchesDirectory = join(appPath, patchDir)\n  const groupedPatches = getGroupedPatches(patchesDirectory)\n\n  if (groupedPatches.numPatchFiles === 0) {\n    console.error(chalk.blueBright(\"No patch files found\"))\n    return\n  }\n\n  const errors: string[] = []\n  const warnings: string[] = [...groupedPatches.warnings]\n\n  for (const patches of Object.values(\n    groupedPatches.pathSpecifierToPatchFiles,\n  )) {\n    applyPatchesForPackage({\n      patches,\n      appPath,\n      patchDir,\n      reverse,\n      warnings,\n      errors,\n    })\n  }\n\n  for (const warning of warnings) {\n    console.warn(warning)\n  }\n  for (const error of errors) {\n    console.error(error)\n  }\n\n  const problemsSummary = []\n  if (warnings.length) {\n    problemsSummary.push(chalk.yellow(`${warnings.length} warning(s)`))\n  }\n  if (errors.length) {\n    problemsSummary.push(chalk.red(`${errors.length} error(s)`))\n  }\n\n  if (problemsSummary.length) {\n    console.error(\"---\")\n    console.error(\n      \"patch-package finished with\",\n      problemsSummary.join(\", \") + \".\",\n    )\n  }\n\n  if (errors.length && shouldExitWithError) {\n    process.exit(1)\n  }\n\n  if (warnings.length && shouldExitWithWarning) {\n    process.exit(1)\n  }\n\n  process.exit(0)\n}\n\nexport function applyPatchesForPackage({\n  patches,\n  appPath,\n  patchDir,\n  reverse,\n  warnings,\n  errors,\n}: {\n  patches: PatchedPackageDetails[]\n  appPath: string\n  patchDir: string\n  reverse: boolean\n  warnings: string[]\n  errors: string[]\n}) {\n  const pathSpecifier = patches[0].pathSpecifier\n  const state = patches.length > 1 ? getPatchApplicationState(patches[0]) : null\n  const unappliedPatches = patches.slice(0)\n  const appliedPatches: PatchedPackageDetails[] = []\n  // if there are multiple patches to apply, we can't rely on the reverse-patch-dry-run behavior to make this operation\n  // idempotent, so instead we need to check the state file to see whether we have already applied any of the patches\n  // todo: once this is battle tested we might want to use the same approach for single patches as well, but it's not biggie since the dry run thing is fast\n  if (unappliedPatches && state) {\n    for (let i = 0; i < state.patches.length; i++) {\n      const patchThatWasApplied = state.patches[i]\n      const patchToApply = unappliedPatches[0]\n      const currentPatchHash = hashFile(\n        join(appPath, patchDir, patchToApply.patchFilename),\n      )\n      if (patchThatWasApplied.patchContentHash === currentPatchHash) {\n        // this patch was applied we can skip it\n        appliedPatches.push(unappliedPatches.shift()!)\n      } else {\n        console.error(\n          chalk.red(\"Error:\"),\n          `The patches for ${chalk.bold(pathSpecifier)} have changed.`,\n          `You should reinstall your node_modules folder to make sure the package is up to date`,\n        )\n        process.exit(1)\n      }\n    }\n  }\n\n  if (reverse && state) {\n    // if we are reversing the patches we need to make the unappliedPatches array\n    // be the reversed version of the appliedPatches array.\n    // The applied patches array should then be empty because it is used differently\n    // when outputting the state file.\n    unappliedPatches.length = 0\n    unappliedPatches.push(...appliedPatches)\n    unappliedPatches.reverse()\n    appliedPatches.length = 0\n  }\n  if (appliedPatches.length) {\n    // some patches have already been applied\n    appliedPatches.forEach(logPatchApplication)\n  }\n  if (!unappliedPatches.length) {\n    return\n  }\n  let failedPatch: PatchedPackageDetails | null = null\n  packageLoop: for (const patchDetails of unappliedPatches) {\n    try {\n      const { name, version, path, isDevOnly, patchFilename } = patchDetails\n\n      const installedPackageVersion = getInstalledPackageVersion({\n        appPath,\n        path,\n        pathSpecifier,\n        isDevOnly:\n          isDevOnly ||\n          // check for direct-dependents in prod\n          (process.env.NODE_ENV === \"production\" &&\n            packageIsDevDependency({\n              appPath,\n              patchDetails,\n            })),\n        patchFilename,\n      })\n      if (!installedPackageVersion) {\n        // it's ok we're in production mode and this is a dev only package\n        console.log(\n          `Skipping dev-only ${chalk.bold(\n            pathSpecifier,\n          )}@${version} ${chalk.blue(\"✔\")}`,\n        )\n        continue\n      }\n\n      if (\n        applyPatch({\n          patchFilePath: join(appPath, patchDir, patchFilename) as string,\n          reverse,\n          patchDetails,\n          patchDir,\n          cwd: process.cwd(),\n        })\n      ) {\n        appliedPatches.push(patchDetails)\n        // yay patch was applied successfully\n        // print warning if version mismatch\n        if (installedPackageVersion !== version) {\n          warnings.push(\n            createVersionMismatchWarning({\n              packageName: name,\n              actualVersion: installedPackageVersion,\n              originalVersion: version,\n              pathSpecifier,\n              path,\n            }),\n          )\n        }\n        logPatchApplication(patchDetails)\n      } else if (patches.length > 1) {\n        logPatchSequenceError({ patchDetails })\n        // in case the package has multiple patches, we need to break out of this inner loop\n        // because we don't want to apply more patches on top of the broken state\n        failedPatch = patchDetails\n        break packageLoop\n      } else if (installedPackageVersion === version) {\n        // completely failed to apply patch\n        // TODO: propagate useful error messages from patch application\n        errors.push(\n          createBrokenPatchFileError({\n            packageName: name,\n            patchFilename,\n            pathSpecifier,\n            path,\n          }),\n        )\n        break packageLoop\n      } else {\n        errors.push(\n          createPatchApplicationFailureError({\n            packageName: name,\n            actualVersion: installedPackageVersion,\n            originalVersion: version,\n            patchFilename,\n            path,\n            pathSpecifier,\n          }),\n        )\n        // in case the package has multiple patches, we need to break out of this inner loop\n        // because we don't want to apply more patches on top of the broken state\n        break packageLoop\n      }\n    } catch (error) {\n      if (error instanceof PatchApplicationError) {\n        errors.push(error.message)\n      } else {\n        errors.push(\n          createUnexpectedError({\n            filename: patchDetails.patchFilename,\n            error: error as Error,\n          }),\n        )\n      }\n      // in case the package has multiple patches, we need to break out of this inner loop\n      // because we don't want to apply more patches on top of the broken state\n      break packageLoop\n    }\n  }\n\n  if (patches.length > 1) {\n    if (reverse) {\n      if (!state) {\n        throw new Error(\"unexpected state: no state file found while reversing\")\n      }\n      // if we removed all the patches that were previously applied we can delete the state file\n      if (appliedPatches.length === patches.length) {\n        clearPatchApplicationState(patches[0])\n      } else {\n        // We failed while reversing patches and some are still in the applied state.\n        // We need to update the state file to reflect that.\n        // appliedPatches is currently the patches that were successfully reversed, in the order they were reversed\n        // So we need to find the index of the last reversed patch in the original patches array\n        // and then remove all the patches after that. Sorry for the confusing code.\n        const lastReversedPatchIndex = patches.indexOf(\n          appliedPatches[appliedPatches.length - 1],\n        )\n        if (lastReversedPatchIndex === -1) {\n          throw new Error(\n            \"unexpected state: failed to find last reversed patch in original patches array\",\n          )\n        }\n\n        savePatchApplicationState({\n          packageDetails: patches[0],\n          patches: patches.slice(0, lastReversedPatchIndex).map((patch) => ({\n            didApply: true,\n            patchContentHash: hashFile(\n              join(appPath, patchDir, patch.patchFilename),\n            ),\n            patchFilename: patch.patchFilename,\n          })),\n          isRebasing: false,\n        })\n      }\n    } else {\n      const nextState = appliedPatches.map(\n        (patch): PatchState => ({\n          didApply: true,\n          patchContentHash: hashFile(\n            join(appPath, patchDir, patch.patchFilename),\n          ),\n          patchFilename: patch.patchFilename,\n        }),\n      )\n\n      if (failedPatch) {\n        nextState.push({\n          didApply: false,\n          patchContentHash: hashFile(\n            join(appPath, patchDir, failedPatch.patchFilename),\n          ),\n          patchFilename: failedPatch.patchFilename,\n        })\n      }\n      savePatchApplicationState({\n        packageDetails: patches[0],\n        patches: nextState,\n        isRebasing: !!failedPatch,\n      })\n    }\n  }\n}\n\nexport function applyPatch({\n  patchFilePath,\n  reverse,\n  patchDetails,\n  patchDir,\n  cwd,\n}: {\n  patchFilePath: string\n  reverse: boolean\n  patchDetails: PackageDetails\n  patchDir: string\n  cwd: string\n}): boolean {\n  const patch = readPatch({\n    patchFilePath,\n    patchDetails,\n    patchDir,\n  })\n  try {\n    executeEffects(reverse ? reversePatch(patch) : patch, {\n      dryRun: true,\n      cwd,\n    })\n    executeEffects(reverse ? reversePatch(patch) : patch, {\n      dryRun: false,\n      cwd,\n    })\n  } catch (e) {\n    try {\n      executeEffects(reverse ? patch : reversePatch(patch), {\n        dryRun: true,\n        cwd,\n      })\n    } catch (e) {\n      return false\n    }\n  }\n\n  return true\n}\n\nfunction createVersionMismatchWarning({\n  packageName,\n  actualVersion,\n  originalVersion,\n  pathSpecifier,\n  path,\n}: {\n  packageName: string\n  actualVersion: string\n  originalVersion: string\n  pathSpecifier: string\n  path: string\n}) {\n  return `\n${chalk.yellow(\"Warning:\")} patch-package detected a patch file version mismatch\n\n  Don't worry! This is probably fine. The patch was still applied\n  successfully. Here's the deets:\n\n  Patch file created for\n\n    ${packageName}@${chalk.bold(originalVersion)}\n\n  applied to\n\n    ${packageName}@${chalk.bold(actualVersion)}\n  \n  At path\n  \n    ${path}\n\n  This warning is just to give you a heads-up. There is a small chance of\n  breakage even though the patch was applied successfully. Make sure the package\n  still behaves like you expect (you wrote tests, right?) and then run\n\n    ${chalk.bold(`patch-package ${pathSpecifier}`)}\n\n  to update the version in the patch file name and make this warning go away.\n`\n}\n\nfunction createBrokenPatchFileError({\n  packageName,\n  patchFilename,\n  path,\n  pathSpecifier,\n}: {\n  packageName: string\n  patchFilename: string\n  path: string\n  pathSpecifier: string\n}) {\n  return `\n${chalk.red.bold(\"**ERROR**\")} ${chalk.red(\n    `Failed to apply patch for package ${chalk.bold(packageName)} at path`,\n  )}\n  \n    ${path}\n\n  This error was caused because patch-package cannot apply the following patch file:\n\n    patches/${patchFilename}\n\n  Try removing node_modules and trying again. If that doesn't work, maybe there was\n  an accidental change made to the patch file? Try recreating it by manually\n  editing the appropriate files and running:\n  \n    patch-package ${pathSpecifier}\n  \n  If that doesn't work, then it's a bug in patch-package, so please submit a bug\n  report. Thanks!\n\n    https://github.com/ds300/patch-package/issues\n    \n`\n}\n\nfunction createPatchApplicationFailureError({\n  packageName,\n  actualVersion,\n  originalVersion,\n  patchFilename,\n  path,\n  pathSpecifier,\n}: {\n  packageName: string\n  actualVersion: string\n  originalVersion: string\n  patchFilename: string\n  path: string\n  pathSpecifier: string\n}) {\n  return `\n${chalk.red.bold(\"**ERROR**\")} ${chalk.red(\n    `Failed to apply patch for package ${chalk.bold(packageName)} at path`,\n  )}\n  \n    ${path}\n\n  This error was caused because ${chalk.bold(packageName)} has changed since you\n  made the patch file for it. This introduced conflicts with your patch,\n  just like a merge conflict in Git when separate incompatible changes are\n  made to the same piece of code.\n\n  Maybe this means your patch file is no longer necessary, in which case\n  hooray! Just delete it!\n\n  Otherwise, you need to generate a new patch file.\n\n  To generate a new one, just repeat the steps you made to generate the first\n  one.\n\n  i.e. manually make the appropriate file changes, then run \n\n    patch-package ${pathSpecifier}\n\n  Info:\n    Patch file: patches/${patchFilename}\n    Patch was made for version: ${chalk.green.bold(originalVersion)}\n    Installed version: ${chalk.red.bold(actualVersion)}\n`\n}\n\nfunction createUnexpectedError({\n  filename,\n  error,\n}: {\n  filename: string\n  error: Error\n}) {\n  return `\n${chalk.red.bold(\"**ERROR**\")} ${chalk.red(\n    `Failed to apply patch file ${chalk.bold(filename)}`,\n  )}\n  \n${error.stack}\n\n  `\n}\n"]}

@@ -18,2 +18,3 @@ "use strict";

const ci_info_1 = require("ci-info");
const rebase_1 = require("./rebase");
const appPath = getAppRootPath_1.getAppRootPath();

@@ -30,4 +31,5 @@ const argv = minimist_1.default(process_1.default.argv.slice(2), {

"create-issue",
"",
],
string: ["patch-dir", "append"],
string: ["patch-dir", "append", "rebase"],
});

@@ -49,3 +51,19 @@ const packageNames = argv._;

}
if (packageNames.length) {
if ("rebase" in argv) {
if (!argv.rebase) {
console.error(chalk_1.default.red("You must specify a patch file name or number when rebasing patches"));
process_1.default.exit(1);
}
if (packageNames.length !== 1) {
console.error(chalk_1.default.red("You must specify exactly one package name when rebasing patches"));
process_1.default.exit(1);
}
rebase_1.rebase({
appPath,
packagePathSpecifier: packageNames[0],
patchDir,
targetPatch: argv.rebase,
});
}
else if (packageNames.length) {
const includePaths = makeRegExp_1.makeRegExp(argv.include, "include", /.*/, argv["case-sensitive-path-filtering"]);

@@ -184,2 +202,2 @@ const excludePaths = makeRegExp_1.makeRegExp(argv.exclude, "exclude", /^package\.json$/, argv["case-sensitive-path-filtering"]);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\"\nimport process from \"process\"\nimport minimist from \"minimist\"\n\nimport { applyPatchesForApp } from \"./applyPatches\"\nimport { getAppRootPath } from \"./getAppRootPath\"\nimport { makePatch } from \"./makePatch\"\nimport { makeRegExp } from \"./makeRegExp\"\nimport { detectPackageManager } from \"./detectPackageManager\"\nimport { join } from \"./path\"\nimport { normalize, sep } from \"path\"\nimport slash = require(\"slash\")\nimport { isCI } from \"ci-info\"\n\nconst appPath = getAppRootPath()\nconst argv = minimist(process.argv.slice(2), {\n  boolean: [\n    \"use-yarn\",\n    \"case-sensitive-path-filtering\",\n    \"reverse\",\n    \"help\",\n    \"version\",\n    \"error-on-fail\",\n    \"error-on-warn\",\n    \"create-issue\",\n  ],\n  string: [\"patch-dir\", \"append\"],\n})\nconst packageNames = argv._\n\nconsole.log(\n  chalk.bold(\"patch-package\"),\n  // tslint:disable-next-line:no-var-requires\n  require(join(__dirname, \"../package.json\")).version,\n)\n\nif (argv.version || argv.v) {\n  // noop\n} else if (argv.help || argv.h) {\n  printHelp()\n} else {\n  const patchDir = slash(normalize((argv[\"patch-dir\"] || \"patches\") + sep))\n  if (patchDir.startsWith(\"/\")) {\n    throw new Error(\"--patch-dir must be a relative path\")\n  }\n  if (packageNames.length) {\n    const includePaths = makeRegExp(\n      argv.include,\n      \"include\",\n      /.*/,\n      argv[\"case-sensitive-path-filtering\"],\n    )\n    const excludePaths = makeRegExp(\n      argv.exclude,\n      \"exclude\",\n      /^package\\.json$/,\n      argv[\"case-sensitive-path-filtering\"],\n    )\n    const packageManager = detectPackageManager(\n      appPath,\n      argv[\"use-yarn\"] ? \"yarn\" : null,\n    )\n    const createIssue = argv[\"create-issue\"]\n    packageNames.forEach((packagePathSpecifier: string) => {\n      makePatch({\n        packagePathSpecifier,\n        appPath,\n        packageManager,\n        includePaths,\n        excludePaths,\n        patchDir,\n        createIssue,\n        mode:\n          \"append\" in argv\n            ? { type: \"append\", name: argv.append || undefined }\n            : { type: \"overwrite_last\" },\n      })\n    })\n  } else {\n    console.log(\"Applying patches...\")\n    const reverse = !!argv[\"reverse\"]\n    // don't want to exit(1) on postinstall locally.\n    // see https://github.com/ds300/patch-package/issues/86\n    const shouldExitWithError =\n      !!argv[\"error-on-fail\"] ||\n      (process.env.NODE_ENV === \"production\" && isCI) ||\n      (isCI && !process.env.PATCH_PACKAGE_INTEGRATION_TEST) ||\n      process.env.NODE_ENV === \"test\"\n\n    const shouldExitWithWarning = !!argv[\"error-on-warn\"]\n\n    applyPatchesForApp({\n      appPath,\n      reverse,\n      patchDir,\n      shouldExitWithError,\n      shouldExitWithWarning,\n    })\n  }\n}\n\nfunction printHelp() {\n  console.log(`\nUsage:\n\n  1. Patching packages\n  ====================\n\n    ${chalk.bold(\"patch-package\")}\n\n  Without arguments, the ${chalk.bold(\n    \"patch-package\",\n  )} command will attempt to find and apply\n  patch files to your project. It looks for files named like\n\n     ./patches/<package-name>+<version>.patch\n\n  Options:\n\n    ${chalk.bold(\"--patch-dir <dirname>\")}\n\n      Specify the name for the directory in which the patch files are located.\n      \n    ${chalk.bold(\"--error-on-fail\")}\n    \n      Forces patch-package to exit with code 1 after failing.\n    \n      When running locally patch-package always exits with 0 by default.\n      This happens even after failing to apply patches because otherwise \n      yarn.lock and package.json might get out of sync with node_modules,\n      which can be very confusing.\n      \n      --error-on-fail is ${chalk.bold(\"switched on\")} by default on CI.\n      \n      See https://github.com/ds300/patch-package/issues/86 for background.\n      \n    ${chalk.bold(\"--error-on-warn\")}\n    \n      Forces patch-package to exit with code 1 after warning.\n      \n      See https://github.com/ds300/patch-package/issues/314 for background.\n\n    ${chalk.bold(\"--reverse\")}\n        \n      Un-applies all patches.\n\n      Note that this will fail if the patched files have changed since being\n      patched. In that case, you'll probably need to re-install 'node_modules'.\n\n      This option was added to help people using CircleCI avoid an issue around caching\n      and patch file updates (https://github.com/ds300/patch-package/issues/37),\n      but might be useful in other contexts too.\n      \n\n  2. Creating patch files\n  =======================\n\n    ${chalk.bold(\"patch-package\")} <package-name>${chalk.italic(\n    \"[ <package-name>]\",\n  )}\n\n  When given package names as arguments, patch-package will create patch files\n  based on any changes you've made to the versions installed by yarn/npm.\n\n  Options:\n  \n    ${chalk.bold(\"--create-issue\")}\n    \n       For packages whose source is hosted on GitHub this option opens a web\n       browser with a draft issue based on your diff.\n\n    ${chalk.bold(\"--use-yarn\")}\n\n        By default, patch-package checks whether you use npm or yarn based on\n        which lockfile you have. If you have both, it uses npm by default.\n        Set this option to override that default and always use yarn.\n\n    ${chalk.bold(\"--exclude <regexp>\")}\n\n        Ignore paths matching the regexp when creating patch files.\n        Paths are relative to the root dir of the package to be patched.\n\n        Default: 'package\\\\.json$'\n\n    ${chalk.bold(\"--include <regexp>\")}\n\n        Only consider paths matching the regexp when creating patch files.\n        Paths are relative to the root dir of the package to be patched.\n\n        Default '.*'\n\n    ${chalk.bold(\"--case-sensitive-path-filtering\")}\n\n        Make regexps used in --include or --exclude filters case-sensitive.\n    \n    ${chalk.bold(\"--patch-dir\")}\n\n        Specify the name for the directory in which to put the patch files.\n`)\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\"\nimport process from \"process\"\nimport minimist from \"minimist\"\n\nimport { applyPatchesForApp } from \"./applyPatches\"\nimport { getAppRootPath } from \"./getAppRootPath\"\nimport { makePatch } from \"./makePatch\"\nimport { makeRegExp } from \"./makeRegExp\"\nimport { detectPackageManager } from \"./detectPackageManager\"\nimport { join } from \"./path\"\nimport { normalize, sep } from \"path\"\nimport slash = require(\"slash\")\nimport { isCI } from \"ci-info\"\nimport { rebase } from \"./rebase\"\n\nconst appPath = getAppRootPath()\nconst argv = minimist(process.argv.slice(2), {\n  boolean: [\n    \"use-yarn\",\n    \"case-sensitive-path-filtering\",\n    \"reverse\",\n    \"help\",\n    \"version\",\n    \"error-on-fail\",\n    \"error-on-warn\",\n    \"create-issue\",\n    \"\",\n  ],\n  string: [\"patch-dir\", \"append\", \"rebase\"],\n})\nconst packageNames = argv._\n\nconsole.log(\n  chalk.bold(\"patch-package\"),\n  // tslint:disable-next-line:no-var-requires\n  require(join(__dirname, \"../package.json\")).version,\n)\n\nif (argv.version || argv.v) {\n  // noop\n} else if (argv.help || argv.h) {\n  printHelp()\n} else {\n  const patchDir = slash(normalize((argv[\"patch-dir\"] || \"patches\") + sep))\n  if (patchDir.startsWith(\"/\")) {\n    throw new Error(\"--patch-dir must be a relative path\")\n  }\n  if (\"rebase\" in argv) {\n    if (!argv.rebase) {\n      console.error(\n        chalk.red(\n          \"You must specify a patch file name or number when rebasing patches\",\n        ),\n      )\n      process.exit(1)\n    }\n    if (packageNames.length !== 1) {\n      console.error(\n        chalk.red(\n          \"You must specify exactly one package name when rebasing patches\",\n        ),\n      )\n      process.exit(1)\n    }\n    rebase({\n      appPath,\n      packagePathSpecifier: packageNames[0],\n      patchDir,\n      targetPatch: argv.rebase,\n    })\n  } else if (packageNames.length) {\n    const includePaths = makeRegExp(\n      argv.include,\n      \"include\",\n      /.*/,\n      argv[\"case-sensitive-path-filtering\"],\n    )\n    const excludePaths = makeRegExp(\n      argv.exclude,\n      \"exclude\",\n      /^package\\.json$/,\n      argv[\"case-sensitive-path-filtering\"],\n    )\n    const packageManager = detectPackageManager(\n      appPath,\n      argv[\"use-yarn\"] ? \"yarn\" : null,\n    )\n    const createIssue = argv[\"create-issue\"]\n    packageNames.forEach((packagePathSpecifier: string) => {\n      makePatch({\n        packagePathSpecifier,\n        appPath,\n        packageManager,\n        includePaths,\n        excludePaths,\n        patchDir,\n        createIssue,\n        mode:\n          \"append\" in argv\n            ? { type: \"append\", name: argv.append || undefined }\n            : { type: \"overwrite_last\" },\n      })\n    })\n  } else {\n    console.log(\"Applying patches...\")\n    const reverse = !!argv[\"reverse\"]\n    // don't want to exit(1) on postinstall locally.\n    // see https://github.com/ds300/patch-package/issues/86\n    const shouldExitWithError =\n      !!argv[\"error-on-fail\"] ||\n      (process.env.NODE_ENV === \"production\" && isCI) ||\n      (isCI && !process.env.PATCH_PACKAGE_INTEGRATION_TEST) ||\n      process.env.NODE_ENV === \"test\"\n\n    const shouldExitWithWarning = !!argv[\"error-on-warn\"]\n\n    applyPatchesForApp({\n      appPath,\n      reverse,\n      patchDir,\n      shouldExitWithError,\n      shouldExitWithWarning,\n    })\n  }\n}\n\nfunction printHelp() {\n  console.log(`\nUsage:\n\n  1. Patching packages\n  ====================\n\n    ${chalk.bold(\"patch-package\")}\n\n  Without arguments, the ${chalk.bold(\n    \"patch-package\",\n  )} command will attempt to find and apply\n  patch files to your project. It looks for files named like\n\n     ./patches/<package-name>+<version>.patch\n\n  Options:\n\n    ${chalk.bold(\"--patch-dir <dirname>\")}\n\n      Specify the name for the directory in which the patch files are located.\n      \n    ${chalk.bold(\"--error-on-fail\")}\n    \n      Forces patch-package to exit with code 1 after failing.\n    \n      When running locally patch-package always exits with 0 by default.\n      This happens even after failing to apply patches because otherwise \n      yarn.lock and package.json might get out of sync with node_modules,\n      which can be very confusing.\n      \n      --error-on-fail is ${chalk.bold(\"switched on\")} by default on CI.\n      \n      See https://github.com/ds300/patch-package/issues/86 for background.\n      \n    ${chalk.bold(\"--error-on-warn\")}\n    \n      Forces patch-package to exit with code 1 after warning.\n      \n      See https://github.com/ds300/patch-package/issues/314 for background.\n\n    ${chalk.bold(\"--reverse\")}\n        \n      Un-applies all patches.\n\n      Note that this will fail if the patched files have changed since being\n      patched. In that case, you'll probably need to re-install 'node_modules'.\n\n      This option was added to help people using CircleCI avoid an issue around caching\n      and patch file updates (https://github.com/ds300/patch-package/issues/37),\n      but might be useful in other contexts too.\n      \n\n  2. Creating patch files\n  =======================\n\n    ${chalk.bold(\"patch-package\")} <package-name>${chalk.italic(\n    \"[ <package-name>]\",\n  )}\n\n  When given package names as arguments, patch-package will create patch files\n  based on any changes you've made to the versions installed by yarn/npm.\n\n  Options:\n  \n    ${chalk.bold(\"--create-issue\")}\n    \n       For packages whose source is hosted on GitHub this option opens a web\n       browser with a draft issue based on your diff.\n\n    ${chalk.bold(\"--use-yarn\")}\n\n        By default, patch-package checks whether you use npm or yarn based on\n        which lockfile you have. If you have both, it uses npm by default.\n        Set this option to override that default and always use yarn.\n\n    ${chalk.bold(\"--exclude <regexp>\")}\n\n        Ignore paths matching the regexp when creating patch files.\n        Paths are relative to the root dir of the package to be patched.\n\n        Default: 'package\\\\.json$'\n\n    ${chalk.bold(\"--include <regexp>\")}\n\n        Only consider paths matching the regexp when creating patch files.\n        Paths are relative to the root dir of the package to be patched.\n\n        Default '.*'\n\n    ${chalk.bold(\"--case-sensitive-path-filtering\")}\n\n        Make regexps used in --include or --exclude filters case-sensitive.\n    \n    ${chalk.bold(\"--patch-dir\")}\n\n        Specify the name for the directory in which to put the patch files.\n`)\n}\n"]}

@@ -6,4 +6,5 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
exports.makePatch = void 0;
exports.logPatchSequenceError = exports.makePatch = void 0;
const chalk_1 = __importDefault(require("chalk"));
const console_1 = __importDefault(require("console"));
const fs_1 = require("fs");

@@ -28,3 +29,3 @@ const fs_extra_1 = require("fs-extra");

function printNoPackageFoundError(packageName, packageJsonPath) {
console.error(`No such package ${packageName}
console_1.default.error(`No such package ${packageName}

@@ -34,13 +35,39 @@ File not found: ${packageJsonPath}`);

function makePatch({ packagePathSpecifier, appPath, packageManager, includePaths, excludePaths, patchDir, createIssue, mode, }) {
var _a, _b, _c;
var _a, _b, _c, _d, _e;
const packageDetails = PackageDetails_1.getPatchDetailsFromCliString(packagePathSpecifier);
if (!packageDetails) {
console.error("No such package", packagePathSpecifier);
console_1.default.error("No such package", packagePathSpecifier);
return;
}
const state = stateFile_1.getPatchApplicationState(packageDetails);
const isRebasing = (_a = state === null || state === void 0 ? void 0 : state.isRebasing) !== null && _a !== void 0 ? _a : false;
// TODO: verify applied patch hashes
// TODO: handle case for --rebase 0
// TODO: handle empty diffs while rebasing
if (mode.type === "overwrite_last" &&
isRebasing &&
(state === null || state === void 0 ? void 0 : state.patches.length) === 0) {
mode = { type: "append", name: "initial" };
}
const existingPatches = patchFs_1.getGroupedPatches(patchDir).pathSpecifierToPatchFiles[packageDetails.pathSpecifier] || [];
// apply all existing patches if appending
// otherwise apply all but the last
const previouslyAppliedPatches = state === null || state === void 0 ? void 0 : state.patches.filter((p) => p.didApply);
const patchesToApplyBeforeDiffing = isRebasing
? mode.type === "append"
? existingPatches.slice(0, previouslyAppliedPatches.length)
: state.patches[state.patches.length - 1].didApply
? existingPatches.slice(0, previouslyAppliedPatches.length - 1)
: existingPatches.slice(0, previouslyAppliedPatches.length)
: mode.type === "append"
? existingPatches
: existingPatches.slice(0, -1);
if (createIssue && mode.type === "append") {
console.error("--create-issue is not compatible with --append.");
console_1.default.error("--create-issue is not compatible with --append.");
process.exit(1);
}
if (createIssue && isRebasing) {
console_1.default.error("--create-issue is not compatible with rebasing.");
process.exit(1);
}
const numPatchesAfterCreate = mode.type === "append" || existingPatches.length === 0

@@ -50,3 +77,4 @@ ? existingPatches.length + 1

const vcs = createIssue_1.getPackageVCSDetails(packageDetails);
const canCreateIssue = createIssue_1.shouldRecommendIssue(vcs) &&
const canCreateIssue = !isRebasing &&
createIssue_1.shouldRecommendIssue(vcs) &&
numPatchesAfterCreate === 1 &&

@@ -67,3 +95,3 @@ mode.type !== "append";

const patchesDir = path_1.resolve(path_1.join(appPath, patchDir));
console.info(chalk_1.default.grey("•"), "Creating temporary folder");
console_1.default.info(chalk_1.default.grey("•"), "Creating temporary folder");
// make a blank package.json

@@ -89,3 +117,3 @@ fs_extra_1.mkdirpSync(tmpRepoNpmRoot);

if (packageManager === "yarn") {
console.info(chalk_1.default.grey("•"), `Installing ${packageDetails.name}@${packageVersion} with yarn`);
console_1.default.info(chalk_1.default.grey("•"), `Installing ${packageDetails.name}@${packageVersion} with yarn`);
try {

@@ -108,3 +136,3 @@ // try first without ignoring scripts in case they are required

else {
console.info(chalk_1.default.grey("•"), `Installing ${packageDetails.name}@${packageVersion} with npm`);
console_1.default.info(chalk_1.default.grey("•"), `Installing ${packageDetails.name}@${packageVersion} with npm`);
try {

@@ -140,3 +168,3 @@ // try first without ignoring scripts in case they are required

// commit the package
console.info(chalk_1.default.grey("•"), "Diffing your files with clean files");
console_1.default.info(chalk_1.default.grey("•"), "Diffing your files with clean files");
fs_extra_1.writeFileSync(path_1.join(tmpRepo.name, ".gitignore"), "!/node_modules\n\n");

@@ -148,6 +176,3 @@ git("init");

filterFiles_1.removeIgnoredFiles(tmpRepoPackagePath, includePaths, excludePaths);
// apply all existing patches if appending
// otherwise apply all but the last
const patchesToApplyBeforeCommit = mode.type === "append" ? existingPatches : existingPatches.slice(0, -1);
for (const patchDetails of patchesToApplyBeforeCommit) {
for (const patchDetails of patchesToApplyBeforeDiffing) {
if (!applyPatches_1.applyPatch({

@@ -161,3 +186,3 @@ patchDetails,

// TODO: add better error message once --rebase is implemented
console.error(`Failed to apply patch ${patchDetails.patchFilename} to ${packageDetails.pathSpecifier}`);
console_1.default.error(`Failed to apply patch ${patchDetails.patchFilename} to ${packageDetails.pathSpecifier}`);
process.exit(1);

@@ -185,4 +210,4 @@ }

if (diffResult.stdout.length === 0) {
console.warn(`⁉️ Not creating patch file for package '${packagePathSpecifier}'`);
console.warn(`⁉️ There don't appear to be any changes.`);
console_1.default.warn(`⁉️ Not creating patch file for package '${packagePathSpecifier}'`);
console_1.default.warn(`⁉️ There don't appear to be any changes.`);
process.exit(1);

@@ -196,3 +221,3 @@ return;

if (e.message.includes("Unexpected file mode string: 120000")) {
console.error(`
console_1.default.error(`
⛔️ ${chalk_1.default.red.bold("ERROR")}

@@ -213,3 +238,3 @@

})));
console.error(`
console_1.default.error(`
⛔️ ${chalk_1.default.red.bold("ERROR")}

@@ -237,4 +262,4 @@

// maybe delete existing
if (mode.type === "overwrite_last") {
const prevPatch = existingPatches[existingPatches.length - 1];
if (!isRebasing && mode.type === "overwrite_last") {
const prevPatch = patchesToApplyBeforeDiffing[patchesToApplyBeforeDiffing.length - 1];
if (prevPatch) {

@@ -250,3 +275,3 @@ const patchFilePath = path_1.join(appPath, patchDir, prevPatch.patchFilename);

}
else if (existingPatches.length === 1) {
else if (!isRebasing && existingPatches.length === 1) {
// if we are appending to an existing patch that doesn't have a sequence number let's rename it

@@ -259,3 +284,3 @@ const prevPatch = existingPatches[0];

sequenceNumber: 1,
sequenceName: (_a = prevPatch.sequenceName) !== null && _a !== void 0 ? _a : "initial",
sequenceName: (_b = prevPatch.sequenceName) !== null && _b !== void 0 ? _b : "initial",
});

@@ -267,9 +292,9 @@ const oldPath = path_1.join(appPath, patchDir, prevPatch.patchFilename);

prevPatch.patchFilename = newFileName;
prevPatch.sequenceName = (_b = prevPatch.sequenceName) !== null && _b !== void 0 ? _b : "initial";
prevPatch.sequenceName = (_c = prevPatch.sequenceName) !== null && _c !== void 0 ? _c : "initial";
}
}
const lastPatch = existingPatches[existingPatches.length - 1];
const lastPatch = existingPatches[state ? state.patches.length - 1 : existingPatches.length - 1];
const sequenceName = mode.type === "append" ? mode.name : lastPatch === null || lastPatch === void 0 ? void 0 : lastPatch.sequenceName;
const sequenceNumber = mode.type === "append"
? ((_c = lastPatch === null || lastPatch === void 0 ? void 0 : lastPatch.sequenceNumber) !== null && _c !== void 0 ? _c : 0) + 1
? ((_d = lastPatch === null || lastPatch === void 0 ? void 0 : lastPatch.sequenceNumber) !== null && _d !== void 0 ? _d : 0) + 1
: lastPatch === null || lastPatch === void 0 ? void 0 : lastPatch.sequenceNumber;

@@ -288,6 +313,26 @@ const patchFileName = createPatchFileName({

fs_extra_1.writeFileSync(patchPath, diffResult.stdout);
console.log(`${chalk_1.default.green("✔")} Created file ${path_1.join(patchDir, patchFileName)}\n`);
const prevState = (mode.type === "append"
? existingPatches
: existingPatches.slice(0, -1)).map((p) => ({
console_1.default.log(`${chalk_1.default.green("✔")} Created file ${path_1.join(patchDir, patchFileName)}\n`);
// if we inserted a new patch into a sequence we may need to update the sequence numbers
if (isRebasing && mode.type === "append") {
const patchesToNudge = existingPatches.slice(state.patches.length);
if (sequenceNumber === undefined) {
throw new Error("sequenceNumber is undefined while rebasing");
}
if (((_e = patchesToNudge[0]) === null || _e === void 0 ? void 0 : _e.sequenceNumber) !== undefined &&
patchesToNudge[0].sequenceNumber <= sequenceNumber) {
let next = sequenceNumber + 1;
for (const p of patchesToNudge) {
const newName = createPatchFileName({
packageDetails,
packageVersion,
sequenceName: p.sequenceName,
sequenceNumber: next++,
});
const oldPath = path_1.join(appPath, patchDir, p.patchFilename);
const newPath = path_1.join(appPath, patchDir, newName);
fs_1.renameSync(oldPath, newPath);
}
}
}
const prevState = patchesToApplyBeforeDiffing.map((p) => ({
patchFilename: p.patchFilename,

@@ -305,5 +350,46 @@ didApply: true,

];
if (nextState.length > 1) {
stateFile_1.savePatchApplicationState(packageDetails, nextState);
// if any patches come after this one we just made, we should reapply them
let didFailWhileFinishingRebase = false;
if (isRebasing) {
const currentPatches = patchFs_1.getGroupedPatches(path_1.join(appPath, patchDir))
.pathSpecifierToPatchFiles[packageDetails.pathSpecifier];
const previouslyUnappliedPatches = currentPatches.slice(nextState.length);
if (previouslyUnappliedPatches.length) {
console_1.default.log(`Fast forwarding...`);
for (const patch of previouslyUnappliedPatches) {
const patchFilePath = path_1.join(appPath, patchDir, patch.patchFilename);
if (!applyPatches_1.applyPatch({
patchDetails: patch,
patchDir,
patchFilePath,
reverse: false,
cwd: tmpRepo.name,
})) {
didFailWhileFinishingRebase = true;
logPatchSequenceError({ patchDetails: patch });
nextState.push({
patchFilename: patch.patchFilename,
didApply: false,
patchContentHash: hash_1.hashFile(patchFilePath),
});
break;
}
else {
console_1.default.log(` ${chalk_1.default.green("✔")} ${patch.patchFilename}`);
nextState.push({
patchFilename: patch.patchFilename,
didApply: true,
patchContentHash: hash_1.hashFile(patchFilePath),
});
}
}
}
}
if (isRebasing || numPatchesAfterCreate > 1) {
stateFile_1.savePatchApplicationState({
packageDetails,
patches: nextState,
isRebasing: didFailWhileFinishingRebase,
});
}
else {

@@ -326,3 +412,3 @@ stateFile_1.clearPatchApplicationState(packageDetails);

catch (e) {
console.error(e);
console_1.default.error(e);
throw e;

@@ -346,2 +432,20 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"makePatch.js","sourceRoot":"","sources":["../src/makePatch.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\"\nimport { renameSync } from \"fs\"\nimport {\n  copySync,\n  existsSync,\n  mkdirpSync,\n  mkdirSync,\n  realpathSync,\n  unlinkSync,\n  writeFileSync,\n} from \"fs-extra\"\nimport { sync as rimraf } from \"rimraf\"\nimport { dirSync } from \"tmp\"\nimport { gzipSync } from \"zlib\"\nimport { applyPatch } from \"./applyPatches\"\nimport {\n  getPackageVCSDetails,\n  maybePrintIssueCreationPrompt,\n  openIssueCreationLink,\n  shouldRecommendIssue,\n} from \"./createIssue\"\nimport { PackageManager } from \"./detectPackageManager\"\nimport { removeIgnoredFiles } from \"./filterFiles\"\nimport { getPackageResolution } from \"./getPackageResolution\"\nimport { getPackageVersion } from \"./getPackageVersion\"\nimport { hashFile } from \"./hash\"\nimport {\n  getPatchDetailsFromCliString,\n  PackageDetails,\n  PatchedPackageDetails,\n} from \"./PackageDetails\"\nimport { parsePatchFile } from \"./patch/parse\"\nimport { getGroupedPatches } from \"./patchFs\"\nimport { dirname, join, resolve } from \"./path\"\nimport { resolveRelativeFileDependencies } from \"./resolveRelativeFileDependencies\"\nimport { spawnSafeSync } from \"./spawnSafe\"\nimport {\n  clearPatchApplicationState,\n  PatchState,\n  savePatchApplicationState,\n  STATE_FILE_NAME,\n} from \"./stateFile\"\n\nfunction printNoPackageFoundError(\n  packageName: string,\n  packageJsonPath: string,\n) {\n  console.error(\n    `No such package ${packageName}\n\n  File not found: ${packageJsonPath}`,\n  )\n}\n\nexport function makePatch({\n  packagePathSpecifier,\n  appPath,\n  packageManager,\n  includePaths,\n  excludePaths,\n  patchDir,\n  createIssue,\n  mode,\n}: {\n  packagePathSpecifier: string\n  appPath: string\n  packageManager: PackageManager\n  includePaths: RegExp\n  excludePaths: RegExp\n  patchDir: string\n  createIssue: boolean\n  mode: { type: \"overwrite_last\" } | { type: \"append\"; name?: string }\n}) {\n  const packageDetails = getPatchDetailsFromCliString(packagePathSpecifier)\n\n  if (!packageDetails) {\n    console.error(\"No such package\", packagePathSpecifier)\n    return\n  }\n\n  const existingPatches =\n    getGroupedPatches(patchDir).pathSpecifierToPatchFiles[\n      packageDetails.pathSpecifier\n    ] || []\n\n  if (createIssue && mode.type === \"append\") {\n    console.error(\"--create-issue is not compatible with --append.\")\n    process.exit(1)\n  }\n\n  const numPatchesAfterCreate =\n    mode.type === \"append\" || existingPatches.length === 0\n      ? existingPatches.length + 1\n      : existingPatches.length\n  const vcs = getPackageVCSDetails(packageDetails)\n  const canCreateIssue =\n    shouldRecommendIssue(vcs) &&\n    numPatchesAfterCreate === 1 &&\n    mode.type !== \"append\"\n\n  const appPackageJson = require(join(appPath, \"package.json\"))\n  const packagePath = join(appPath, packageDetails.path)\n  const packageJsonPath = join(packagePath, \"package.json\")\n\n  if (!existsSync(packageJsonPath)) {\n    printNoPackageFoundError(packagePathSpecifier, packageJsonPath)\n    process.exit(1)\n  }\n\n  const tmpRepo = dirSync({ unsafeCleanup: true })\n  const tmpRepoPackagePath = join(tmpRepo.name, packageDetails.path)\n  const tmpRepoNpmRoot = tmpRepoPackagePath.slice(\n    0,\n    -`/node_modules/${packageDetails.name}`.length,\n  )\n\n  const tmpRepoPackageJsonPath = join(tmpRepoNpmRoot, \"package.json\")\n\n  try {\n    const patchesDir = resolve(join(appPath, patchDir))\n\n    console.info(chalk.grey(\"•\"), \"Creating temporary folder\")\n\n    // make a blank package.json\n    mkdirpSync(tmpRepoNpmRoot)\n    writeFileSync(\n      tmpRepoPackageJsonPath,\n      JSON.stringify({\n        dependencies: {\n          [packageDetails.name]: getPackageResolution({\n            packageDetails,\n            packageManager,\n            appPath,\n          }),\n        },\n        resolutions: resolveRelativeFileDependencies(\n          appPath,\n          appPackageJson.resolutions || {},\n        ),\n      }),\n    )\n\n    const packageVersion = getPackageVersion(\n      join(resolve(packageDetails.path), \"package.json\"),\n    )\n\n    // copy .npmrc/.yarnrc in case packages are hosted in private registry\n    // copy .yarn directory as well to ensure installations work in yarn 2\n    // tslint:disable-next-line:align\n    ;[\".npmrc\", \".yarnrc\", \".yarn\"].forEach((rcFile) => {\n      const rcPath = join(appPath, rcFile)\n      if (existsSync(rcPath)) {\n        copySync(rcPath, join(tmpRepo.name, rcFile), { dereference: true })\n      }\n    })\n\n    if (packageManager === \"yarn\") {\n      console.info(\n        chalk.grey(\"•\"),\n        `Installing ${packageDetails.name}@${packageVersion} with yarn`,\n      )\n      try {\n        // try first without ignoring scripts in case they are required\n        // this works in 99.99% of cases\n        spawnSafeSync(`yarn`, [\"install\", \"--ignore-engines\"], {\n          cwd: tmpRepoNpmRoot,\n          logStdErrOnError: false,\n        })\n      } catch (e) {\n        // try again while ignoring scripts in case the script depends on\n        // an implicit context which we havn't reproduced\n        spawnSafeSync(\n          `yarn`,\n          [\"install\", \"--ignore-engines\", \"--ignore-scripts\"],\n          {\n            cwd: tmpRepoNpmRoot,\n          },\n        )\n      }\n    } else {\n      console.info(\n        chalk.grey(\"•\"),\n        `Installing ${packageDetails.name}@${packageVersion} with npm`,\n      )\n      try {\n        // try first without ignoring scripts in case they are required\n        // this works in 99.99% of cases\n        spawnSafeSync(`npm`, [\"i\", \"--force\"], {\n          cwd: tmpRepoNpmRoot,\n          logStdErrOnError: false,\n          stdio: \"ignore\",\n        })\n      } catch (e) {\n        // try again while ignoring scripts in case the script depends on\n        // an implicit context which we havn't reproduced\n        spawnSafeSync(`npm`, [\"i\", \"--ignore-scripts\", \"--force\"], {\n          cwd: tmpRepoNpmRoot,\n          stdio: \"ignore\",\n        })\n      }\n    }\n\n    const git = (...args: string[]) =>\n      spawnSafeSync(\"git\", args, {\n        cwd: tmpRepo.name,\n        env: { ...process.env, HOME: tmpRepo.name },\n        maxBuffer: 1024 * 1024 * 100,\n      })\n\n    // remove nested node_modules just to be safe\n    rimraf(join(tmpRepoPackagePath, \"node_modules\"))\n    // remove .git just to be safe\n    rimraf(join(tmpRepoPackagePath, \".git\"))\n    // remove patch-package state file\n    rimraf(join(tmpRepoPackagePath, STATE_FILE_NAME))\n\n    // commit the package\n    console.info(chalk.grey(\"•\"), \"Diffing your files with clean files\")\n    writeFileSync(join(tmpRepo.name, \".gitignore\"), \"!/node_modules\\n\\n\")\n    git(\"init\")\n    git(\"config\", \"--local\", \"user.name\", \"patch-package\")\n    git(\"config\", \"--local\", \"user.email\", \"patch@pack.age\")\n\n    // remove ignored files first\n    removeIgnoredFiles(tmpRepoPackagePath, includePaths, excludePaths)\n\n    // apply all existing patches if appending\n    // otherwise apply all but the last\n    const patchesToApplyBeforeCommit =\n      mode.type === \"append\" ? existingPatches : existingPatches.slice(0, -1)\n    for (const patchDetails of patchesToApplyBeforeCommit) {\n      if (\n        !applyPatch({\n          patchDetails,\n          patchDir,\n          patchFilePath: join(appPath, patchDir, patchDetails.patchFilename),\n          reverse: false,\n          cwd: tmpRepo.name,\n        })\n      ) {\n        // TODO: add better error message once --rebase is implemented\n        console.error(\n          `Failed to apply patch ${patchDetails.patchFilename} to ${packageDetails.pathSpecifier}`,\n        )\n        process.exit(1)\n      }\n    }\n    git(\"add\", \"-f\", packageDetails.path)\n    git(\"commit\", \"--allow-empty\", \"-m\", \"init\")\n\n    // replace package with user's version\n    rimraf(tmpRepoPackagePath)\n\n    // pnpm installs packages as symlinks, copySync would copy only the symlink\n    copySync(realpathSync(packagePath), tmpRepoPackagePath)\n\n    // remove nested node_modules just to be safe\n    rimraf(join(tmpRepoPackagePath, \"node_modules\"))\n    // remove .git just to be safe\n    rimraf(join(tmpRepoPackagePath, \".git\"))\n    // remove patch-package state file\n    rimraf(join(tmpRepoPackagePath, STATE_FILE_NAME))\n\n    // also remove ignored files like before\n    removeIgnoredFiles(tmpRepoPackagePath, includePaths, excludePaths)\n\n    // stage all files\n    git(\"add\", \"-f\", packageDetails.path)\n\n    // get diff of changes\n    const diffResult = git(\n      \"diff\",\n      \"--cached\",\n      \"--no-color\",\n      \"--ignore-space-at-eol\",\n      \"--no-ext-diff\",\n      \"--src-prefix=a/\",\n      \"--dst-prefix=b/\",\n    )\n\n    if (diffResult.stdout.length === 0) {\n      console.warn(\n        `⁉️  Not creating patch file for package '${packagePathSpecifier}'`,\n      )\n      console.warn(`⁉️  There don't appear to be any changes.`)\n      process.exit(1)\n      return\n    }\n\n    try {\n      parsePatchFile(diffResult.stdout.toString())\n    } catch (e) {\n      if (\n        (e as Error).message.includes(\"Unexpected file mode string: 120000\")\n      ) {\n        console.error(`\n⛔️ ${chalk.red.bold(\"ERROR\")}\n\n  Your changes involve creating symlinks. patch-package does not yet support\n  symlinks.\n  \n  ️Please use ${chalk.bold(\"--include\")} and/or ${chalk.bold(\n          \"--exclude\",\n        )} to narrow the scope of your patch if\n  this was unintentional.\n`)\n      } else {\n        const outPath = \"./patch-package-error.json.gz\"\n        writeFileSync(\n          outPath,\n          gzipSync(\n            JSON.stringify({\n              error: { message: e.message, stack: e.stack },\n              patch: diffResult.stdout.toString(),\n            }),\n          ),\n        )\n        console.error(`\n⛔️ ${chalk.red.bold(\"ERROR\")}\n        \n  patch-package was unable to read the patch-file made by git. This should not\n  happen.\n  \n  A diagnostic file was written to\n  \n    ${outPath}\n  \n  Please attach it to a github issue\n  \n    https://github.com/ds300/patch-package/issues/new?title=New+patch+parse+failed&body=Please+attach+the+diagnostic+file+by+dragging+it+into+here+🙏\n  \n  Note that this diagnostic file will contain code from the package you were\n  attempting to patch.\n\n`)\n      }\n      process.exit(1)\n      return\n    }\n\n    // maybe delete existing\n    if (mode.type === \"overwrite_last\") {\n      const prevPatch = existingPatches[existingPatches.length - 1] as\n        | PatchedPackageDetails\n        | undefined\n      if (prevPatch) {\n        const patchFilePath = join(appPath, patchDir, prevPatch.patchFilename)\n        try {\n          unlinkSync(patchFilePath)\n        } catch (e) {\n          // noop\n        }\n      }\n    } else if (existingPatches.length === 1) {\n      // if we are appending to an existing patch that doesn't have a sequence number let's rename it\n      const prevPatch = existingPatches[0]\n      if (prevPatch.sequenceNumber === undefined) {\n        const newFileName = createPatchFileName({\n          packageDetails,\n          packageVersion,\n          sequenceNumber: 1,\n          sequenceName: prevPatch.sequenceName ?? \"initial\",\n        })\n        const oldPath = join(appPath, patchDir, prevPatch.patchFilename)\n        const newPath = join(appPath, patchDir, newFileName)\n        renameSync(oldPath, newPath)\n        prevPatch.sequenceNumber = 1\n        prevPatch.patchFilename = newFileName\n        prevPatch.sequenceName = prevPatch.sequenceName ?? \"initial\"\n      }\n    }\n\n    const lastPatch = existingPatches[existingPatches.length - 1] as\n      | PatchedPackageDetails\n      | undefined\n    const sequenceName =\n      mode.type === \"append\" ? mode.name : lastPatch?.sequenceName\n    const sequenceNumber =\n      mode.type === \"append\"\n        ? (lastPatch?.sequenceNumber ?? 0) + 1\n        : lastPatch?.sequenceNumber\n\n    const patchFileName = createPatchFileName({\n      packageDetails,\n      packageVersion,\n      sequenceName,\n      sequenceNumber,\n    })\n\n    const patchPath = join(patchesDir, patchFileName)\n    if (!existsSync(dirname(patchPath))) {\n      // scoped package\n      mkdirSync(dirname(patchPath))\n    }\n    writeFileSync(patchPath, diffResult.stdout)\n    console.log(\n      `${chalk.green(\"✔\")} Created file ${join(patchDir, patchFileName)}\\n`,\n    )\n    const prevState: PatchState[] = (mode.type === \"append\"\n      ? existingPatches\n      : existingPatches.slice(0, -1)\n    ).map(\n      (p): PatchState => ({\n        patchFilename: p.patchFilename,\n        didApply: true,\n        patchContentHash: hashFile(join(appPath, patchDir, p.patchFilename)),\n      }),\n    )\n    const nextState: PatchState[] = [\n      ...prevState,\n      {\n        patchFilename: patchFileName,\n        didApply: true,\n        patchContentHash: hashFile(patchPath),\n      },\n    ]\n    if (nextState.length > 1) {\n      savePatchApplicationState(packageDetails, nextState)\n    } else {\n      clearPatchApplicationState(packageDetails)\n    }\n    if (canCreateIssue) {\n      if (createIssue) {\n        openIssueCreationLink({\n          packageDetails,\n          patchFileContents: diffResult.stdout.toString(),\n          packageVersion,\n        })\n      } else {\n        maybePrintIssueCreationPrompt(vcs, packageDetails, packageManager)\n      }\n    }\n  } catch (e) {\n    console.error(e)\n    throw e\n  } finally {\n    tmpRepo.removeCallback()\n  }\n}\n\nfunction createPatchFileName({\n  packageDetails,\n  packageVersion,\n  sequenceNumber,\n  sequenceName,\n}: {\n  packageDetails: PackageDetails\n  packageVersion: string\n  sequenceNumber?: number\n  sequenceName?: string\n}) {\n  const packageNames = packageDetails.packageNames\n    .map((name) => name.replace(/\\//g, \"+\"))\n    .join(\"++\")\n\n  const nameAndVersion = `${packageNames}+${packageVersion}`\n  const num =\n    sequenceNumber === undefined\n      ? \"\"\n      : `+${sequenceNumber.toString().padStart(3, \"0\")}`\n  const name = !sequenceName ? \"\" : `+${sequenceName}`\n\n  return `${nameAndVersion}${num}${name}.patch`\n}\n"]}
function logPatchSequenceError({ patchDetails, }) {
console_1.default.log(`
${chalk_1.default.red.bold("⛔ ERROR")}
Failed to apply patch file ${chalk_1.default.bold(patchDetails.patchFilename)}.
If this patch file is no longer useful, delete it and run
${chalk_1.default.bold(`patch-package`)}
Otherwise you should open ${patchDetails.path}, manually apply the changes from the patch file, and run
${chalk_1.default.bold(`patch-package ${patchDetails.pathSpecifier}`)}
to update the patch file.
`);
}
exports.logPatchSequenceError = logPatchSequenceError;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"makePatch.js","sourceRoot":"","sources":["../src/makePatch.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\"\nimport console from \"console\"\nimport { renameSync } from \"fs\"\nimport {\n  copySync,\n  existsSync,\n  mkdirpSync,\n  mkdirSync,\n  realpathSync,\n  unlinkSync,\n  writeFileSync,\n} from \"fs-extra\"\nimport { sync as rimraf } from \"rimraf\"\nimport { dirSync } from \"tmp\"\nimport { gzipSync } from \"zlib\"\nimport { applyPatch } from \"./applyPatches\"\nimport {\n  getPackageVCSDetails,\n  maybePrintIssueCreationPrompt,\n  openIssueCreationLink,\n  shouldRecommendIssue,\n} from \"./createIssue\"\nimport { PackageManager } from \"./detectPackageManager\"\nimport { removeIgnoredFiles } from \"./filterFiles\"\nimport { getPackageResolution } from \"./getPackageResolution\"\nimport { getPackageVersion } from \"./getPackageVersion\"\nimport { hashFile } from \"./hash\"\nimport {\n  getPatchDetailsFromCliString,\n  PackageDetails,\n  PatchedPackageDetails,\n} from \"./PackageDetails\"\nimport { parsePatchFile } from \"./patch/parse\"\nimport { getGroupedPatches } from \"./patchFs\"\nimport { dirname, join, resolve } from \"./path\"\nimport { resolveRelativeFileDependencies } from \"./resolveRelativeFileDependencies\"\nimport { spawnSafeSync } from \"./spawnSafe\"\nimport {\n  clearPatchApplicationState,\n  getPatchApplicationState,\n  PatchState,\n  savePatchApplicationState,\n  STATE_FILE_NAME,\n} from \"./stateFile\"\n\nfunction printNoPackageFoundError(\n  packageName: string,\n  packageJsonPath: string,\n) {\n  console.error(\n    `No such package ${packageName}\n\n  File not found: ${packageJsonPath}`,\n  )\n}\n\nexport function makePatch({\n  packagePathSpecifier,\n  appPath,\n  packageManager,\n  includePaths,\n  excludePaths,\n  patchDir,\n  createIssue,\n  mode,\n}: {\n  packagePathSpecifier: string\n  appPath: string\n  packageManager: PackageManager\n  includePaths: RegExp\n  excludePaths: RegExp\n  patchDir: string\n  createIssue: boolean\n  mode: { type: \"overwrite_last\" } | { type: \"append\"; name?: string }\n}) {\n  const packageDetails = getPatchDetailsFromCliString(packagePathSpecifier)\n\n  if (!packageDetails) {\n    console.error(\"No such package\", packagePathSpecifier)\n    return\n  }\n\n  const state = getPatchApplicationState(packageDetails)\n  const isRebasing = state?.isRebasing ?? false\n  // TODO: verify applied patch hashes\n  // TODO: handle case for --rebase 0\n  // TODO: handle empty diffs while rebasing\n  if (\n    mode.type === \"overwrite_last\" &&\n    isRebasing &&\n    state?.patches.length === 0\n  ) {\n    mode = { type: \"append\", name: \"initial\" }\n  }\n\n  const existingPatches =\n    getGroupedPatches(patchDir).pathSpecifierToPatchFiles[\n      packageDetails.pathSpecifier\n    ] || []\n\n  // apply all existing patches if appending\n  // otherwise apply all but the last\n  const previouslyAppliedPatches = state?.patches.filter((p) => p.didApply)\n  const patchesToApplyBeforeDiffing: PatchedPackageDetails[] = isRebasing\n    ? mode.type === \"append\"\n      ? existingPatches.slice(0, previouslyAppliedPatches!.length)\n      : state!.patches[state!.patches.length - 1].didApply\n      ? existingPatches.slice(0, previouslyAppliedPatches!.length - 1)\n      : existingPatches.slice(0, previouslyAppliedPatches!.length)\n    : mode.type === \"append\"\n    ? existingPatches\n    : existingPatches.slice(0, -1)\n\n  if (createIssue && mode.type === \"append\") {\n    console.error(\"--create-issue is not compatible with --append.\")\n    process.exit(1)\n  }\n\n  if (createIssue && isRebasing) {\n    console.error(\"--create-issue is not compatible with rebasing.\")\n    process.exit(1)\n  }\n\n  const numPatchesAfterCreate =\n    mode.type === \"append\" || existingPatches.length === 0\n      ? existingPatches.length + 1\n      : existingPatches.length\n  const vcs = getPackageVCSDetails(packageDetails)\n  const canCreateIssue =\n    !isRebasing &&\n    shouldRecommendIssue(vcs) &&\n    numPatchesAfterCreate === 1 &&\n    mode.type !== \"append\"\n\n  const appPackageJson = require(join(appPath, \"package.json\"))\n  const packagePath = join(appPath, packageDetails.path)\n  const packageJsonPath = join(packagePath, \"package.json\")\n\n  if (!existsSync(packageJsonPath)) {\n    printNoPackageFoundError(packagePathSpecifier, packageJsonPath)\n    process.exit(1)\n  }\n\n  const tmpRepo = dirSync({ unsafeCleanup: true })\n  const tmpRepoPackagePath = join(tmpRepo.name, packageDetails.path)\n  const tmpRepoNpmRoot = tmpRepoPackagePath.slice(\n    0,\n    -`/node_modules/${packageDetails.name}`.length,\n  )\n\n  const tmpRepoPackageJsonPath = join(tmpRepoNpmRoot, \"package.json\")\n\n  try {\n    const patchesDir = resolve(join(appPath, patchDir))\n\n    console.info(chalk.grey(\"•\"), \"Creating temporary folder\")\n\n    // make a blank package.json\n    mkdirpSync(tmpRepoNpmRoot)\n    writeFileSync(\n      tmpRepoPackageJsonPath,\n      JSON.stringify({\n        dependencies: {\n          [packageDetails.name]: getPackageResolution({\n            packageDetails,\n            packageManager,\n            appPath,\n          }),\n        },\n        resolutions: resolveRelativeFileDependencies(\n          appPath,\n          appPackageJson.resolutions || {},\n        ),\n      }),\n    )\n\n    const packageVersion = getPackageVersion(\n      join(resolve(packageDetails.path), \"package.json\"),\n    )\n\n    // copy .npmrc/.yarnrc in case packages are hosted in private registry\n    // copy .yarn directory as well to ensure installations work in yarn 2\n    // tslint:disable-next-line:align\n    ;[\".npmrc\", \".yarnrc\", \".yarn\"].forEach((rcFile) => {\n      const rcPath = join(appPath, rcFile)\n      if (existsSync(rcPath)) {\n        copySync(rcPath, join(tmpRepo.name, rcFile), { dereference: true })\n      }\n    })\n\n    if (packageManager === \"yarn\") {\n      console.info(\n        chalk.grey(\"•\"),\n        `Installing ${packageDetails.name}@${packageVersion} with yarn`,\n      )\n      try {\n        // try first without ignoring scripts in case they are required\n        // this works in 99.99% of cases\n        spawnSafeSync(`yarn`, [\"install\", \"--ignore-engines\"], {\n          cwd: tmpRepoNpmRoot,\n          logStdErrOnError: false,\n        })\n      } catch (e) {\n        // try again while ignoring scripts in case the script depends on\n        // an implicit context which we havn't reproduced\n        spawnSafeSync(\n          `yarn`,\n          [\"install\", \"--ignore-engines\", \"--ignore-scripts\"],\n          {\n            cwd: tmpRepoNpmRoot,\n          },\n        )\n      }\n    } else {\n      console.info(\n        chalk.grey(\"•\"),\n        `Installing ${packageDetails.name}@${packageVersion} with npm`,\n      )\n      try {\n        // try first without ignoring scripts in case they are required\n        // this works in 99.99% of cases\n        spawnSafeSync(`npm`, [\"i\", \"--force\"], {\n          cwd: tmpRepoNpmRoot,\n          logStdErrOnError: false,\n          stdio: \"ignore\",\n        })\n      } catch (e) {\n        // try again while ignoring scripts in case the script depends on\n        // an implicit context which we havn't reproduced\n        spawnSafeSync(`npm`, [\"i\", \"--ignore-scripts\", \"--force\"], {\n          cwd: tmpRepoNpmRoot,\n          stdio: \"ignore\",\n        })\n      }\n    }\n\n    const git = (...args: string[]) =>\n      spawnSafeSync(\"git\", args, {\n        cwd: tmpRepo.name,\n        env: { ...process.env, HOME: tmpRepo.name },\n        maxBuffer: 1024 * 1024 * 100,\n      })\n\n    // remove nested node_modules just to be safe\n    rimraf(join(tmpRepoPackagePath, \"node_modules\"))\n    // remove .git just to be safe\n    rimraf(join(tmpRepoPackagePath, \".git\"))\n    // remove patch-package state file\n    rimraf(join(tmpRepoPackagePath, STATE_FILE_NAME))\n\n    // commit the package\n    console.info(chalk.grey(\"•\"), \"Diffing your files with clean files\")\n    writeFileSync(join(tmpRepo.name, \".gitignore\"), \"!/node_modules\\n\\n\")\n    git(\"init\")\n    git(\"config\", \"--local\", \"user.name\", \"patch-package\")\n    git(\"config\", \"--local\", \"user.email\", \"patch@pack.age\")\n\n    // remove ignored files first\n    removeIgnoredFiles(tmpRepoPackagePath, includePaths, excludePaths)\n\n    for (const patchDetails of patchesToApplyBeforeDiffing) {\n      if (\n        !applyPatch({\n          patchDetails,\n          patchDir,\n          patchFilePath: join(appPath, patchDir, patchDetails.patchFilename),\n          reverse: false,\n          cwd: tmpRepo.name,\n        })\n      ) {\n        // TODO: add better error message once --rebase is implemented\n        console.error(\n          `Failed to apply patch ${patchDetails.patchFilename} to ${packageDetails.pathSpecifier}`,\n        )\n        process.exit(1)\n      }\n    }\n    git(\"add\", \"-f\", packageDetails.path)\n    git(\"commit\", \"--allow-empty\", \"-m\", \"init\")\n\n    // replace package with user's version\n    rimraf(tmpRepoPackagePath)\n\n    // pnpm installs packages as symlinks, copySync would copy only the symlink\n    copySync(realpathSync(packagePath), tmpRepoPackagePath)\n\n    // remove nested node_modules just to be safe\n    rimraf(join(tmpRepoPackagePath, \"node_modules\"))\n    // remove .git just to be safe\n    rimraf(join(tmpRepoPackagePath, \".git\"))\n    // remove patch-package state file\n    rimraf(join(tmpRepoPackagePath, STATE_FILE_NAME))\n\n    // also remove ignored files like before\n    removeIgnoredFiles(tmpRepoPackagePath, includePaths, excludePaths)\n\n    // stage all files\n    git(\"add\", \"-f\", packageDetails.path)\n\n    // get diff of changes\n    const diffResult = git(\n      \"diff\",\n      \"--cached\",\n      \"--no-color\",\n      \"--ignore-space-at-eol\",\n      \"--no-ext-diff\",\n      \"--src-prefix=a/\",\n      \"--dst-prefix=b/\",\n    )\n\n    if (diffResult.stdout.length === 0) {\n      console.warn(\n        `⁉️  Not creating patch file for package '${packagePathSpecifier}'`,\n      )\n      console.warn(`⁉️  There don't appear to be any changes.`)\n      process.exit(1)\n      return\n    }\n\n    try {\n      parsePatchFile(diffResult.stdout.toString())\n    } catch (e) {\n      if (\n        (e as Error).message.includes(\"Unexpected file mode string: 120000\")\n      ) {\n        console.error(`\n⛔️ ${chalk.red.bold(\"ERROR\")}\n\n  Your changes involve creating symlinks. patch-package does not yet support\n  symlinks.\n  \n  ️Please use ${chalk.bold(\"--include\")} and/or ${chalk.bold(\n          \"--exclude\",\n        )} to narrow the scope of your patch if\n  this was unintentional.\n`)\n      } else {\n        const outPath = \"./patch-package-error.json.gz\"\n        writeFileSync(\n          outPath,\n          gzipSync(\n            JSON.stringify({\n              error: { message: e.message, stack: e.stack },\n              patch: diffResult.stdout.toString(),\n            }),\n          ),\n        )\n        console.error(`\n⛔️ ${chalk.red.bold(\"ERROR\")}\n        \n  patch-package was unable to read the patch-file made by git. This should not\n  happen.\n  \n  A diagnostic file was written to\n  \n    ${outPath}\n  \n  Please attach it to a github issue\n  \n    https://github.com/ds300/patch-package/issues/new?title=New+patch+parse+failed&body=Please+attach+the+diagnostic+file+by+dragging+it+into+here+🙏\n  \n  Note that this diagnostic file will contain code from the package you were\n  attempting to patch.\n\n`)\n      }\n      process.exit(1)\n      return\n    }\n\n    // maybe delete existing\n    if (!isRebasing && mode.type === \"overwrite_last\") {\n      const prevPatch = patchesToApplyBeforeDiffing[\n        patchesToApplyBeforeDiffing.length - 1\n      ] as PatchedPackageDetails | undefined\n      if (prevPatch) {\n        const patchFilePath = join(appPath, patchDir, prevPatch.patchFilename)\n        try {\n          unlinkSync(patchFilePath)\n        } catch (e) {\n          // noop\n        }\n      }\n    } else if (!isRebasing && existingPatches.length === 1) {\n      // if we are appending to an existing patch that doesn't have a sequence number let's rename it\n      const prevPatch = existingPatches[0]\n      if (prevPatch.sequenceNumber === undefined) {\n        const newFileName = createPatchFileName({\n          packageDetails,\n          packageVersion,\n          sequenceNumber: 1,\n          sequenceName: prevPatch.sequenceName ?? \"initial\",\n        })\n        const oldPath = join(appPath, patchDir, prevPatch.patchFilename)\n        const newPath = join(appPath, patchDir, newFileName)\n        renameSync(oldPath, newPath)\n        prevPatch.sequenceNumber = 1\n        prevPatch.patchFilename = newFileName\n        prevPatch.sequenceName = prevPatch.sequenceName ?? \"initial\"\n      }\n    }\n\n    const lastPatch = existingPatches[\n      state ? state.patches.length - 1 : existingPatches.length - 1\n    ] as PatchedPackageDetails | undefined\n    const sequenceName =\n      mode.type === \"append\" ? mode.name : lastPatch?.sequenceName\n    const sequenceNumber =\n      mode.type === \"append\"\n        ? (lastPatch?.sequenceNumber ?? 0) + 1\n        : lastPatch?.sequenceNumber\n\n    const patchFileName = createPatchFileName({\n      packageDetails,\n      packageVersion,\n      sequenceName,\n      sequenceNumber,\n    })\n\n    const patchPath = join(patchesDir, patchFileName)\n    if (!existsSync(dirname(patchPath))) {\n      // scoped package\n      mkdirSync(dirname(patchPath))\n    }\n    writeFileSync(patchPath, diffResult.stdout)\n    console.log(\n      `${chalk.green(\"✔\")} Created file ${join(patchDir, patchFileName)}\\n`,\n    )\n\n    // if we inserted a new patch into a sequence we may need to update the sequence numbers\n    if (isRebasing && mode.type === \"append\") {\n      const patchesToNudge = existingPatches.slice(state!.patches.length)\n      if (sequenceNumber === undefined) {\n        throw new Error(\"sequenceNumber is undefined while rebasing\")\n      }\n      if (\n        patchesToNudge[0]?.sequenceNumber !== undefined &&\n        patchesToNudge[0].sequenceNumber <= sequenceNumber\n      ) {\n        let next = sequenceNumber + 1\n        for (const p of patchesToNudge) {\n          const newName = createPatchFileName({\n            packageDetails,\n            packageVersion,\n            sequenceName: p.sequenceName,\n            sequenceNumber: next++,\n          })\n          const oldPath = join(appPath, patchDir, p.patchFilename)\n          const newPath = join(appPath, patchDir, newName)\n          renameSync(oldPath, newPath)\n        }\n      }\n    }\n\n    const prevState: PatchState[] = patchesToApplyBeforeDiffing.map(\n      (p): PatchState => ({\n        patchFilename: p.patchFilename,\n        didApply: true,\n        patchContentHash: hashFile(join(appPath, patchDir, p.patchFilename)),\n      }),\n    )\n    const nextState: PatchState[] = [\n      ...prevState,\n      {\n        patchFilename: patchFileName,\n        didApply: true,\n        patchContentHash: hashFile(patchPath),\n      },\n    ]\n\n    // if any patches come after this one we just made, we should reapply them\n    let didFailWhileFinishingRebase = false\n    if (isRebasing) {\n      const currentPatches = getGroupedPatches(join(appPath, patchDir))\n        .pathSpecifierToPatchFiles[packageDetails.pathSpecifier]\n\n      const previouslyUnappliedPatches = currentPatches.slice(nextState.length)\n      if (previouslyUnappliedPatches.length) {\n        console.log(`Fast forwarding...`)\n        for (const patch of previouslyUnappliedPatches) {\n          const patchFilePath = join(appPath, patchDir, patch.patchFilename)\n          if (\n            !applyPatch({\n              patchDetails: patch,\n              patchDir,\n              patchFilePath,\n              reverse: false,\n              cwd: tmpRepo.name,\n            })\n          ) {\n            didFailWhileFinishingRebase = true\n            logPatchSequenceError({ patchDetails: patch })\n            nextState.push({\n              patchFilename: patch.patchFilename,\n              didApply: false,\n              patchContentHash: hashFile(patchFilePath),\n            })\n            break\n          } else {\n            console.log(`  ${chalk.green(\"✔\")} ${patch.patchFilename}`)\n            nextState.push({\n              patchFilename: patch.patchFilename,\n              didApply: true,\n              patchContentHash: hashFile(patchFilePath),\n            })\n          }\n        }\n      }\n    }\n\n    if (isRebasing || numPatchesAfterCreate > 1) {\n      savePatchApplicationState({\n        packageDetails,\n        patches: nextState,\n        isRebasing: didFailWhileFinishingRebase,\n      })\n    } else {\n      clearPatchApplicationState(packageDetails)\n    }\n\n    if (canCreateIssue) {\n      if (createIssue) {\n        openIssueCreationLink({\n          packageDetails,\n          patchFileContents: diffResult.stdout.toString(),\n          packageVersion,\n        })\n      } else {\n        maybePrintIssueCreationPrompt(vcs, packageDetails, packageManager)\n      }\n    }\n  } catch (e) {\n    console.error(e)\n    throw e\n  } finally {\n    tmpRepo.removeCallback()\n  }\n}\n\nfunction createPatchFileName({\n  packageDetails,\n  packageVersion,\n  sequenceNumber,\n  sequenceName,\n}: {\n  packageDetails: PackageDetails\n  packageVersion: string\n  sequenceNumber?: number\n  sequenceName?: string\n}) {\n  const packageNames = packageDetails.packageNames\n    .map((name) => name.replace(/\\//g, \"+\"))\n    .join(\"++\")\n\n  const nameAndVersion = `${packageNames}+${packageVersion}`\n  const num =\n    sequenceNumber === undefined\n      ? \"\"\n      : `+${sequenceNumber.toString().padStart(3, \"0\")}`\n  const name = !sequenceName ? \"\" : `+${sequenceName}`\n\n  return `${nameAndVersion}${num}${name}.patch`\n}\n\nexport function logPatchSequenceError({\n  patchDetails,\n}: {\n  patchDetails: PatchedPackageDetails\n}) {\n  console.log(`\n${chalk.red.bold(\"⛔ ERROR\")}\n\nFailed to apply patch file ${chalk.bold(patchDetails.patchFilename)}.\n\nIf this patch file is no longer useful, delete it and run\n\n  ${chalk.bold(`patch-package`)}\n  \nOtherwise you should open ${\n    patchDetails.path\n  }, manually apply the changes from the patch file, and run\n\n  ${chalk.bold(`patch-package ${patchDetails.pathSpecifier}`)}\n\nto update the patch file.\n`)\n}\n"]}
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });

@@ -6,21 +9,32 @@ exports.clearPatchApplicationState = exports.savePatchApplicationState = exports.getPatchApplicationState = exports.STATE_FILE_NAME = void 0;

const path_1 = require("path");
const version = 0;
const json_stable_stringify_1 = __importDefault(require("json-stable-stringify"));
const version = 1;
exports.STATE_FILE_NAME = ".patch-package.json";
function getPatchApplicationState(packageDetails) {
const fileName = path_1.join(packageDetails.path, exports.STATE_FILE_NAME);
let state = null;
try {
const state = JSON.parse(fs_1.readFileSync(fileName, "utf8"));
if (state.version !== version) {
return null;
}
return state;
state = JSON.parse(fs_1.readFileSync(fileName, "utf8"));
}
catch (e) {
// noop
}
if (!state) {
return null;
}
if (state.version !== version) {
console.error(`You upgraded patch-package and need to fully reinstall node_modules to continue.`);
process.exit(1);
}
return state;
}
exports.getPatchApplicationState = getPatchApplicationState;
function savePatchApplicationState(packageDetails, patches) {
function savePatchApplicationState({ packageDetails, patches, isRebasing, }) {
const fileName = path_1.join(packageDetails.path, exports.STATE_FILE_NAME);
fs_1.writeFileSync(fileName, JSON.stringify({ version, patches }, null, 2), "utf8");
const state = {
patches,
version,
isRebasing,
};
fs_1.writeFileSync(fileName, json_stable_stringify_1.default(state, { space: 4 }), "utf8");
}

@@ -38,2 +52,2 @@ exports.savePatchApplicationState = savePatchApplicationState;

exports.clearPatchApplicationState = clearPatchApplicationState;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGVGaWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3N0YXRlRmlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQkFBNEQ7QUFDNUQsK0JBQTJCO0FBUTNCLE1BQU0sT0FBTyxHQUFHLENBQUMsQ0FBQTtBQU1KLFFBQUEsZUFBZSxHQUFHLHFCQUFxQixDQUFBO0FBRXBELFNBQWdCLHdCQUF3QixDQUN0QyxjQUE4QjtJQUU5QixNQUFNLFFBQVEsR0FBRyxXQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSx1QkFBZSxDQUFDLENBQUE7SUFFM0QsSUFBSTtRQUNGLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsaUJBQVksQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQTtRQUN4RCxJQUFJLEtBQUssQ0FBQyxPQUFPLEtBQUssT0FBTyxFQUFFO1lBQzdCLE9BQU8sSUFBSSxDQUFBO1NBQ1o7UUFDRCxPQUFPLEtBQUssQ0FBQTtLQUNiO0lBQUMsT0FBTyxDQUFDLEVBQUU7UUFDVixPQUFPLElBQUksQ0FBQTtLQUNaO0FBQ0gsQ0FBQztBQWRELDREQWNDO0FBQ0QsU0FBZ0IseUJBQXlCLENBQ3ZDLGNBQThCLEVBQzlCLE9BQXFCO0lBRXJCLE1BQU0sUUFBUSxHQUFHLFdBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLHVCQUFlLENBQUMsQ0FBQTtJQUUzRCxrQkFBYSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQTtBQUNoRixDQUFDO0FBUEQsOERBT0M7QUFFRCxTQUFnQiwwQkFBMEIsQ0FBQyxjQUE4QjtJQUN2RSxNQUFNLFFBQVEsR0FBRyxXQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSx1QkFBZSxDQUFDLENBQUE7SUFFM0QsSUFBSTtRQUNGLGVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQTtLQUNyQjtJQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ1YsT0FBTztLQUNSO0FBQ0gsQ0FBQztBQVJELGdFQVFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVhZEZpbGVTeW5jLCB1bmxpbmtTeW5jLCB3cml0ZUZpbGVTeW5jIH0gZnJvbSBcImZzXCJcbmltcG9ydCB7IGpvaW4gfSBmcm9tIFwicGF0aFwiXG5pbXBvcnQgeyBQYWNrYWdlRGV0YWlscyB9IGZyb20gXCIuL1BhY2thZ2VEZXRhaWxzXCJcbmV4cG9ydCBpbnRlcmZhY2UgUGF0Y2hTdGF0ZSB7XG4gIHBhdGNoRmlsZW5hbWU6IHN0cmluZ1xuICBwYXRjaENvbnRlbnRIYXNoOiBzdHJpbmdcbiAgZGlkQXBwbHk6IHRydWVcbn1cblxuY29uc3QgdmVyc2lvbiA9IDBcbmV4cG9ydCBpbnRlcmZhY2UgUGF0Y2hBcHBsaWNhdGlvblN0YXRlIHtcbiAgdmVyc2lvbjogbnVtYmVyXG4gIHBhdGNoZXM6IFBhdGNoU3RhdGVbXVxufVxuXG5leHBvcnQgY29uc3QgU1RBVEVfRklMRV9OQU1FID0gXCIucGF0Y2gtcGFja2FnZS5qc29uXCJcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFBhdGNoQXBwbGljYXRpb25TdGF0ZShcbiAgcGFja2FnZURldGFpbHM6IFBhY2thZ2VEZXRhaWxzLFxuKTogUGF0Y2hBcHBsaWNhdGlvblN0YXRlIHwgbnVsbCB7XG4gIGNvbnN0IGZpbGVOYW1lID0gam9pbihwYWNrYWdlRGV0YWlscy5wYXRoLCBTVEFURV9GSUxFX05BTUUpXG5cbiAgdHJ5IHtcbiAgICBjb25zdCBzdGF0ZSA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKGZpbGVOYW1lLCBcInV0ZjhcIikpXG4gICAgaWYgKHN0YXRlLnZlcnNpb24gIT09IHZlcnNpb24pIHtcbiAgICAgIHJldHVybiBudWxsXG4gICAgfVxuICAgIHJldHVybiBzdGF0ZVxuICB9IGNhdGNoIChlKSB7XG4gICAgcmV0dXJuIG51bGxcbiAgfVxufVxuZXhwb3J0IGZ1bmN0aW9uIHNhdmVQYXRjaEFwcGxpY2F0aW9uU3RhdGUoXG4gIHBhY2thZ2VEZXRhaWxzOiBQYWNrYWdlRGV0YWlscyxcbiAgcGF0Y2hlczogUGF0Y2hTdGF0ZVtdLFxuKSB7XG4gIGNvbnN0IGZpbGVOYW1lID0gam9pbihwYWNrYWdlRGV0YWlscy5wYXRoLCBTVEFURV9GSUxFX05BTUUpXG5cbiAgd3JpdGVGaWxlU3luYyhmaWxlTmFtZSwgSlNPTi5zdHJpbmdpZnkoeyB2ZXJzaW9uLCBwYXRjaGVzIH0sIG51bGwsIDIpLCBcInV0ZjhcIilcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNsZWFyUGF0Y2hBcHBsaWNhdGlvblN0YXRlKHBhY2thZ2VEZXRhaWxzOiBQYWNrYWdlRGV0YWlscykge1xuICBjb25zdCBmaWxlTmFtZSA9IGpvaW4ocGFja2FnZURldGFpbHMucGF0aCwgU1RBVEVfRklMRV9OQU1FKVxuXG4gIHRyeSB7XG4gICAgdW5saW5rU3luYyhmaWxlTmFtZSlcbiAgfSBjYXRjaCAoZSkge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGVGaWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3N0YXRlRmlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSwyQkFBNEQ7QUFDNUQsK0JBQTJCO0FBRTNCLGtGQUE2QztBQU83QyxNQUFNLE9BQU8sR0FBRyxDQUFDLENBQUE7QUFPSixRQUFBLGVBQWUsR0FBRyxxQkFBcUIsQ0FBQTtBQUVwRCxTQUFnQix3QkFBd0IsQ0FDdEMsY0FBOEI7SUFFOUIsTUFBTSxRQUFRLEdBQUcsV0FBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsdUJBQWUsQ0FBQyxDQUFBO0lBRTNELElBQUksS0FBSyxHQUFpQyxJQUFJLENBQUE7SUFDOUMsSUFBSTtRQUNGLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFZLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUE7S0FDbkQ7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNWLE9BQU87S0FDUjtJQUNELElBQUksQ0FBQyxLQUFLLEVBQUU7UUFDVixPQUFPLElBQUksQ0FBQTtLQUNaO0lBQ0QsSUFBSSxLQUFLLENBQUMsT0FBTyxLQUFLLE9BQU8sRUFBRTtRQUM3QixPQUFPLENBQUMsS0FBSyxDQUNYLGtGQUFrRixDQUNuRixDQUFBO1FBQ0QsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtLQUNoQjtJQUNELE9BQU8sS0FBSyxDQUFBO0FBQ2QsQ0FBQztBQXJCRCw0REFxQkM7QUFFRCxTQUFnQix5QkFBeUIsQ0FBQyxFQUN4QyxjQUFjLEVBQ2QsT0FBTyxFQUNQLFVBQVUsR0FLWDtJQUNDLE1BQU0sUUFBUSxHQUFHLFdBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLHVCQUFlLENBQUMsQ0FBQTtJQUUzRCxNQUFNLEtBQUssR0FBMEI7UUFDbkMsT0FBTztRQUNQLE9BQU87UUFDUCxVQUFVO0tBQ1gsQ0FBQTtJQUVELGtCQUFhLENBQUMsUUFBUSxFQUFFLCtCQUFTLENBQUMsS0FBSyxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUE7QUFDakUsQ0FBQztBQWxCRCw4REFrQkM7QUFFRCxTQUFnQiwwQkFBMEIsQ0FBQyxjQUE4QjtJQUN2RSxNQUFNLFFBQVEsR0FBRyxXQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSx1QkFBZSxDQUFDLENBQUE7SUFFM0QsSUFBSTtRQUNGLGVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQTtLQUNyQjtJQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ1YsT0FBTztLQUNSO0FBQ0gsQ0FBQztBQVJELGdFQVFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVhZEZpbGVTeW5jLCB1bmxpbmtTeW5jLCB3cml0ZUZpbGVTeW5jIH0gZnJvbSBcImZzXCJcbmltcG9ydCB7IGpvaW4gfSBmcm9tIFwicGF0aFwiXG5pbXBvcnQgeyBQYWNrYWdlRGV0YWlscyB9IGZyb20gXCIuL1BhY2thZ2VEZXRhaWxzXCJcbmltcG9ydCBzdHJpbmdpZnkgZnJvbSBcImpzb24tc3RhYmxlLXN0cmluZ2lmeVwiXG5leHBvcnQgaW50ZXJmYWNlIFBhdGNoU3RhdGUge1xuICBwYXRjaEZpbGVuYW1lOiBzdHJpbmdcbiAgcGF0Y2hDb250ZW50SGFzaDogc3RyaW5nXG4gIGRpZEFwcGx5OiBib29sZWFuXG59XG5cbmNvbnN0IHZlcnNpb24gPSAxXG5leHBvcnQgaW50ZXJmYWNlIFBhdGNoQXBwbGljYXRpb25TdGF0ZSB7XG4gIHZlcnNpb246IG51bWJlclxuICBwYXRjaGVzOiBQYXRjaFN0YXRlW11cbiAgaXNSZWJhc2luZzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgU1RBVEVfRklMRV9OQU1FID0gXCIucGF0Y2gtcGFja2FnZS5qc29uXCJcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFBhdGNoQXBwbGljYXRpb25TdGF0ZShcbiAgcGFja2FnZURldGFpbHM6IFBhY2thZ2VEZXRhaWxzLFxuKTogUGF0Y2hBcHBsaWNhdGlvblN0YXRlIHwgbnVsbCB7XG4gIGNvbnN0IGZpbGVOYW1lID0gam9pbihwYWNrYWdlRGV0YWlscy5wYXRoLCBTVEFURV9GSUxFX05BTUUpXG5cbiAgbGV0IHN0YXRlOiBudWxsIHwgUGF0Y2hBcHBsaWNhdGlvblN0YXRlID0gbnVsbFxuICB0cnkge1xuICAgIHN0YXRlID0gSlNPTi5wYXJzZShyZWFkRmlsZVN5bmMoZmlsZU5hbWUsIFwidXRmOFwiKSlcbiAgfSBjYXRjaCAoZSkge1xuICAgIC8vIG5vb3BcbiAgfVxuICBpZiAoIXN0YXRlKSB7XG4gICAgcmV0dXJuIG51bGxcbiAgfVxuICBpZiAoc3RhdGUudmVyc2lvbiAhPT0gdmVyc2lvbikge1xuICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICBgWW91IHVwZ3JhZGVkIHBhdGNoLXBhY2thZ2UgYW5kIG5lZWQgdG8gZnVsbHkgcmVpbnN0YWxsIG5vZGVfbW9kdWxlcyB0byBjb250aW51ZS5gLFxuICAgIClcbiAgICBwcm9jZXNzLmV4aXQoMSlcbiAgfVxuICByZXR1cm4gc3RhdGVcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNhdmVQYXRjaEFwcGxpY2F0aW9uU3RhdGUoe1xuICBwYWNrYWdlRGV0YWlscyxcbiAgcGF0Y2hlcyxcbiAgaXNSZWJhc2luZyxcbn06IHtcbiAgcGFja2FnZURldGFpbHM6IFBhY2thZ2VEZXRhaWxzXG4gIHBhdGNoZXM6IFBhdGNoU3RhdGVbXVxuICBpc1JlYmFzaW5nOiBib29sZWFuXG59KSB7XG4gIGNvbnN0IGZpbGVOYW1lID0gam9pbihwYWNrYWdlRGV0YWlscy5wYXRoLCBTVEFURV9GSUxFX05BTUUpXG5cbiAgY29uc3Qgc3RhdGU6IFBhdGNoQXBwbGljYXRpb25TdGF0ZSA9IHtcbiAgICBwYXRjaGVzLFxuICAgIHZlcnNpb24sXG4gICAgaXNSZWJhc2luZyxcbiAgfVxuXG4gIHdyaXRlRmlsZVN5bmMoZmlsZU5hbWUsIHN0cmluZ2lmeShzdGF0ZSwgeyBzcGFjZTogNCB9KSwgXCJ1dGY4XCIpXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjbGVhclBhdGNoQXBwbGljYXRpb25TdGF0ZShwYWNrYWdlRGV0YWlsczogUGFja2FnZURldGFpbHMpIHtcbiAgY29uc3QgZmlsZU5hbWUgPSBqb2luKHBhY2thZ2VEZXRhaWxzLnBhdGgsIFNUQVRFX0ZJTEVfTkFNRSlcblxuICB0cnkge1xuICAgIHVubGlua1N5bmMoZmlsZU5hbWUpXG4gIH0gY2F0Y2ggKGUpIHtcbiAgICAvLyBub29wXG4gIH1cbn1cbiJdfQ==
{
"name": "patch-package",
"version": "8.0.0-canary.2",
"version": "8.0.0-canary.3",
"description": "Fix broken node modules with no fuss",

@@ -55,6 +55,7 @@ "main": "dist/index.js",

"@types/jest": "^24.0.11",
"@types/json-stable-stringify": "^1.0.34",
"@types/minimist": "^1.2.2",
"@types/node": "^12.0.0",
"@types/rimraf": "^2.0.2",
"@types/semver": "^7.0.0",
"@types/semver": "^7.5.0",
"@types/tmp": "^0.0.34",

@@ -79,2 +80,3 @@ "husky": "^1.3.1",

"fs-extra": "^9.0.0",
"json-stable-stringify": "^1.0.2",
"klaw-sync": "^6.0.0",

@@ -84,3 +86,3 @@ "minimist": "^1.2.6",

"rimraf": "^2.6.3",
"semver": "^7.0.0",
"semver": "^7.5.3",
"slash": "^2.0.0",

@@ -87,0 +89,0 @@ "tmp": "^0.0.33",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc