Socket
Socket
Sign inDemoInstall

patch-package

Package Overview
Dependencies
48
Maintainers
1
Versions
95
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 7.0.0 to 8.0.0-canary.0

205

dist/applyPatches.js

@@ -8,12 +8,11 @@ "use strict";

const chalk_1 = __importDefault(require("chalk"));
const patchFs_1 = require("./patchFs");
const apply_1 = require("./patch/apply");
const fs_extra_1 = require("fs-extra");
const path_1 = require("./path");
const path_2 = require("path");
const PackageDetails_1 = require("./PackageDetails");
const reverse_1 = require("./patch/reverse");
const path_1 = require("path");
const semver_1 = __importDefault(require("semver"));
const packageIsDevDependency_1 = require("./packageIsDevDependency");
const apply_1 = require("./patch/apply");
const read_1 = require("./patch/read");
const packageIsDevDependency_1 = require("./packageIsDevDependency");
const reverse_1 = require("./patch/reverse");
const patchFs_1 = require("./patchFs");
const path_2 = require("./path");
class PatchApplicationError extends Error {

@@ -24,10 +23,4 @@ constructor(msg) {

}
function findPatchFiles(patchesDirectory) {
if (!fs_extra_1.existsSync(patchesDirectory)) {
return [];
}
return patchFs_1.getPatchFiles(patchesDirectory);
}
function getInstalledPackageVersion({ appPath, path, pathSpecifier, isDevOnly, patchFilename, }) {
const packageDir = path_1.join(appPath, path);
const packageDir = path_2.join(appPath, path);
if (!fs_extra_1.existsSync(packageDir)) {

@@ -37,3 +30,3 @@ if (process.env.NODE_ENV === "production" && isDevOnly) {

}
let err = `${chalk_1.default.red("Error:")} Patch file found for package ${path_2.posix.basename(pathSpecifier)}` + ` which is not present at ${path_1.relative(".", packageDir)}`;
let err = `${chalk_1.default.red("Error:")} Patch file found for package ${path_1.posix.basename(pathSpecifier)}` + ` which is not present at ${path_2.relative(".", packageDir)}`;
if (!isDevOnly && process.env.NODE_ENV === "production") {

@@ -49,7 +42,7 @@ err += `

}
const { version } = require(path_1.join(packageDir, "package.json"));
const { version } = require(path_2.join(packageDir, "package.json"));
// normalize version for `npm ci`
const result = semver_1.default.valid(version);
if (result === null) {
throw new PatchApplicationError(`${chalk_1.default.red("Error:")} Version string '${version}' cannot be parsed from ${path_1.join(packageDir, "package.json")}`);
throw new PatchApplicationError(`${chalk_1.default.red("Error:")} Version string '${version}' cannot be parsed from ${path_2.join(packageDir, "package.json")}`);
}

@@ -59,5 +52,5 @@ return result;

function applyPatchesForApp({ appPath, reverse, patchDir, shouldExitWithError, shouldExitWithWarning, }) {
const patchesDirectory = path_1.join(appPath, patchDir);
const files = findPatchFiles(patchesDirectory);
if (files.length === 0) {
const patchesDirectory = path_2.join(appPath, patchDir);
const groupedPatches = patchFs_1.getGroupedPatches(patchesDirectory);
if (groupedPatches.numPatchFiles === 0) {
console.error(chalk_1.default.blueBright("No patch files found"));

@@ -67,74 +60,92 @@ return;

const errors = [];
const warnings = [];
for (const filename of files) {
try {
const packageDetails = PackageDetails_1.getPackageDetailsFromPatchFilename(filename);
if (!packageDetails) {
warnings.push(`Unrecognized patch file in patches directory ${filename}`);
continue;
}
const { name, version, path, pathSpecifier, isDevOnly, patchFilename, } = packageDetails;
const installedPackageVersion = getInstalledPackageVersion({
appPath,
path,
pathSpecifier,
isDevOnly: isDevOnly ||
// check for direct-dependents in prod
(process.env.NODE_ENV === "production" &&
packageIsDevDependency_1.packageIsDevDependency({ appPath, packageDetails })),
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_1.resolve(patchesDirectory, filename),
reverse,
packageDetails,
patchDir,
})) {
// yay patch was applied successfully
// print warning if version mismatch
if (installedPackageVersion !== version) {
warnings.push(createVersionMismatchWarning({
const warnings = [...groupedPatches.warnings];
for (const [pathSpecifier, details] of Object.entries(groupedPatches.pathSpecifierToPatchFiles)) {
packageLoop: for (const patchDetails of details) {
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(),
})) {
// yay patch was applied successfully
// print warning if version mismatch
if (installedPackageVersion !== version) {
warnings.push(createVersionMismatchWarning({
packageName: name,
actualVersion: installedPackageVersion,
originalVersion: version,
pathSpecifier,
path,
}));
}
const sequenceString = patchDetails.sequenceNumber != null
? ` (${patchDetails.sequenceNumber}${patchDetails.sequenceName
? " " + patchDetails.sequenceName
: ""})`
: "";
console.log(`${chalk_1.default.bold(pathSpecifier)}@${version}${sequenceString} ${chalk_1.default.green("✔")}`);
}
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,
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;
}
console.log(`${chalk_1.default.bold(pathSpecifier)}@${version} ${chalk_1.default.green("✔")}`);
}
else if (installedPackageVersion === version) {
// completely failed to apply patch
// TODO: propagate useful error messages from patch application
errors.push(createBrokenPatchFileError({
packageName: name,
patchFileName: filename,
pathSpecifier,
path,
}));
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;
}
else {
errors.push(createPatchApplictionFailureError({
packageName: name,
actualVersion: installedPackageVersion,
originalVersion: version,
patchFileName: filename,
path,
pathSpecifier,
}));
}
}
catch (error) {
if (error instanceof PatchApplicationError) {
errors.push(error.message);
}
else {
errors.push(createUnexpectedError({ filename, error }));
}
}
}

@@ -167,10 +178,20 @@ for (const warning of warnings) {

exports.applyPatchesForApp = applyPatchesForApp;
function applyPatch({ patchFilePath, reverse, packageDetails, patchDir, }) {
const patch = read_1.readPatch({ patchFilePath, packageDetails, patchDir });
function applyPatch({ patchFilePath, reverse, patchDetails, patchDir, cwd, }) {
const patch = read_1.readPatch({
patchFilePath,
patchDetails,
patchDir,
});
try {
apply_1.executeEffects(reverse ? reverse_1.reversePatch(patch) : patch, { dryRun: false });
apply_1.executeEffects(reverse ? reverse_1.reversePatch(patch) : patch, {
dryRun: false,
cwd,
});
}
catch (e) {
try {
apply_1.executeEffects(reverse ? patch : reverse_1.reversePatch(patch), { dryRun: true });
apply_1.executeEffects(reverse ? patch : reverse_1.reversePatch(patch), {
dryRun: true,
cwd,
});
}

@@ -212,3 +233,3 @@ catch (e) {

}
function createBrokenPatchFileError({ packageName, patchFileName, path, pathSpecifier, }) {
function createBrokenPatchFileError({ packageName, patchFilename, path, pathSpecifier, }) {
return `

@@ -221,3 +242,3 @@ ${chalk_1.default.red.bold("**ERROR**")} ${chalk_1.default.red(`Failed to apply patch for package ${chalk_1.default.bold(packageName)} at path`)}

patches/${patchFileName}
patches/${patchFilename}

@@ -237,3 +258,3 @@ Try removing node_modules and trying again. If that doesn't work, maybe there was

}
function createPatchApplictionFailureError({ packageName, actualVersion, originalVersion, patchFileName, path, pathSpecifier, }) {
function createPatchApplicationFailureError({ packageName, actualVersion, originalVersion, patchFilename, path, pathSpecifier, }) {
return `

@@ -262,3 +283,3 @@ ${chalk_1.default.red.bold("**ERROR**")} ${chalk_1.default.red(`Failed to apply patch for package ${chalk_1.default.bold(packageName)} at path`)}

Info:
Patch file: patches/${patchFileName}
Patch file: patches/${patchFilename}
Patch was made for version: ${chalk_1.default.green.bold(originalVersion)}

@@ -276,2 +297,2 @@ Installed version: ${chalk_1.default.red.bold(actualVersion)}

}
//# 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 { getPatchFiles } from \"./patchFs\"\nimport { executeEffects } from \"./patch/apply\"\nimport { existsSync } from \"fs-extra\"\nimport { join, resolve, relative } from \"./path\"\nimport { posix } from \"path\"\nimport {\n  getPackageDetailsFromPatchFilename,\n  PackageDetails,\n} from \"./PackageDetails\"\nimport { reversePatch } from \"./patch/reverse\"\nimport semver from \"semver\"\nimport { readPatch } from \"./patch/read\"\nimport { packageIsDevDependency } from \"./packageIsDevDependency\"\n\nclass PatchApplicationError extends Error {\n  constructor(msg: string) {\n    super(msg)\n  }\n}\n\nfunction findPatchFiles(patchesDirectory: string): string[] {\n  if (!existsSync(patchesDirectory)) {\n    return []\n  }\n\n  return getPatchFiles(patchesDirectory) as string[]\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\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 files = findPatchFiles(patchesDirectory)\n\n  if (files.length === 0) {\n    console.error(chalk.blueBright(\"No patch files found\"))\n    return\n  }\n\n  const errors: string[] = []\n  const warnings: string[] = []\n\n  for (const filename of files) {\n    try {\n      const packageDetails = getPackageDetailsFromPatchFilename(filename)\n\n      if (!packageDetails) {\n        warnings.push(\n          `Unrecognized patch file in patches directory ${filename}`,\n        )\n        continue\n      }\n\n      const {\n        name,\n        version,\n        path,\n        pathSpecifier,\n        isDevOnly,\n        patchFilename,\n      } = packageDetails\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({ appPath, packageDetails })),\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, filename) as string,\n          reverse,\n          packageDetails,\n          patchDir,\n        })\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        console.log(\n          `${chalk.bold(pathSpecifier)}@${version} ${chalk.green(\"✔\")}`,\n        )\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: filename,\n            pathSpecifier,\n            path,\n          }),\n        )\n      } else {\n        errors.push(\n          createPatchApplictionFailureError({\n            packageName: name,\n            actualVersion: installedPackageVersion,\n            originalVersion: version,\n            patchFileName: filename,\n            path,\n            pathSpecifier,\n          }),\n        )\n      }\n    } catch (error) {\n      if (error instanceof PatchApplicationError) {\n        errors.push(error.message)\n      } else {\n        errors.push(createUnexpectedError({ filename, error }))\n      }\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  packageDetails,\n  patchDir,\n}: {\n  patchFilePath: string\n  reverse: boolean\n  packageDetails: PackageDetails\n  patchDir: string\n}): boolean {\n  const patch = readPatch({ patchFilePath, packageDetails, patchDir })\n  try {\n    executeEffects(reverse ? reversePatch(patch) : patch, { dryRun: false })\n  } catch (e) {\n    try {\n      executeEffects(reverse ? patch : reversePatch(patch), { dryRun: true })\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 createPatchApplictionFailureError({\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":";;;;;;AAAA,kDAAyB;AACzB,uCAAqC;AACrC,+BAA4B;AAC5B,oDAA2B;AAE3B,qEAAiE;AACjE,yCAA8C;AAC9C,uCAAwC;AACxC,6CAA8C;AAC9C,uCAA6C;AAC7C,iCAAgD;AAEhD,MAAM,qBAAsB,SAAQ,KAAK;IACvC,YAAY,GAAW;QACrB,KAAK,CAAC,GAAG,CAAC,CAAA;IACZ,CAAC;CACF;AAED,SAAS,0BAA0B,CAAC,EAClC,OAAO,EACP,IAAI,EACJ,aAAa,EACb,SAAS,EACT,aAAa,GAOd;IACC,MAAM,UAAU,GAAG,WAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;IACtC,IAAI,CAAC,qBAAU,CAAC,UAAU,CAAC,EAAE;QAC3B,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,IAAI,SAAS,EAAE;YACtD,OAAO,IAAI,CAAA;SACZ;QAED,IAAI,GAAG,GACL,GAAG,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,iCAAiC,YAAK,CAAC,QAAQ,CACnE,aAAa,CACd,EAAE,GAAG,4BAA4B,eAAQ,CAAC,GAAG,EAAE,UAAU,CAAC,EAAE,CAAA;QAE/D,IAAI,CAAC,SAAS,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,EAAE;YACvD,GAAG,IAAI;;;;MAIP,eAAK,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;CAC9D,CAAA;SACI;QACD,MAAM,IAAI,qBAAqB,CAAC,GAAG,CAAC,CAAA;KACrC;IAED,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAI,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC,CAAA;IAC7D,iCAAiC;IACjC,MAAM,MAAM,GAAG,gBAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;IACpC,IAAI,MAAM,KAAK,IAAI,EAAE;QACnB,MAAM,IAAI,qBAAqB,CAC7B,GAAG,eAAK,CAAC,GAAG,CACV,QAAQ,CACT,oBAAoB,OAAO,2BAA2B,WAAI,CACzD,UAAU,EACV,cAAc,CACf,EAAE,CACJ,CAAA;KACF;IAED,OAAO,MAAgB,CAAA;AACzB,CAAC;AAED,SAAgB,kBAAkB,CAAC,EACjC,OAAO,EACP,OAAO,EACP,QAAQ,EACR,mBAAmB,EACnB,qBAAqB,GAOtB;IACC,MAAM,gBAAgB,GAAG,WAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAChD,MAAM,cAAc,GAAG,2BAAiB,CAAC,gBAAgB,CAAC,CAAA;IAE1D,IAAI,cAAc,CAAC,aAAa,KAAK,CAAC,EAAE;QACtC,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC,CAAA;QACvD,OAAM;KACP;IAED,MAAM,MAAM,GAAa,EAAE,CAAA;IAC3B,MAAM,QAAQ,GAAa,CAAC,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAA;IAEvD,KAAK,MAAM,CAAC,aAAa,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CACnD,cAAc,CAAC,yBAAyB,CACzC,EAAE;QACD,WAAW,EAAE,KAAK,MAAM,YAAY,IAAI,OAAO,EAAE;YAC/C,IAAI;gBACF,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,YAAY,CAAA;gBAEtE,MAAM,uBAAuB,GAAG,0BAA0B,CAAC;oBACzD,OAAO;oBACP,IAAI;oBACJ,aAAa;oBACb,SAAS,EACP,SAAS;wBACT,sCAAsC;wBACtC,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY;4BACpC,+CAAsB,CAAC;gCACrB,OAAO;gCACP,YAAY;6BACb,CAAC,CAAC;oBACP,aAAa;iBACd,CAAC,CAAA;gBACF,IAAI,CAAC,uBAAuB,EAAE;oBAC5B,kEAAkE;oBAClE,OAAO,CAAC,GAAG,CACT,qBAAqB,eAAK,CAAC,IAAI,CAC7B,aAAa,CACd,IAAI,OAAO,IAAI,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAClC,CAAA;oBACD,SAAQ;iBACT;gBAED,IACE,UAAU,CAAC;oBACT,aAAa,EAAE,cAAO,CAAC,gBAAgB,EAAE,aAAa,CAAW;oBACjE,OAAO;oBACP,YAAY;oBACZ,QAAQ;oBACR,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE;iBACnB,CAAC,EACF;oBACA,qCAAqC;oBACrC,oCAAoC;oBACpC,IAAI,uBAAuB,KAAK,OAAO,EAAE;wBACvC,QAAQ,CAAC,IAAI,CACX,4BAA4B,CAAC;4BAC3B,WAAW,EAAE,IAAI;4BACjB,aAAa,EAAE,uBAAuB;4BACtC,eAAe,EAAE,OAAO;4BACxB,aAAa;4BACb,IAAI;yBACL,CAAC,CACH,CAAA;qBACF;oBACD,MAAM,cAAc,GAClB,YAAY,CAAC,cAAc,IAAI,IAAI;wBACjC,CAAC,CAAC,KAAK,YAAY,CAAC,cAAc,GAC9B,YAAY,CAAC,YAAY;4BACvB,CAAC,CAAC,GAAG,GAAG,YAAY,CAAC,YAAY;4BACjC,CAAC,CAAC,EACN,GAAG;wBACL,CAAC,CAAC,EAAE,CAAA;oBACR,OAAO,CAAC,GAAG,CACT,GAAG,eAAK,CAAC,IAAI,CACX,aAAa,CACd,IAAI,OAAO,GAAG,cAAc,IAAI,eAAK,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CACpD,CAAA;iBACF;qBAAM,IAAI,uBAAuB,KAAK,OAAO,EAAE;oBAC9C,mCAAmC;oBACnC,+DAA+D;oBAC/D,MAAM,CAAC,IAAI,CACT,0BAA0B,CAAC;wBACzB,WAAW,EAAE,IAAI;wBACjB,aAAa;wBACb,aAAa;wBACb,IAAI;qBACL,CAAC,CACH,CAAA;oBACD,oFAAoF;oBACpF,yEAAyE;oBACzE,MAAM,WAAW,CAAA;iBAClB;qBAAM;oBACL,MAAM,CAAC,IAAI,CACT,kCAAkC,CAAC;wBACjC,WAAW,EAAE,IAAI;wBACjB,aAAa,EAAE,uBAAuB;wBACtC,eAAe,EAAE,OAAO;wBACxB,aAAa;wBACb,IAAI;wBACJ,aAAa;qBACd,CAAC,CACH,CAAA;oBACD,oFAAoF;oBACpF,yEAAyE;oBACzE,MAAM,WAAW,CAAA;iBAClB;aACF;YAAC,OAAO,KAAK,EAAE;gBACd,IAAI,KAAK,YAAY,qBAAqB,EAAE;oBAC1C,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;iBAC3B;qBAAM;oBACL,MAAM,CAAC,IAAI,CACT,qBAAqB,CAAC;wBACpB,QAAQ,EAAE,YAAY,CAAC,aAAa;wBACpC,KAAK,EAAE,KAAc;qBACtB,CAAC,CACH,CAAA;iBACF;gBACD,oFAAoF;gBACpF,yEAAyE;gBACzE,MAAM,WAAW,CAAA;aAClB;SACF;KACF;IAED,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;QAC9B,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;KACtB;IACD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;KACrB;IAED,MAAM,eAAe,GAAG,EAAE,CAAA;IAC1B,IAAI,QAAQ,CAAC,MAAM,EAAE;QACnB,eAAe,CAAC,IAAI,CAAC,eAAK,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC,MAAM,aAAa,CAAC,CAAC,CAAA;KACpE;IACD,IAAI,MAAM,CAAC,MAAM,EAAE;QACjB,eAAe,CAAC,IAAI,CAAC,eAAK,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,WAAW,CAAC,CAAC,CAAA;KAC7D;IAED,IAAI,eAAe,CAAC,MAAM,EAAE;QAC1B,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpB,OAAO,CAAC,KAAK,CACX,6BAA6B,EAC7B,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,CACjC,CAAA;KACF;IAED,IAAI,MAAM,CAAC,MAAM,IAAI,mBAAmB,EAAE;QACxC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;KAChB;IAED,IAAI,QAAQ,CAAC,MAAM,IAAI,qBAAqB,EAAE;QAC5C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;KAChB;IAED,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;AACjB,CAAC;AAzKD,gDAyKC;AAED,SAAgB,UAAU,CAAC,EACzB,aAAa,EACb,OAAO,EACP,YAAY,EACZ,QAAQ,EACR,GAAG,GAOJ;IACC,MAAM,KAAK,GAAG,gBAAS,CAAC;QACtB,aAAa;QACb,YAAY;QACZ,QAAQ;KACT,CAAC,CAAA;IACF,IAAI;QACF,sBAAc,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE;YACpD,MAAM,EAAE,KAAK;YACb,GAAG;SACJ,CAAC,CAAA;KACH;IAAC,OAAO,CAAC,EAAE;QACV,IAAI;YACF,sBAAc,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,sBAAY,CAAC,KAAK,CAAC,EAAE;gBACpD,MAAM,EAAE,IAAI;gBACZ,GAAG;aACJ,CAAC,CAAA;SACH;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAA;SACb;KACF;IAED,OAAO,IAAI,CAAA;AACb,CAAC;AAnCD,gCAmCC;AAED,SAAS,4BAA4B,CAAC,EACpC,WAAW,EACX,aAAa,EACb,eAAe,EACf,aAAa,EACb,IAAI,GAOL;IACC,OAAO;EACP,eAAK,CAAC,MAAM,CAAC,UAAU,CAAC;;;;;;;MAOpB,WAAW,IAAI,eAAK,CAAC,IAAI,CAAC,eAAe,CAAC;;;;MAI1C,WAAW,IAAI,eAAK,CAAC,IAAI,CAAC,aAAa,CAAC;;;;MAIxC,IAAI;;;;;;MAMJ,eAAK,CAAC,IAAI,CAAC,iBAAiB,aAAa,EAAE,CAAC;;;CAGjD,CAAA;AACD,CAAC;AAED,SAAS,0BAA0B,CAAC,EAClC,WAAW,EACX,aAAa,EACb,IAAI,EACJ,aAAa,GAMd;IACC,OAAO;EACP,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,eAAK,CAAC,GAAG,CACtC,qCAAqC,eAAK,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CACvE;;MAEG,IAAI;;;;cAII,aAAa;;;;;;oBAMP,aAAa;;;;;;;CAOhC,CAAA;AACD,CAAC;AAED,SAAS,kCAAkC,CAAC,EAC1C,WAAW,EACX,aAAa,EACb,eAAe,EACf,aAAa,EACb,IAAI,EACJ,aAAa,GAQd;IACC,OAAO;EACP,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,eAAK,CAAC,GAAG,CACtC,qCAAqC,eAAK,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CACvE;;MAEG,IAAI;;kCAEwB,eAAK,CAAC,IAAI,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;oBAerC,aAAa;;;0BAGP,aAAa;kCACL,eAAK,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;yBAC1C,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC;CACrD,CAAA;AACD,CAAC;AAED,SAAS,qBAAqB,CAAC,EAC7B,QAAQ,EACR,KAAK,GAIN;IACC,OAAO;EACP,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,eAAK,CAAC,GAAG,CACtC,8BAA8B,eAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CACrD;;EAED,KAAK,CAAC,KAAK;;GAEV,CAAA;AACH,CAAC","sourcesContent":["import chalk from \"chalk\"\nimport { existsSync } from \"fs-extra\"\nimport { posix } from \"path\"\nimport semver from \"semver\"\nimport { PackageDetails } 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\"\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\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, details] of Object.entries(\n    groupedPatches.pathSpecifierToPatchFiles,\n  )) {\n    packageLoop: for (const patchDetails of details) {\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          // 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          const sequenceString =\n            patchDetails.sequenceNumber != null\n              ? ` (${patchDetails.sequenceNumber}${\n                  patchDetails.sequenceName\n                    ? \" \" + patchDetails.sequenceName\n                    : \"\"\n                })`\n              : \"\"\n          console.log(\n            `${chalk.bold(\n              pathSpecifier,\n            )}@${version}${sequenceString} ${chalk.green(\"✔\")}`,\n          )\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\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"]}

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

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

@@ -62,2 +62,5 @@ const packageNames = argv._;

createIssue,
mode: "append" in argv
? { type: "append", name: argv.append || undefined }
: { type: "overwrite_last" },
});

@@ -180,2 +183,2 @@ });

}
//# 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\"],\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      })\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\"\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"]}

@@ -8,17 +8,18 @@ "use strict";

const chalk_1 = __importDefault(require("chalk"));
const path_1 = require("./path");
const spawnSafe_1 = require("./spawnSafe");
const filterFiles_1 = require("./filterFiles");
const fs_1 = require("fs");
const fs_extra_1 = require("fs-extra");
const rimraf_1 = require("rimraf");
const fs_extra_2 = require("fs-extra");
const tmp_1 = require("tmp");
const zlib_1 = require("zlib");
const applyPatches_1 = require("./applyPatches");
const createIssue_1 = require("./createIssue");
const filterFiles_1 = require("./filterFiles");
const getPackageResolution_1 = require("./getPackageResolution");
const getPackageVersion_1 = require("./getPackageVersion");
const PackageDetails_1 = require("./PackageDetails");
const parse_1 = require("./patch/parse");
const patchFs_1 = require("./patchFs");
const PackageDetails_1 = require("./PackageDetails");
const path_1 = require("./path");
const resolveRelativeFileDependencies_1 = require("./resolveRelativeFileDependencies");
const getPackageResolution_1 = require("./getPackageResolution");
const parse_1 = require("./patch/parse");
const zlib_1 = require("zlib");
const getPackageVersion_1 = require("./getPackageVersion");
const createIssue_1 = require("./createIssue");
const spawnSafe_1 = require("./spawnSafe");
function printNoPackageFoundError(packageName, packageJsonPath) {

@@ -29,3 +30,4 @@ console.error(`No such package ${packageName}

}
function makePatch({ packagePathSpecifier, appPath, packageManager, includePaths, excludePaths, patchDir, createIssue, }) {
function makePatch({ packagePathSpecifier, appPath, packageManager, includePaths, excludePaths, patchDir, createIssue, mode, }) {
var _a, _b, _c;
const packageDetails = PackageDetails_1.getPatchDetailsFromCliString(packagePathSpecifier);

@@ -36,2 +38,3 @@ if (!packageDetails) {

}
const existingPatches = patchFs_1.getGroupedPatches(patchDir).pathSpecifierToPatchFiles[packageDetails.pathSpecifier] || [];
const appPackageJson = require(path_1.join(appPath, "package.json"));

@@ -67,3 +70,3 @@ const packagePath = path_1.join(appPath, packageDetails.path);

if (fs_extra_1.existsSync(rcPath)) {
fs_extra_2.copySync(rcPath, path_1.join(tmpRepo.name, rcFile), { dereference: true });
fs_extra_1.copySync(rcPath, path_1.join(tmpRepo.name, rcFile), { dereference: true });
}

@@ -126,2 +129,17 @@ });

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) {
if (!applyPatches_1.applyPatch({
patchDetails,
patchDir,
patchFilePath: path_1.join(appPath, patchDir, patchDetails.patchFilename),
reverse: false,
cwd: tmpRepo.name,
})) {
console.error(`Failed to apply patch ${patchDetails.patchFilename} to ${packageDetails.pathSpecifier}`);
process.exit(1);
}
}
git("add", "-f", packageDetails.path);

@@ -132,3 +150,3 @@ git("commit", "--allow-empty", "-m", "init");

// pnpm installs packages as symlinks, copySync would copy only the symlink
fs_extra_2.copySync(fs_extra_1.realpathSync(packagePath), tmpRepoPackagePath);
fs_extra_1.copySync(fs_extra_1.realpathSync(packagePath), tmpRepoPackagePath);
// remove nested node_modules just to be safe

@@ -194,11 +212,42 @@ rimraf_1.sync(path_1.join(tmpRepoPackagePath, "node_modules"));

// maybe delete existing
patchFs_1.getPatchFiles(patchDir).forEach((filename) => {
const deets = PackageDetails_1.getPackageDetailsFromPatchFilename(filename);
if (deets && deets.path === packageDetails.path) {
fs_extra_1.unlinkSync(path_1.join(patchDir, filename));
if (mode.type === "overwrite_last") {
const prevPatch = existingPatches[existingPatches.length - 1];
if (prevPatch) {
const patchFilePath = path_1.join(appPath, patchDir, prevPatch.patchFilename);
try {
fs_extra_1.unlinkSync(patchFilePath);
}
catch (e) {
// noop
}
}
});
}
else if (existingPatches.length === 1) {
// if we are appending to an existing patch that doesn't have a sequence number let's rename it
const prevPatch = existingPatches[0];
if (prevPatch.sequenceNumber === undefined) {
const newFileName = createPatchFileName({
packageDetails,
packageVersion,
sequenceNumber: 1,
sequenceName: (_a = prevPatch.sequenceName) !== null && _a !== void 0 ? _a : "initial",
});
const oldPath = path_1.join(appPath, patchDir, prevPatch.patchFilename);
const newPath = path_1.join(appPath, patchDir, newFileName);
fs_1.renameSync(oldPath, newPath);
prevPatch.sequenceNumber = 1;
prevPatch.patchFilename = newFileName;
prevPatch.sequenceName = (_b = prevPatch.sequenceName) !== null && _b !== void 0 ? _b : "initial";
}
}
const lastPatch = existingPatches[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
: lastPatch === null || lastPatch === void 0 ? void 0 : lastPatch.sequenceNumber;
const patchFileName = createPatchFileName({
packageDetails,
packageVersion,
sequenceName,
sequenceNumber,
});

@@ -232,8 +281,13 @@ const patchPath = path_1.join(patchesDir, patchFileName);

exports.makePatch = makePatch;
function createPatchFileName({ packageDetails, packageVersion, }) {
function createPatchFileName({ packageDetails, packageVersion, sequenceNumber, sequenceName, }) {
const packageNames = packageDetails.packageNames
.map((name) => name.replace(/\//g, "+"))
.join("++");
return `${packageNames}+${packageVersion}.patch`;
const nameAndVersion = `${packageNames}+${packageVersion}`;
const num = sequenceNumber === undefined
? ""
: `+${sequenceNumber.toString().padStart(3, "0")}`;
const name = !sequenceName ? "" : `+${sequenceName}`;
return `${nameAndVersion}${num}${name}.patch`;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"makePatch.js","sourceRoot":"","sources":["../src/makePatch.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAyB;AACzB,iCAA+C;AAC/C,2CAA2C;AAE3C,+CAAkD;AAClD,uCAOiB;AACjB,mCAAuC;AACvC,uCAAmC;AACnC,6BAA6B;AAC7B,uCAAyC;AACzC,qDAIyB;AACzB,uFAAmF;AACnF,iEAA6D;AAC7D,yCAA8C;AAC9C,+BAA+B;AAC/B,2DAAuD;AACvD,+CAGsB;AAEtB,SAAS,wBAAwB,CAC/B,WAAmB,EACnB,eAAuB;IAEvB,OAAO,CAAC,KAAK,CACX,mBAAmB,WAAW;;oBAEd,eAAe,EAAE,CAClC,CAAA;AACH,CAAC;AAED,SAAgB,SAAS,CAAC,EACxB,oBAAoB,EACpB,OAAO,EACP,cAAc,EACd,YAAY,EACZ,YAAY,EACZ,QAAQ,EACR,WAAW,GASZ;IACC,MAAM,cAAc,GAAG,6CAA4B,CAAC,oBAAoB,CAAC,CAAA;IAEzE,IAAI,CAAC,cAAc,EAAE;QACnB,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,CAAA;QACtD,OAAM;KACP;IACD,MAAM,cAAc,GAAG,OAAO,CAAC,WAAI,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAA;IAC7D,MAAM,WAAW,GAAG,WAAI,CAAC,OAAO,EAAE,cAAc,CAAC,IAAI,CAAC,CAAA;IACtD,MAAM,eAAe,GAAG,WAAI,CAAC,WAAW,EAAE,cAAc,CAAC,CAAA;IAEzD,IAAI,CAAC,qBAAU,CAAC,eAAe,CAAC,EAAE;QAChC,wBAAwB,CAAC,oBAAoB,EAAE,eAAe,CAAC,CAAA;QAC/D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;KAChB;IAED,MAAM,OAAO,GAAG,aAAO,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAA;IAChD,MAAM,kBAAkB,GAAG,WAAI,CAAC,OAAO,CAAC,IAAI,EAAE,cAAc,CAAC,IAAI,CAAC,CAAA;IAClE,MAAM,cAAc,GAAG,kBAAkB,CAAC,KAAK,CAC7C,CAAC,EACD,CAAC,iBAAiB,cAAc,CAAC,IAAI,EAAE,CAAC,MAAM,CAC/C,CAAA;IAED,MAAM,sBAAsB,GAAG,WAAI,CAAC,cAAc,EAAE,cAAc,CAAC,CAAA;IAEnE,IAAI;QACF,MAAM,UAAU,GAAG,cAAO,CAAC,WAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAA;QAEnD,OAAO,CAAC,IAAI,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,2BAA2B,CAAC,CAAA;QAE1D,4BAA4B;QAC5B,qBAAU,CAAC,cAAc,CAAC,CAAA;QAC1B,wBAAa,CACX,sBAAsB,EACtB,IAAI,CAAC,SAAS,CAAC;YACb,YAAY,EAAE;gBACZ,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,2CAAoB,CAAC;oBAC1C,cAAc;oBACd,cAAc;oBACd,OAAO;iBACR,CAAC;aACH;YACD,WAAW,EAAE,iEAA+B,CAC1C,OAAO,EACP,cAAc,CAAC,WAAW,IAAI,EAAE,CACjC;SACF,CAAC,CACH,CAAA;QAED,MAAM,cAAc,GAAG,qCAAiB,CACtC,WAAI,CAAC,cAAO,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,cAAc,CAAC,CACnD,CAKE;QAAA,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACjD,MAAM,MAAM,GAAG,WAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;YACpC,IAAI,qBAAU,CAAC,MAAM,CAAC,EAAE;gBACtB,mBAAQ,CAAC,MAAM,EAAE,WAAI,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;aACpE;QACH,CAAC,CAAC,CAAA;QAEJ,IAAI,cAAc,KAAK,MAAM,EAAE;YAC7B,OAAO,CAAC,IAAI,CACV,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EACf,cAAc,cAAc,CAAC,IAAI,IAAI,cAAc,YAAY,CAChE,CAAA;YACD,IAAI;gBACF,+DAA+D;gBAC/D,gCAAgC;gBAChC,yBAAa,CAAC,MAAM,EAAE,CAAC,SAAS,EAAE,kBAAkB,CAAC,EAAE;oBACrD,GAAG,EAAE,cAAc;oBACnB,gBAAgB,EAAE,KAAK;iBACxB,CAAC,CAAA;aACH;YAAC,OAAO,CAAC,EAAE;gBACV,iEAAiE;gBACjE,iDAAiD;gBACjD,yBAAa,CACX,MAAM,EACN,CAAC,SAAS,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,EACnD;oBACE,GAAG,EAAE,cAAc;iBACpB,CACF,CAAA;aACF;SACF;aAAM;YACL,OAAO,CAAC,IAAI,CACV,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EACf,cAAc,cAAc,CAAC,IAAI,IAAI,cAAc,WAAW,CAC/D,CAAA;YACD,IAAI;gBACF,+DAA+D;gBAC/D,gCAAgC;gBAChC,yBAAa,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,SAAS,CAAC,EAAE;oBACrC,GAAG,EAAE,cAAc;oBACnB,gBAAgB,EAAE,KAAK;oBACvB,KAAK,EAAE,QAAQ;iBAChB,CAAC,CAAA;aACH;YAAC,OAAO,CAAC,EAAE;gBACV,iEAAiE;gBACjE,iDAAiD;gBACjD,yBAAa,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,kBAAkB,EAAE,SAAS,CAAC,EAAE;oBACzD,GAAG,EAAE,cAAc;oBACnB,KAAK,EAAE,QAAQ;iBAChB,CAAC,CAAA;aACH;SACF;QAED,MAAM,GAAG,GAAG,CAAC,GAAG,IAAc,EAAE,EAAE,CAChC,yBAAa,CAAC,KAAK,EAAE,IAAI,EAAE;YACzB,GAAG,EAAE,OAAO,CAAC,IAAI;YACjB,GAAG,kCAAO,OAAO,CAAC,GAAG,KAAE,IAAI,EAAE,OAAO,CAAC,IAAI,GAAE;YAC3C,SAAS,EAAE,IAAI,GAAG,IAAI,GAAG,GAAG;SAC7B,CAAC,CAAA;QAEJ,6CAA6C;QAC7C,aAAM,CAAC,WAAI,CAAC,kBAAkB,EAAE,cAAc,CAAC,CAAC,CAAA;QAChD,8BAA8B;QAC9B,aAAM,CAAC,WAAI,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC,CAAA;QAExC,qBAAqB;QACrB,OAAO,CAAC,IAAI,CAAC,eAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,qCAAqC,CAAC,CAAA;QACpE,wBAAa,CAAC,WAAI,CAAC,OAAO,CAAC,IAAI,EAAE,YAAY,CAAC,EAAE,oBAAoB,CAAC,CAAA;QACrE,GAAG,CAAC,MAAM,CAAC,CAAA;QACX,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,eAAe,CAAC,CAAA;QACtD,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAE,gBAAgB,CAAC,CAAA;QAExD,6BAA6B;QAC7B,gCAAkB,CAAC,kBAAkB,EAAE,YAAY,EAAE,YAAY,CAAC,CAAA;QAElE,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,cAAc,CAAC,IAAI,CAAC,CAAA;QACrC,GAAG,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,CAAC,CAAA;QAE5C,sCAAsC;QACtC,aAAM,CAAC,kBAAkB,CAAC,CAAA;QAE1B,2EAA2E;QAC3E,mBAAQ,CAAC,uBAAY,CAAC,WAAW,CAAC,EAAE,kBAAkB,CAAC,CAAA;QAEvD,6CAA6C;QAC7C,aAAM,CAAC,WAAI,CAAC,kBAAkB,EAAE,cAAc,CAAC,CAAC,CAAA;QAChD,8BAA8B;QAC9B,aAAM,CAAC,WAAI,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC,CAAA;QAExC,wCAAwC;QACxC,gCAAkB,CAAC,kBAAkB,EAAE,YAAY,EAAE,YAAY,CAAC,CAAA;QAElE,kBAAkB;QAClB,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,cAAc,CAAC,IAAI,CAAC,CAAA;QAErC,sBAAsB;QACtB,MAAM,UAAU,GAAG,GAAG,CACpB,MAAM,EACN,UAAU,EACV,YAAY,EACZ,uBAAuB,EACvB,eAAe,EACf,iBAAiB,EACjB,iBAAiB,CAClB,CAAA;QAED,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;YAClC,OAAO,CAAC,IAAI,CACV,4CAA4C,oBAAoB,GAAG,CACpE,CAAA;YACD,OAAO,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAA;YACzD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACf,OAAM;SACP;QAED,IAAI;YACF,sBAAc,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAA;SAC7C;QAAC,OAAO,CAAC,EAAE;YACV,IACG,CAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,qCAAqC,CAAC,EACpE;gBACA,OAAO,CAAC,KAAK,CAAC;KACjB,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;gBAKZ,eAAK,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,eAAK,CAAC,IAAI,CAClD,WAAW,CACZ;;CAER,CAAC,CAAA;aACK;iBAAM;gBACL,MAAM,OAAO,GAAG,+BAA+B,CAAA;gBAC/C,wBAAa,CACX,OAAO,EACP,eAAQ,CACN,IAAI,CAAC,SAAS,CAAC;oBACb,KAAK,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE;oBAC7C,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,QAAQ,EAAE;iBACpC,CAAC,CACH,CACF,CAAA;gBACD,OAAO,CAAC,KAAK,CAAC;KACjB,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;;;MAOtB,OAAO;;;;;;;;;CASZ,CAAC,CAAA;aACK;YACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACf,OAAM;SACP;QAED,wBAAwB;QACxB,uBAAa,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC3C,MAAM,KAAK,GAAG,mDAAkC,CAAC,QAAQ,CAAC,CAAA;YAC1D,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,KAAK,cAAc,CAAC,IAAI,EAAE;gBAC/C,qBAAU,CAAC,WAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAA;aACrC;QACH,CAAC,CAAC,CAAA;QAEF,MAAM,aAAa,GAAG,mBAAmB,CAAC;YACxC,cAAc;YACd,cAAc;SACf,CAAC,CAAA;QAEF,MAAM,SAAS,GAAG,WAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAA;QACjD,IAAI,CAAC,qBAAU,CAAC,cAAO,CAAC,SAAS,CAAC,CAAC,EAAE;YACnC,iBAAiB;YACjB,oBAAS,CAAC,cAAO,CAAC,SAAS,CAAC,CAAC,CAAA;SAC9B;QACD,wBAAa,CAAC,SAAS,EAAE,UAAU,CAAC,MAAM,CAAC,CAAA;QAC3C,OAAO,CAAC,GAAG,CACT,GAAG,eAAK,CAAC,KAAK,CAAC,GAAG,CAAC,iBAAiB,WAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,IAAI,CACtE,CAAA;QACD,IAAI,WAAW,EAAE;YACf,mCAAqB,CAAC;gBACpB,cAAc;gBACd,iBAAiB,EAAE,UAAU,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC/C,cAAc;aACf,CAAC,CAAA;SACH;aAAM;YACL,2CAA6B,CAAC,cAAc,EAAE,cAAc,CAAC,CAAA;SAC9D;KACF;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QAChB,MAAM,CAAC,CAAA;KACR;YAAS;QACR,OAAO,CAAC,cAAc,EAAE,CAAA;KACzB;AACH,CAAC;AAnRD,8BAmRC;AAED,SAAS,mBAAmB,CAAC,EAC3B,cAAc,EACd,cAAc,GAIf;IACC,MAAM,YAAY,GAAG,cAAc,CAAC,YAAY;SAC7C,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACvC,IAAI,CAAC,IAAI,CAAC,CAAA;IAEb,OAAO,GAAG,YAAY,IAAI,cAAc,QAAQ,CAAA;AAClD,CAAC","sourcesContent":["import chalk from \"chalk\"\nimport { join, dirname, resolve } from \"./path\"\nimport { spawnSafeSync } from \"./spawnSafe\"\nimport { PackageManager } from \"./detectPackageManager\"\nimport { removeIgnoredFiles } from \"./filterFiles\"\nimport {\n  writeFileSync,\n  existsSync,\n  mkdirSync,\n  unlinkSync,\n  mkdirpSync,\n  realpathSync,\n} from \"fs-extra\"\nimport { sync as rimraf } from \"rimraf\"\nimport { copySync } from \"fs-extra\"\nimport { dirSync } from \"tmp\"\nimport { getPatchFiles } from \"./patchFs\"\nimport {\n  getPatchDetailsFromCliString,\n  getPackageDetailsFromPatchFilename,\n  PackageDetails,\n} from \"./PackageDetails\"\nimport { resolveRelativeFileDependencies } from \"./resolveRelativeFileDependencies\"\nimport { getPackageResolution } from \"./getPackageResolution\"\nimport { parsePatchFile } from \"./patch/parse\"\nimport { gzipSync } from \"zlib\"\nimport { getPackageVersion } from \"./getPackageVersion\"\nimport {\n  maybePrintIssueCreationPrompt,\n  openIssueCreationLink,\n} from \"./createIssue\"\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}: {\n  packagePathSpecifier: string\n  appPath: string\n  packageManager: PackageManager\n  includePaths: RegExp\n  excludePaths: RegExp\n  patchDir: string\n  createIssue: boolean\n}) {\n  const packageDetails = getPatchDetailsFromCliString(packagePathSpecifier)\n\n  if (!packageDetails) {\n    console.error(\"No such package\", packagePathSpecifier)\n    return\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\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    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\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    getPatchFiles(patchDir).forEach((filename) => {\n      const deets = getPackageDetailsFromPatchFilename(filename)\n      if (deets && deets.path === packageDetails.path) {\n        unlinkSync(join(patchDir, filename))\n      }\n    })\n\n    const patchFileName = createPatchFileName({\n      packageDetails,\n      packageVersion,\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    if (createIssue) {\n      openIssueCreationLink({\n        packageDetails,\n        patchFileContents: diffResult.stdout.toString(),\n        packageVersion,\n      })\n    } else {\n      maybePrintIssueCreationPrompt(packageDetails, packageManager)\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}: {\n  packageDetails: PackageDetails\n  packageVersion: string\n}) {\n  const packageNames = packageDetails.packageNames\n    .map((name) => name.replace(/\\//g, \"+\"))\n    .join(\"++\")\n\n  return `${packageNames}+${packageVersion}.patch`\n}\n"]}
//# 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  maybePrintIssueCreationPrompt,\n  openIssueCreationLink,\n} from \"./createIssue\"\nimport { PackageManager } from \"./detectPackageManager\"\nimport { removeIgnoredFiles } from \"./filterFiles\"\nimport { getPackageResolution } from \"./getPackageResolution\"\nimport { getPackageVersion } from \"./getPackageVersion\"\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\"\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  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\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        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\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    if (createIssue) {\n      openIssueCreationLink({\n        packageDetails,\n        patchFileContents: diffResult.stdout.toString(),\n        packageVersion,\n      })\n    } else {\n      maybePrintIssueCreationPrompt(packageDetails, packageManager)\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"]}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getPatchDetailsFromCliString = exports.getPackageDetailsFromPatchFilename = void 0;
exports.getPatchDetailsFromCliString = exports.getPackageDetailsFromPatchFilename = exports.parseNameAndVersion = void 0;
const path_1 = require("./path");
function parseNameAndVersion(s) {
const parts = s.split("+");
switch (parts.length) {
function parseNameAndVersion(str) {
const parts = str
.split("+")
.map((s) => s.trim())
.filter(Boolean);
if (parts.length === 0) {
return null;
}
if (parts.length === 1) {
return { packageName: str };
}
const versionIndex = parts.findIndex((part) => part.match(/^\d+\.\d+\.\d+.*$/));
if (versionIndex === -1) {
const [scope, name] = parts;
return { packageName: `${scope}/${name}` };
}
const nameParts = parts.slice(0, versionIndex);
let packageName;
switch (nameParts.length) {
case 0:
return null;
case 1:
packageName = nameParts[0];
break;
case 2:
const [scope, name] = nameParts;
packageName = `${scope}/${name}`;
break;
default:
return null;
}
const version = parts[versionIndex];
const sequenceParts = parts.slice(versionIndex + 1);
if (sequenceParts.length === 0) {
return { packageName, version };
}
// expect sequenceParts[0] to be a number, strip leading 0s
const sequenceNumber = parseInt(sequenceParts[0].replace(/^0+/, ""), 10);
if (isNaN(sequenceNumber)) {
return null;
}
switch (sequenceParts.length) {
case 1: {
return { name: parts[0] };
return { packageName, version, sequenceNumber };
}
case 2: {
const [nameOrScope, versionOrName] = parts;
if (versionOrName.match(/^\d+/)) {
return {
name: nameOrScope,
version: versionOrName,
};
}
return { name: `${nameOrScope}/${versionOrName}` };
return {
packageName,
version,
sequenceName: sequenceParts[1],
sequenceNumber,
};
}
case 3: {
const [scope, name, version] = parts;
return { name: `${scope}/${name}`, version };
default: {
return null;
}

@@ -28,19 +64,4 @@ }

}
exports.parseNameAndVersion = parseNameAndVersion;
function getPackageDetailsFromPatchFilename(patchFilename) {
const legacyMatch = patchFilename.match(/^([^+=]+?)(:|\+)(\d+\.\d+\.\d+.*?)(\.dev)?\.patch$/);
if (legacyMatch) {
const name = legacyMatch[1];
const version = legacyMatch[3];
return {
packageNames: [name],
pathSpecifier: name,
humanReadablePathSpecifier: name,
path: path_1.join("node_modules", name),
name,
version,
isNested: false,
patchFilename,
isDevOnly: patchFilename.endsWith(".dev.patch"),
};
}
const parts = patchFilename

@@ -59,11 +80,15 @@ .replace(/(\.dev)?\.patch$/, "")

return {
name: lastPart.name,
name: lastPart.packageName,
version: lastPart.version,
path: path_1.join("node_modules", parts.map(({ name }) => name).join("/node_modules/")),
path: path_1.join("node_modules", parts.map(({ packageName: name }) => name).join("/node_modules/")),
patchFilename,
pathSpecifier: parts.map(({ name }) => name).join("/"),
humanReadablePathSpecifier: parts.map(({ name }) => name).join(" => "),
pathSpecifier: parts.map(({ packageName: name }) => name).join("/"),
humanReadablePathSpecifier: parts
.map(({ packageName: name }) => name)
.join(" => "),
isNested: parts.length > 1,
packageNames: parts.map(({ name }) => name),
packageNames: parts.map(({ packageName: name }) => name),
isDevOnly: patchFilename.endsWith(".dev.patch"),
sequenceName: lastPart.sequenceName,
sequenceNumber: lastPart.sequenceNumber,
};

@@ -104,2 +129,2 @@ }

exports.getPatchDetailsFromCliString = getPatchDetailsFromCliString;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PackageDetails.js","sourceRoot":"","sources":["../src/PackageDetails.ts"],"names":[],"mappings":"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","sourcesContent":["import { join } from \"./path\"\n\nexport interface PackageDetails {\n  humanReadablePathSpecifier: string\n  pathSpecifier: string\n  path: string\n  name: string\n  isNested: boolean\n  packageNames: string[]\n}\n\nexport interface PatchedPackageDetails extends PackageDetails {\n  version: string\n  patchFilename: string\n  isDevOnly: boolean\n}\n\nfunction parseNameAndVersion(\n  s: string,\n): {\n  name: string\n  version?: string\n} | null {\n  const parts = s.split(\"+\")\n  switch (parts.length) {\n    case 1: {\n      return { name: parts[0] }\n    }\n    case 2: {\n      const [nameOrScope, versionOrName] = parts\n      if (versionOrName.match(/^\\d+/)) {\n        return {\n          name: nameOrScope,\n          version: versionOrName,\n        }\n      }\n      return { name: `${nameOrScope}/${versionOrName}` }\n    }\n    case 3: {\n      const [scope, name, version] = parts\n      return { name: `${scope}/${name}`, version }\n    }\n  }\n  return null\n}\n\nexport function getPackageDetailsFromPatchFilename(\n  patchFilename: string,\n): PatchedPackageDetails | null {\n  const legacyMatch = patchFilename.match(\n    /^([^+=]+?)(:|\\+)(\\d+\\.\\d+\\.\\d+.*?)(\\.dev)?\\.patch$/,\n  )\n\n  if (legacyMatch) {\n    const name = legacyMatch[1]\n    const version = legacyMatch[3]\n\n    return {\n      packageNames: [name],\n      pathSpecifier: name,\n      humanReadablePathSpecifier: name,\n      path: join(\"node_modules\", name),\n      name,\n      version,\n      isNested: false,\n      patchFilename,\n      isDevOnly: patchFilename.endsWith(\".dev.patch\"),\n    }\n  }\n\n  const parts = patchFilename\n    .replace(/(\\.dev)?\\.patch$/, \"\")\n    .split(\"++\")\n    .map(parseNameAndVersion)\n    .filter((x): x is NonNullable<typeof x> => x !== null)\n\n  if (parts.length === 0) {\n    return null\n  }\n\n  const lastPart = parts[parts.length - 1]\n\n  if (!lastPart.version) {\n    return null\n  }\n\n  return {\n    name: lastPart.name,\n    version: lastPart.version,\n    path: join(\n      \"node_modules\",\n      parts.map(({ name }) => name).join(\"/node_modules/\"),\n    ),\n    patchFilename,\n    pathSpecifier: parts.map(({ name }) => name).join(\"/\"),\n    humanReadablePathSpecifier: parts.map(({ name }) => name).join(\" => \"),\n    isNested: parts.length > 1,\n    packageNames: parts.map(({ name }) => name),\n    isDevOnly: patchFilename.endsWith(\".dev.patch\"),\n  }\n}\n\nexport function getPatchDetailsFromCliString(\n  specifier: string,\n): PackageDetails | null {\n  const parts = specifier.split(\"/\")\n\n  const packageNames = []\n\n  let scope: string | null = null\n\n  for (let i = 0; i < parts.length; i++) {\n    if (parts[i].startsWith(\"@\")) {\n      if (scope) {\n        return null\n      }\n      scope = parts[i]\n    } else {\n      if (scope) {\n        packageNames.push(`${scope}/${parts[i]}`)\n        scope = null\n      } else {\n        packageNames.push(parts[i])\n      }\n    }\n  }\n\n  const path = join(\"node_modules\", packageNames.join(\"/node_modules/\"))\n\n  return {\n    packageNames,\n    path,\n    name: packageNames[packageNames.length - 1],\n    humanReadablePathSpecifier: packageNames.join(\" => \"),\n    isNested: packageNames.length > 1,\n    pathSpecifier: specifier,\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PackageDetails.js","sourceRoot":"","sources":["../src/PackageDetails.ts"],"names":[],"mappings":"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","sourcesContent":["import { join } from \"./path\"\n\nexport interface PackageDetails {\n  humanReadablePathSpecifier: string\n  pathSpecifier: string\n  path: string\n  name: string\n  isNested: boolean\n  packageNames: string[]\n}\n\nexport interface PatchedPackageDetails extends PackageDetails {\n  version: string\n  patchFilename: string\n  isDevOnly: boolean\n  sequenceName?: string\n  sequenceNumber?: number\n}\n\nexport function parseNameAndVersion(\n  str: string,\n): {\n  packageName: string\n  version?: string\n  sequenceName?: string\n  sequenceNumber?: number\n} | null {\n  const parts = str\n    .split(\"+\")\n    .map((s) => s.trim())\n    .filter(Boolean)\n  if (parts.length === 0) {\n    return null\n  }\n  if (parts.length === 1) {\n    return { packageName: str }\n  }\n  const versionIndex = parts.findIndex((part) =>\n    part.match(/^\\d+\\.\\d+\\.\\d+.*$/),\n  )\n  if (versionIndex === -1) {\n    const [scope, name] = parts\n    return { packageName: `${scope}/${name}` }\n  }\n  const nameParts = parts.slice(0, versionIndex)\n  let packageName\n  switch (nameParts.length) {\n    case 0:\n      return null\n    case 1:\n      packageName = nameParts[0]\n      break\n    case 2:\n      const [scope, name] = nameParts\n      packageName = `${scope}/${name}`\n      break\n    default:\n      return null\n  }\n\n  const version = parts[versionIndex]\n  const sequenceParts = parts.slice(versionIndex + 1)\n  if (sequenceParts.length === 0) {\n    return { packageName, version }\n  }\n\n  // expect sequenceParts[0] to be a number, strip leading 0s\n  const sequenceNumber = parseInt(sequenceParts[0].replace(/^0+/, \"\"), 10)\n  if (isNaN(sequenceNumber)) {\n    return null\n  }\n  switch (sequenceParts.length) {\n    case 1: {\n      return { packageName, version, sequenceNumber }\n    }\n    case 2: {\n      return {\n        packageName,\n        version,\n        sequenceName: sequenceParts[1],\n        sequenceNumber,\n      }\n    }\n    default: {\n      return null\n    }\n  }\n  return null\n}\n\nexport function getPackageDetailsFromPatchFilename(\n  patchFilename: string,\n): PatchedPackageDetails | null {\n  const parts = patchFilename\n    .replace(/(\\.dev)?\\.patch$/, \"\")\n    .split(\"++\")\n    .map(parseNameAndVersion)\n    .filter((x): x is NonNullable<typeof x> => x !== null)\n\n  if (parts.length === 0) {\n    return null\n  }\n\n  const lastPart = parts[parts.length - 1]\n\n  if (!lastPart.version) {\n    return null\n  }\n\n  return {\n    name: lastPart.packageName,\n    version: lastPart.version,\n    path: join(\n      \"node_modules\",\n      parts.map(({ packageName: name }) => name).join(\"/node_modules/\"),\n    ),\n    patchFilename,\n    pathSpecifier: parts.map(({ packageName: name }) => name).join(\"/\"),\n    humanReadablePathSpecifier: parts\n      .map(({ packageName: name }) => name)\n      .join(\" => \"),\n    isNested: parts.length > 1,\n    packageNames: parts.map(({ packageName: name }) => name),\n    isDevOnly: patchFilename.endsWith(\".dev.patch\"),\n    sequenceName: lastPart.sequenceName,\n    sequenceNumber: lastPart.sequenceNumber,\n  }\n}\n\nexport function getPatchDetailsFromCliString(\n  specifier: string,\n): PackageDetails | null {\n  const parts = specifier.split(\"/\")\n\n  const packageNames = []\n\n  let scope: string | null = null\n\n  for (let i = 0; i < parts.length; i++) {\n    if (parts[i].startsWith(\"@\")) {\n      if (scope) {\n        return null\n      }\n      scope = parts[i]\n    } else {\n      if (scope) {\n        packageNames.push(`${scope}/${parts[i]}`)\n        scope = null\n      } else {\n        packageNames.push(parts[i])\n      }\n    }\n  }\n\n  const path = join(\"node_modules\", packageNames.join(\"/node_modules/\"))\n\n  return {\n    packageNames,\n    path,\n    name: packageNames[packageNames.length - 1],\n    humanReadablePathSpecifier: packageNames.join(\" => \"),\n    isNested: packageNames.length > 1,\n    pathSpecifier: specifier,\n  }\n}\n"]}

@@ -5,69 +5,2 @@ "use strict";

describe("getPackageDetailsFromPatchFilename", () => {
it("parses old-style patch filenames", () => {
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("@types/banana:3.4.2-beta.2.patch")).toMatchInlineSnapshot(`
Object {
"humanReadablePathSpecifier": "@types/banana",
"isDevOnly": false,
"isNested": false,
"name": "@types/banana",
"packageNames": Array [
"@types/banana",
],
"patchFilename": "@types/banana:3.4.2-beta.2.patch",
"path": "node_modules/@types/banana",
"pathSpecifier": "@types/banana",
"version": "3.4.2-beta.2",
}
`);
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("banana:0.4.2.patch"))
.toMatchInlineSnapshot(`
Object {
"humanReadablePathSpecifier": "banana",
"isDevOnly": false,
"isNested": false,
"name": "banana",
"packageNames": Array [
"banana",
],
"patchFilename": "banana:0.4.2.patch",
"path": "node_modules/banana",
"pathSpecifier": "banana",
"version": "0.4.2",
}
`);
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("banana+0.4.2.patch"))
.toMatchInlineSnapshot(`
Object {
"humanReadablePathSpecifier": "banana",
"isDevOnly": false,
"isNested": false,
"name": "banana",
"packageNames": Array [
"banana",
],
"patchFilename": "banana+0.4.2.patch",
"path": "node_modules/banana",
"pathSpecifier": "banana",
"version": "0.4.2",
}
`);
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("banana-0.4.2.patch")).toBe(null);
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("@types+banana-0.4.2.patch")).toBe(null);
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("banana+0.4.2.dev.patch"))
.toMatchInlineSnapshot(`
Object {
"humanReadablePathSpecifier": "banana",
"isDevOnly": true,
"isNested": false,
"name": "banana",
"packageNames": Array [
"banana",
],
"patchFilename": "banana+0.4.2.dev.patch",
"path": "node_modules/banana",
"pathSpecifier": "banana",
"version": "0.4.2",
}
`);
});
it("parses new-style patch filenames", () => {

@@ -88,2 +21,4 @@ expect(PackageDetails_1.getPackageDetailsFromPatchFilename("banana++apple+0.4.2.patch"))

"pathSpecifier": "banana/apple",
"sequenceName": undefined,
"sequenceNumber": undefined,
"version": "0.4.2",

@@ -106,2 +41,4 @@ }

"pathSpecifier": "@types/banana/@types/apple/@mollusc/man",
"sequenceName": undefined,
"sequenceNumber": undefined,
"version": "0.4.2-banana-tree",

@@ -123,2 +60,4 @@ }

"pathSpecifier": "@types/banana.patch/hello",
"sequenceName": undefined,
"sequenceNumber": undefined,
"version": "0.4.2-banana-tree",

@@ -140,2 +79,4 @@ }

"pathSpecifier": "@types/banana.patch/hello",
"sequenceName": undefined,
"sequenceNumber": undefined,
"version": "0.4.2-banana-tree",

@@ -145,2 +86,39 @@ }

});
it("works for ordered patches", () => {
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("left-pad+1.3.0+02+world"))
.toMatchInlineSnapshot(`
Object {
"humanReadablePathSpecifier": "left-pad",
"isDevOnly": false,
"isNested": false,
"name": "left-pad",
"packageNames": Array [
"left-pad",
],
"patchFilename": "left-pad+1.3.0+02+world",
"path": "node_modules/left-pad",
"pathSpecifier": "left-pad",
"sequenceName": "world",
"sequenceNumber": 2,
"version": "1.3.0",
}
`);
expect(PackageDetails_1.getPackageDetailsFromPatchFilename("@microsoft/api-extractor+2.0.0+01+FixThing")).toMatchInlineSnapshot(`
Object {
"humanReadablePathSpecifier": "@microsoft/api-extractor",
"isDevOnly": false,
"isNested": false,
"name": "@microsoft/api-extractor",
"packageNames": Array [
"@microsoft/api-extractor",
],
"patchFilename": "@microsoft/api-extractor+2.0.0+01+FixThing",
"path": "node_modules/@microsoft/api-extractor",
"pathSpecifier": "@microsoft/api-extractor",
"sequenceName": "FixThing",
"sequenceNumber": 1,
"version": "2.0.0",
}
`);
});
});

@@ -234,2 +212,90 @@ describe("getPatchDetailsFromCliString", () => {

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PackageDetails.test.js","sourceRoot":"","sources":["../src/PackageDetails.test.ts"],"names":[],"mappings":";;AAAA,qDAGyB;AAEzB,QAAQ,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAClD,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CACJ,mDAAkC,CAAC,kCAAkC,CAAC,CACvE,CAAC,qBAAqB,CAAC;;;;;;;;;;;;;;CAc3B,CAAC,CAAA;QAEE,MAAM,CAAC,mDAAkC,CAAC,oBAAoB,CAAC,CAAC;aAC7D,qBAAqB,CAAC;;;;;;;;;;;;;;CAc5B,CAAC,CAAA;QAEE,MAAM,CAAC,mDAAkC,CAAC,oBAAoB,CAAC,CAAC;aAC7D,qBAAqB,CAAC;;;;;;;;;;;;;;CAc5B,CAAC,CAAA;QAEE,MAAM,CAAC,mDAAkC,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAE3E,MAAM,CACJ,mDAAkC,CAAC,2BAA2B,CAAC,CAChE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAEZ,MAAM,CAAC,mDAAkC,CAAC,wBAAwB,CAAC,CAAC;aACjE,qBAAqB,CAAC;;;;;;;;;;;;;;CAc5B,CAAC,CAAA;IACA,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CAAC,mDAAkC,CAAC,2BAA2B,CAAC,CAAC;aACpE,qBAAqB,CAAC;;;;;;;;;;;;;;;CAe5B,CAAC,CAAA;QAEE,MAAM,CACJ,mDAAkC,CAChC,mEAAmE,CACpE,CACF,CAAC,qBAAqB,CAAC;;;;;;;;;;;;;;;;CAgB3B,CAAC,CAAA;QAEE,MAAM,CACJ,mDAAkC,CAChC,oDAAoD,CACrD,CACF,CAAC,qBAAqB,CAAC;;;;;;;;;;;;;;;CAe3B,CAAC,CAAA;QAEE,MAAM,CACJ,mDAAkC,CAChC,wDAAwD,CACzD,CACF,CAAC,qBAAqB,CAAC;;;;;;;;;;;;;;;CAe3B,CAAC,CAAA;IACA,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,CAAC,6CAA4B,CAAC,eAAe,CAAC,CAAC,CAAC,qBAAqB,CACzE;;;;;;;;;;;CAWL,CACI,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,CACJ,6CAA4B,CAAC,sBAAsB,CAAC,CACrD,CAAC,qBAAqB,CACrB;;;;;;;;;;;CAWL,CACI,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,CACJ,6CAA4B,CAAC,qBAAqB,CAAC,CACpD,CAAC,qBAAqB,CACrB;;;;;;;;;;;;CAYL,CACI,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,CACJ,6CAA4B,CAAC,6BAA6B,CAAC,CAC5D,CAAC,qBAAqB,CACrB;;;;;;;;;;;;CAYL,CACI,CAAA;QAED,MAAM,CACJ,6CAA4B,CAAC,oCAAoC,CAAC,CACnE,CAAC,qBAAqB,CACrB;;;;;;;;;;;;CAYL,CACI,CAAA;QAED,MAAM,CACJ,6CAA4B,CAAC,mCAAmC,CAAC,CAClE,CAAC,qBAAqB,CACrB;;;;;;;;;;;;;CAaL,CACI,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA","sourcesContent":["import {\n  getPackageDetailsFromPatchFilename,\n  getPatchDetailsFromCliString,\n} from \"./PackageDetails\"\n\ndescribe(\"getPackageDetailsFromPatchFilename\", () => {\n  it(\"parses old-style patch filenames\", () => {\n    expect(\n      getPackageDetailsFromPatchFilename(\"@types/banana:3.4.2-beta.2.patch\"),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana\",\n  \"isDevOnly\": false,\n  \"isNested\": false,\n  \"name\": \"@types/banana\",\n  \"packageNames\": Array [\n    \"@types/banana\",\n  ],\n  \"patchFilename\": \"@types/banana:3.4.2-beta.2.patch\",\n  \"path\": \"node_modules/@types/banana\",\n  \"pathSpecifier\": \"@types/banana\",\n  \"version\": \"3.4.2-beta.2\",\n}\n`)\n\n    expect(getPackageDetailsFromPatchFilename(\"banana:0.4.2.patch\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"banana\",\n  \"isDevOnly\": false,\n  \"isNested\": false,\n  \"name\": \"banana\",\n  \"packageNames\": Array [\n    \"banana\",\n  ],\n  \"patchFilename\": \"banana:0.4.2.patch\",\n  \"path\": \"node_modules/banana\",\n  \"pathSpecifier\": \"banana\",\n  \"version\": \"0.4.2\",\n}\n`)\n\n    expect(getPackageDetailsFromPatchFilename(\"banana+0.4.2.patch\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"banana\",\n  \"isDevOnly\": false,\n  \"isNested\": false,\n  \"name\": \"banana\",\n  \"packageNames\": Array [\n    \"banana\",\n  ],\n  \"patchFilename\": \"banana+0.4.2.patch\",\n  \"path\": \"node_modules/banana\",\n  \"pathSpecifier\": \"banana\",\n  \"version\": \"0.4.2\",\n}\n`)\n\n    expect(getPackageDetailsFromPatchFilename(\"banana-0.4.2.patch\")).toBe(null)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\"@types+banana-0.4.2.patch\"),\n    ).toBe(null)\n\n    expect(getPackageDetailsFromPatchFilename(\"banana+0.4.2.dev.patch\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"banana\",\n  \"isDevOnly\": true,\n  \"isNested\": false,\n  \"name\": \"banana\",\n  \"packageNames\": Array [\n    \"banana\",\n  ],\n  \"patchFilename\": \"banana+0.4.2.dev.patch\",\n  \"path\": \"node_modules/banana\",\n  \"pathSpecifier\": \"banana\",\n  \"version\": \"0.4.2\",\n}\n`)\n  })\n\n  it(\"parses new-style patch filenames\", () => {\n    expect(getPackageDetailsFromPatchFilename(\"banana++apple+0.4.2.patch\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"banana => apple\",\n  \"isDevOnly\": false,\n  \"isNested\": true,\n  \"name\": \"apple\",\n  \"packageNames\": Array [\n    \"banana\",\n    \"apple\",\n  ],\n  \"patchFilename\": \"banana++apple+0.4.2.patch\",\n  \"path\": \"node_modules/banana/node_modules/apple\",\n  \"pathSpecifier\": \"banana/apple\",\n  \"version\": \"0.4.2\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@types+banana++@types+apple++@mollusc+man+0.4.2-banana-tree.patch\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana => @types/apple => @mollusc/man\",\n  \"isDevOnly\": false,\n  \"isNested\": true,\n  \"name\": \"@mollusc/man\",\n  \"packageNames\": Array [\n    \"@types/banana\",\n    \"@types/apple\",\n    \"@mollusc/man\",\n  ],\n  \"patchFilename\": \"@types+banana++@types+apple++@mollusc+man+0.4.2-banana-tree.patch\",\n  \"path\": \"node_modules/@types/banana/node_modules/@types/apple/node_modules/@mollusc/man\",\n  \"pathSpecifier\": \"@types/banana/@types/apple/@mollusc/man\",\n  \"version\": \"0.4.2-banana-tree\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@types+banana.patch++hello+0.4.2-banana-tree.patch\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana.patch => hello\",\n  \"isDevOnly\": false,\n  \"isNested\": true,\n  \"name\": \"hello\",\n  \"packageNames\": Array [\n    \"@types/banana.patch\",\n    \"hello\",\n  ],\n  \"patchFilename\": \"@types+banana.patch++hello+0.4.2-banana-tree.patch\",\n  \"path\": \"node_modules/@types/banana.patch/node_modules/hello\",\n  \"pathSpecifier\": \"@types/banana.patch/hello\",\n  \"version\": \"0.4.2-banana-tree\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@types+banana.patch++hello+0.4.2-banana-tree.dev.patch\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana.patch => hello\",\n  \"isDevOnly\": true,\n  \"isNested\": true,\n  \"name\": \"hello\",\n  \"packageNames\": Array [\n    \"@types/banana.patch\",\n    \"hello\",\n  ],\n  \"patchFilename\": \"@types+banana.patch++hello+0.4.2-banana-tree.dev.patch\",\n  \"path\": \"node_modules/@types/banana.patch/node_modules/hello\",\n  \"pathSpecifier\": \"@types/banana.patch/hello\",\n  \"version\": \"0.4.2-banana-tree\",\n}\n`)\n  })\n})\n\ndescribe(\"getPatchDetailsFromCliString\", () => {\n  it(\"handles a minimal package name\", () => {\n    expect(getPatchDetailsFromCliString(\"patch-package\")).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"patch-package\",\n  \"isNested\": false,\n  \"name\": \"patch-package\",\n  \"packageNames\": Array [\n    \"patch-package\",\n  ],\n  \"path\": \"node_modules/patch-package\",\n  \"pathSpecifier\": \"patch-package\",\n}\n`,\n    )\n  })\n\n  it(\"handles a scoped package name\", () => {\n    expect(\n      getPatchDetailsFromCliString(\"@david/patch-package\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"@david/patch-package\",\n  \"isNested\": false,\n  \"name\": \"@david/patch-package\",\n  \"packageNames\": Array [\n    \"@david/patch-package\",\n  ],\n  \"path\": \"node_modules/@david/patch-package\",\n  \"pathSpecifier\": \"@david/patch-package\",\n}\n`,\n    )\n  })\n\n  it(\"handles a nested package name\", () => {\n    expect(\n      getPatchDetailsFromCliString(\"david/patch-package\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"david => patch-package\",\n  \"isNested\": true,\n  \"name\": \"patch-package\",\n  \"packageNames\": Array [\n    \"david\",\n    \"patch-package\",\n  ],\n  \"path\": \"node_modules/david/node_modules/patch-package\",\n  \"pathSpecifier\": \"david/patch-package\",\n}\n`,\n    )\n  })\n\n  it(\"handles a nested package name with scopes\", () => {\n    expect(\n      getPatchDetailsFromCliString(\"@david/patch-package/banana\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"@david/patch-package => banana\",\n  \"isNested\": true,\n  \"name\": \"banana\",\n  \"packageNames\": Array [\n    \"@david/patch-package\",\n    \"banana\",\n  ],\n  \"path\": \"node_modules/@david/patch-package/node_modules/banana\",\n  \"pathSpecifier\": \"@david/patch-package/banana\",\n}\n`,\n    )\n\n    expect(\n      getPatchDetailsFromCliString(\"@david/patch-package/@david/banana\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"@david/patch-package => @david/banana\",\n  \"isNested\": true,\n  \"name\": \"@david/banana\",\n  \"packageNames\": Array [\n    \"@david/patch-package\",\n    \"@david/banana\",\n  ],\n  \"path\": \"node_modules/@david/patch-package/node_modules/@david/banana\",\n  \"pathSpecifier\": \"@david/patch-package/@david/banana\",\n}\n`,\n    )\n\n    expect(\n      getPatchDetailsFromCliString(\"david/patch-package/@david/banana\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"david => patch-package => @david/banana\",\n  \"isNested\": true,\n  \"name\": \"@david/banana\",\n  \"packageNames\": Array [\n    \"david\",\n    \"patch-package\",\n    \"@david/banana\",\n  ],\n  \"path\": \"node_modules/david/node_modules/patch-package/node_modules/@david/banana\",\n  \"pathSpecifier\": \"david/patch-package/@david/banana\",\n}\n`,\n    )\n  })\n})\n"]}
describe("parseNameAndVersion", () => {
it("works for good-looking names", () => {
expect(PackageDetails_1.parseNameAndVersion("lodash+2.3.4")).toMatchInlineSnapshot(`
Object {
"packageName": "lodash",
"version": "2.3.4",
}
`);
expect(PackageDetails_1.parseNameAndVersion("patch-package+2.0.0-alpha.3"))
.toMatchInlineSnapshot(`
Object {
"packageName": "patch-package",
"version": "2.0.0-alpha.3",
}
`);
});
it("works for scoped package names", () => {
expect(PackageDetails_1.parseNameAndVersion("@react-spring+rafz+2.0.0-alpha.3"))
.toMatchInlineSnapshot(`
Object {
"packageName": "@react-spring/rafz",
"version": "2.0.0-alpha.3",
}
`);
expect(PackageDetails_1.parseNameAndVersion("@microsoft+api-extractor+2.2.3"))
.toMatchInlineSnapshot(`
Object {
"packageName": "@microsoft/api-extractor",
"version": "2.2.3",
}
`);
});
it("works for ordered patches", () => {
expect(PackageDetails_1.parseNameAndVersion("patch-package+2.0.0+01"))
.toMatchInlineSnapshot(`
Object {
"packageName": "patch-package",
"sequenceNumber": 1,
"version": "2.0.0",
}
`);
expect(PackageDetails_1.parseNameAndVersion("@react-spring+rafz+2.0.0-alpha.3+23"))
.toMatchInlineSnapshot(`
Object {
"packageName": "@react-spring/rafz",
"sequenceNumber": 23,
"version": "2.0.0-alpha.3",
}
`);
expect(PackageDetails_1.parseNameAndVersion("@microsoft+api-extractor+2.0.0+001"))
.toMatchInlineSnapshot(`
Object {
"packageName": "@microsoft/api-extractor",
"sequenceNumber": 1,
"version": "2.0.0",
}
`);
});
it("works for ordered patches with names", () => {
expect(PackageDetails_1.parseNameAndVersion("patch-package+2.0.0+021+FixImportantThing"))
.toMatchInlineSnapshot(`
Object {
"packageName": "patch-package",
"sequenceName": "FixImportantThing",
"sequenceNumber": 21,
"version": "2.0.0",
}
`);
expect(PackageDetails_1.parseNameAndVersion("@react-spring+rafz+2.0.0-alpha.3+000023+Foo"))
.toMatchInlineSnapshot(`
Object {
"packageName": "@react-spring/rafz",
"sequenceName": "Foo",
"sequenceNumber": 23,
"version": "2.0.0-alpha.3",
}
`);
expect(PackageDetails_1.parseNameAndVersion("@microsoft+api-extractor+2.0.0+001+Bar"))
.toMatchInlineSnapshot(`
Object {
"packageName": "@microsoft/api-extractor",
"sequenceName": "Bar",
"sequenceNumber": 1,
"version": "2.0.0",
}
`);
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PackageDetails.test.js","sourceRoot":"","sources":["../src/PackageDetails.test.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  getPackageDetailsFromPatchFilename,\n  getPatchDetailsFromCliString,\n  parseNameAndVersion,\n} from \"./PackageDetails\"\n\ndescribe(\"getPackageDetailsFromPatchFilename\", () => {\n  it(\"parses new-style patch filenames\", () => {\n    expect(getPackageDetailsFromPatchFilename(\"banana++apple+0.4.2.patch\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"banana => apple\",\n  \"isDevOnly\": false,\n  \"isNested\": true,\n  \"name\": \"apple\",\n  \"packageNames\": Array [\n    \"banana\",\n    \"apple\",\n  ],\n  \"patchFilename\": \"banana++apple+0.4.2.patch\",\n  \"path\": \"node_modules/banana/node_modules/apple\",\n  \"pathSpecifier\": \"banana/apple\",\n  \"sequenceName\": undefined,\n  \"sequenceNumber\": undefined,\n  \"version\": \"0.4.2\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@types+banana++@types+apple++@mollusc+man+0.4.2-banana-tree.patch\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana => @types/apple => @mollusc/man\",\n  \"isDevOnly\": false,\n  \"isNested\": true,\n  \"name\": \"@mollusc/man\",\n  \"packageNames\": Array [\n    \"@types/banana\",\n    \"@types/apple\",\n    \"@mollusc/man\",\n  ],\n  \"patchFilename\": \"@types+banana++@types+apple++@mollusc+man+0.4.2-banana-tree.patch\",\n  \"path\": \"node_modules/@types/banana/node_modules/@types/apple/node_modules/@mollusc/man\",\n  \"pathSpecifier\": \"@types/banana/@types/apple/@mollusc/man\",\n  \"sequenceName\": undefined,\n  \"sequenceNumber\": undefined,\n  \"version\": \"0.4.2-banana-tree\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@types+banana.patch++hello+0.4.2-banana-tree.patch\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana.patch => hello\",\n  \"isDevOnly\": false,\n  \"isNested\": true,\n  \"name\": \"hello\",\n  \"packageNames\": Array [\n    \"@types/banana.patch\",\n    \"hello\",\n  ],\n  \"patchFilename\": \"@types+banana.patch++hello+0.4.2-banana-tree.patch\",\n  \"path\": \"node_modules/@types/banana.patch/node_modules/hello\",\n  \"pathSpecifier\": \"@types/banana.patch/hello\",\n  \"sequenceName\": undefined,\n  \"sequenceNumber\": undefined,\n  \"version\": \"0.4.2-banana-tree\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@types+banana.patch++hello+0.4.2-banana-tree.dev.patch\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@types/banana.patch => hello\",\n  \"isDevOnly\": true,\n  \"isNested\": true,\n  \"name\": \"hello\",\n  \"packageNames\": Array [\n    \"@types/banana.patch\",\n    \"hello\",\n  ],\n  \"patchFilename\": \"@types+banana.patch++hello+0.4.2-banana-tree.dev.patch\",\n  \"path\": \"node_modules/@types/banana.patch/node_modules/hello\",\n  \"pathSpecifier\": \"@types/banana.patch/hello\",\n  \"sequenceName\": undefined,\n  \"sequenceNumber\": undefined,\n  \"version\": \"0.4.2-banana-tree\",\n}\n`)\n  })\n\n  it(\"works for ordered patches\", () => {\n    expect(getPackageDetailsFromPatchFilename(\"left-pad+1.3.0+02+world\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"left-pad\",\n  \"isDevOnly\": false,\n  \"isNested\": false,\n  \"name\": \"left-pad\",\n  \"packageNames\": Array [\n    \"left-pad\",\n  ],\n  \"patchFilename\": \"left-pad+1.3.0+02+world\",\n  \"path\": \"node_modules/left-pad\",\n  \"pathSpecifier\": \"left-pad\",\n  \"sequenceName\": \"world\",\n  \"sequenceNumber\": 2,\n  \"version\": \"1.3.0\",\n}\n`)\n\n    expect(\n      getPackageDetailsFromPatchFilename(\n        \"@microsoft/api-extractor+2.0.0+01+FixThing\",\n      ),\n    ).toMatchInlineSnapshot(`\nObject {\n  \"humanReadablePathSpecifier\": \"@microsoft/api-extractor\",\n  \"isDevOnly\": false,\n  \"isNested\": false,\n  \"name\": \"@microsoft/api-extractor\",\n  \"packageNames\": Array [\n    \"@microsoft/api-extractor\",\n  ],\n  \"patchFilename\": \"@microsoft/api-extractor+2.0.0+01+FixThing\",\n  \"path\": \"node_modules/@microsoft/api-extractor\",\n  \"pathSpecifier\": \"@microsoft/api-extractor\",\n  \"sequenceName\": \"FixThing\",\n  \"sequenceNumber\": 1,\n  \"version\": \"2.0.0\",\n}\n`)\n  })\n})\n\ndescribe(\"getPatchDetailsFromCliString\", () => {\n  it(\"handles a minimal package name\", () => {\n    expect(getPatchDetailsFromCliString(\"patch-package\")).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"patch-package\",\n  \"isNested\": false,\n  \"name\": \"patch-package\",\n  \"packageNames\": Array [\n    \"patch-package\",\n  ],\n  \"path\": \"node_modules/patch-package\",\n  \"pathSpecifier\": \"patch-package\",\n}\n`,\n    )\n  })\n\n  it(\"handles a scoped package name\", () => {\n    expect(\n      getPatchDetailsFromCliString(\"@david/patch-package\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"@david/patch-package\",\n  \"isNested\": false,\n  \"name\": \"@david/patch-package\",\n  \"packageNames\": Array [\n    \"@david/patch-package\",\n  ],\n  \"path\": \"node_modules/@david/patch-package\",\n  \"pathSpecifier\": \"@david/patch-package\",\n}\n`,\n    )\n  })\n\n  it(\"handles a nested package name\", () => {\n    expect(\n      getPatchDetailsFromCliString(\"david/patch-package\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"david => patch-package\",\n  \"isNested\": true,\n  \"name\": \"patch-package\",\n  \"packageNames\": Array [\n    \"david\",\n    \"patch-package\",\n  ],\n  \"path\": \"node_modules/david/node_modules/patch-package\",\n  \"pathSpecifier\": \"david/patch-package\",\n}\n`,\n    )\n  })\n\n  it(\"handles a nested package name with scopes\", () => {\n    expect(\n      getPatchDetailsFromCliString(\"@david/patch-package/banana\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"@david/patch-package => banana\",\n  \"isNested\": true,\n  \"name\": \"banana\",\n  \"packageNames\": Array [\n    \"@david/patch-package\",\n    \"banana\",\n  ],\n  \"path\": \"node_modules/@david/patch-package/node_modules/banana\",\n  \"pathSpecifier\": \"@david/patch-package/banana\",\n}\n`,\n    )\n\n    expect(\n      getPatchDetailsFromCliString(\"@david/patch-package/@david/banana\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"@david/patch-package => @david/banana\",\n  \"isNested\": true,\n  \"name\": \"@david/banana\",\n  \"packageNames\": Array [\n    \"@david/patch-package\",\n    \"@david/banana\",\n  ],\n  \"path\": \"node_modules/@david/patch-package/node_modules/@david/banana\",\n  \"pathSpecifier\": \"@david/patch-package/@david/banana\",\n}\n`,\n    )\n\n    expect(\n      getPatchDetailsFromCliString(\"david/patch-package/@david/banana\"),\n    ).toMatchInlineSnapshot(\n      `\nObject {\n  \"humanReadablePathSpecifier\": \"david => patch-package => @david/banana\",\n  \"isNested\": true,\n  \"name\": \"@david/banana\",\n  \"packageNames\": Array [\n    \"david\",\n    \"patch-package\",\n    \"@david/banana\",\n  ],\n  \"path\": \"node_modules/david/node_modules/patch-package/node_modules/@david/banana\",\n  \"pathSpecifier\": \"david/patch-package/@david/banana\",\n}\n`,\n    )\n  })\n})\n\ndescribe(\"parseNameAndVersion\", () => {\n  it(\"works for good-looking names\", () => {\n    expect(parseNameAndVersion(\"lodash+2.3.4\")).toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"lodash\",\n  \"version\": \"2.3.4\",\n}\n`)\n    expect(parseNameAndVersion(\"patch-package+2.0.0-alpha.3\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"patch-package\",\n  \"version\": \"2.0.0-alpha.3\",\n}\n`)\n  })\n  it(\"works for scoped package names\", () => {\n    expect(parseNameAndVersion(\"@react-spring+rafz+2.0.0-alpha.3\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"@react-spring/rafz\",\n  \"version\": \"2.0.0-alpha.3\",\n}\n`)\n    expect(parseNameAndVersion(\"@microsoft+api-extractor+2.2.3\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"@microsoft/api-extractor\",\n  \"version\": \"2.2.3\",\n}\n`)\n  })\n  it(\"works for ordered patches\", () => {\n    expect(parseNameAndVersion(\"patch-package+2.0.0+01\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"patch-package\",\n  \"sequenceNumber\": 1,\n  \"version\": \"2.0.0\",\n}\n`)\n    expect(parseNameAndVersion(\"@react-spring+rafz+2.0.0-alpha.3+23\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"@react-spring/rafz\",\n  \"sequenceNumber\": 23,\n  \"version\": \"2.0.0-alpha.3\",\n}\n`)\n    expect(parseNameAndVersion(\"@microsoft+api-extractor+2.0.0+001\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"@microsoft/api-extractor\",\n  \"sequenceNumber\": 1,\n  \"version\": \"2.0.0\",\n}\n`)\n  })\n\n  it(\"works for ordered patches with names\", () => {\n    expect(parseNameAndVersion(\"patch-package+2.0.0+021+FixImportantThing\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"patch-package\",\n  \"sequenceName\": \"FixImportantThing\",\n  \"sequenceNumber\": 21,\n  \"version\": \"2.0.0\",\n}\n`)\n    expect(parseNameAndVersion(\"@react-spring+rafz+2.0.0-alpha.3+000023+Foo\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"@react-spring/rafz\",\n  \"sequenceName\": \"Foo\",\n  \"sequenceNumber\": 23,\n  \"version\": \"2.0.0-alpha.3\",\n}\n`)\n    expect(parseNameAndVersion(\"@microsoft+api-extractor+2.0.0+001+Bar\"))\n      .toMatchInlineSnapshot(`\nObject {\n  \"packageName\": \"@microsoft/api-extractor\",\n  \"sequenceName\": \"Bar\",\n  \"sequenceNumber\": 1,\n  \"version\": \"2.0.0\",\n}\n`)\n  })\n})\n"]}

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

const fs_1 = require("fs");
function packageIsDevDependency({ appPath, packageDetails, }) {
function packageIsDevDependency({ appPath, patchDetails, }) {
const packageJsonPath = path_1.join(appPath, "package.json");

@@ -13,5 +13,5 @@ if (!fs_1.existsSync(packageJsonPath)) {

const { devDependencies } = require(packageJsonPath);
return Boolean(devDependencies && devDependencies[packageDetails.packageNames[0]]);
return Boolean(devDependencies && devDependencies[patchDetails.packageNames[0]]);
}
exports.packageIsDevDependency = packageIsDevDependency;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZUlzRGV2RGVwZW5kZW5jeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9wYWNrYWdlSXNEZXZEZXBlbmRlbmN5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLGlDQUE2QjtBQUM3QiwyQkFBK0I7QUFFL0IsU0FBZ0Isc0JBQXNCLENBQUMsRUFDckMsT0FBTyxFQUNQLGNBQWMsR0FJZjtJQUNDLE1BQU0sZUFBZSxHQUFHLFdBQUksQ0FBQyxPQUFPLEVBQUUsY0FBYyxDQUFDLENBQUE7SUFDckQsSUFBSSxDQUFDLGVBQVUsQ0FBQyxlQUFlLENBQUMsRUFBRTtRQUNoQyxPQUFPLEtBQUssQ0FBQTtLQUNiO0lBQ0QsTUFBTSxFQUFFLGVBQWUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQTtJQUNwRCxPQUFPLE9BQU8sQ0FBQyxlQUFlLElBQUksZUFBZSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0FBQ3BGLENBQUM7QUFiRCx3REFhQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhdGNoZWRQYWNrYWdlRGV0YWlscyB9IGZyb20gXCIuL1BhY2thZ2VEZXRhaWxzXCJcbmltcG9ydCB7IGpvaW4gfSBmcm9tIFwiLi9wYXRoXCJcbmltcG9ydCB7IGV4aXN0c1N5bmMgfSBmcm9tIFwiZnNcIlxuXG5leHBvcnQgZnVuY3Rpb24gcGFja2FnZUlzRGV2RGVwZW5kZW5jeSh7XG4gIGFwcFBhdGgsXG4gIHBhY2thZ2VEZXRhaWxzLFxufToge1xuICBhcHBQYXRoOiBzdHJpbmdcbiAgcGFja2FnZURldGFpbHM6IFBhdGNoZWRQYWNrYWdlRGV0YWlsc1xufSkge1xuICBjb25zdCBwYWNrYWdlSnNvblBhdGggPSBqb2luKGFwcFBhdGgsIFwicGFja2FnZS5qc29uXCIpXG4gIGlmICghZXhpc3RzU3luYyhwYWNrYWdlSnNvblBhdGgpKSB7XG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cbiAgY29uc3QgeyBkZXZEZXBlbmRlbmNpZXMgfSA9IHJlcXVpcmUocGFja2FnZUpzb25QYXRoKVxuICByZXR1cm4gQm9vbGVhbihkZXZEZXBlbmRlbmNpZXMgJiYgZGV2RGVwZW5kZW5jaWVzW3BhY2thZ2VEZXRhaWxzLnBhY2thZ2VOYW1lc1swXV0pXG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZUlzRGV2RGVwZW5kZW5jeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9wYWNrYWdlSXNEZXZEZXBlbmRlbmN5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLGlDQUE2QjtBQUM3QiwyQkFBK0I7QUFFL0IsU0FBZ0Isc0JBQXNCLENBQUMsRUFDckMsT0FBTyxFQUNQLFlBQVksR0FJYjtJQUNDLE1BQU0sZUFBZSxHQUFHLFdBQUksQ0FBQyxPQUFPLEVBQUUsY0FBYyxDQUFDLENBQUE7SUFDckQsSUFBSSxDQUFDLGVBQVUsQ0FBQyxlQUFlLENBQUMsRUFBRTtRQUNoQyxPQUFPLEtBQUssQ0FBQTtLQUNiO0lBQ0QsTUFBTSxFQUFFLGVBQWUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQTtJQUNwRCxPQUFPLE9BQU8sQ0FDWixlQUFlLElBQUksZUFBZSxDQUFDLFlBQVksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FDakUsQ0FBQTtBQUNILENBQUM7QUFmRCx3REFlQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBhdGNoZWRQYWNrYWdlRGV0YWlscyB9IGZyb20gXCIuL1BhY2thZ2VEZXRhaWxzXCJcbmltcG9ydCB7IGpvaW4gfSBmcm9tIFwiLi9wYXRoXCJcbmltcG9ydCB7IGV4aXN0c1N5bmMgfSBmcm9tIFwiZnNcIlxuXG5leHBvcnQgZnVuY3Rpb24gcGFja2FnZUlzRGV2RGVwZW5kZW5jeSh7XG4gIGFwcFBhdGgsXG4gIHBhdGNoRGV0YWlscyxcbn06IHtcbiAgYXBwUGF0aDogc3RyaW5nXG4gIHBhdGNoRGV0YWlsczogUGF0Y2hlZFBhY2thZ2VEZXRhaWxzXG59KSB7XG4gIGNvbnN0IHBhY2thZ2VKc29uUGF0aCA9IGpvaW4oYXBwUGF0aCwgXCJwYWNrYWdlLmpzb25cIilcbiAgaWYgKCFleGlzdHNTeW5jKHBhY2thZ2VKc29uUGF0aCkpIHtcbiAgICByZXR1cm4gZmFsc2VcbiAgfVxuICBjb25zdCB7IGRldkRlcGVuZGVuY2llcyB9ID0gcmVxdWlyZShwYWNrYWdlSnNvblBhdGgpXG4gIHJldHVybiBCb29sZWFuKFxuICAgIGRldkRlcGVuZGVuY2llcyAmJiBkZXZEZXBlbmRlbmNpZXNbcGF0Y2hEZXRhaWxzLnBhY2thZ2VOYW1lc1swXV0sXG4gIClcbn1cbiJdfQ==

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

appPath,
packageDetails: PackageDetails_1.getPackageDetailsFromPatchFilename("typescript+3.0.1.patch"),
patchDetails: PackageDetails_1.getPackageDetailsFromPatchFilename("typescript+3.0.1.patch"),
})).toBe(true);

@@ -20,3 +20,3 @@ });

appPath,
packageDetails: PackageDetails_1.getPackageDetailsFromPatchFilename("chalk+3.0.1.patch"),
patchDetails: PackageDetails_1.getPackageDetailsFromPatchFilename("chalk+3.0.1.patch"),
})).toBe(false);

@@ -28,3 +28,3 @@ });

appPath,
packageDetails: PackageDetails_1.getPackageDetailsFromPatchFilename(
patchDetails: PackageDetails_1.getPackageDetailsFromPatchFilename(
// cosmiconfig is a transitive dep of lint-staged

@@ -35,2 +35,2 @@ "cosmiconfig+3.0.1.patch"),

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZUlzRGV2RGVwZW5kZW5jeS50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3BhY2thZ2VJc0RldkRlcGVuZGVuY3kudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHFFQUFpRTtBQUNqRSxpQ0FBNkI7QUFDN0IsK0JBQWdDO0FBQ2hDLHFEQUFxRTtBQUNyRSwyQkFBK0I7QUFFL0IsTUFBTSxPQUFPLEdBQUcsZ0JBQVMsQ0FBQyxXQUFJLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUE7QUFFakQsUUFBUSxDQUFDLCtDQUFzQixFQUFFLEdBQUcsRUFBRTtJQUNwQyxFQUFFLENBQUMsNkNBQTZDLEVBQUUsR0FBRyxFQUFFO1FBQ3JELE1BQU0sQ0FDSiwrQ0FBc0IsQ0FBQztZQUNyQixPQUFPO1lBQ1AsY0FBYyxFQUFFLG1EQUFrQyxDQUNoRCx3QkFBd0IsQ0FDeEI7U0FDSCxDQUFDLENBQ0gsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDZCxDQUFDLENBQUMsQ0FBQTtJQUNGLEVBQUUsQ0FBQyxrREFBa0QsRUFBRSxHQUFHLEVBQUU7UUFDMUQsTUFBTSxDQUNKLCtDQUFzQixDQUFDO1lBQ3JCLE9BQU87WUFDUCxjQUFjLEVBQUUsbURBQWtDLENBQ2hELG1CQUFtQixDQUNuQjtTQUNILENBQUMsQ0FDSCxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUNmLENBQUMsQ0FBQyxDQUFBO0lBQ0YsRUFBRSxDQUFDLHlFQUF5RSxFQUFFLEdBQUcsRUFBRTtRQUNqRixNQUFNLENBQUMsZUFBVSxDQUFDLFdBQUksQ0FBQyxPQUFPLEVBQUUsMEJBQTBCLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3hFLE1BQU0sQ0FDSiwrQ0FBc0IsQ0FBQztZQUNyQixPQUFPO1lBQ1AsY0FBYyxFQUFFLG1EQUFrQztZQUNoRCxpREFBaUQ7WUFDakQseUJBQXlCLENBQ3pCO1NBQ0gsQ0FBQyxDQUNILENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ2YsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHBhY2thZ2VJc0RldkRlcGVuZGVuY3kgfSBmcm9tIFwiLi9wYWNrYWdlSXNEZXZEZXBlbmRlbmN5XCJcbmltcG9ydCB7IGpvaW4gfSBmcm9tIFwiLi9wYXRoXCJcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gXCJwYXRoXCJcbmltcG9ydCB7IGdldFBhY2thZ2VEZXRhaWxzRnJvbVBhdGNoRmlsZW5hbWUgfSBmcm9tIFwiLi9QYWNrYWdlRGV0YWlsc1wiXG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSBcImZzXCJcblxuY29uc3QgYXBwUGF0aCA9IG5vcm1hbGl6ZShqb2luKF9fZGlybmFtZSwgXCIuLi9cIikpXG5cbmRlc2NyaWJlKHBhY2thZ2VJc0RldkRlcGVuZGVuY3ksICgpID0+IHtcbiAgaXQoXCJyZXR1cm5zIHRydWUgaWYgcGFja2FnZSBpcyBhIGRldiBkZXBlbmRlbmN5XCIsICgpID0+IHtcbiAgICBleHBlY3QoXG4gICAgICBwYWNrYWdlSXNEZXZEZXBlbmRlbmN5KHtcbiAgICAgICAgYXBwUGF0aCxcbiAgICAgICAgcGFja2FnZURldGFpbHM6IGdldFBhY2thZ2VEZXRhaWxzRnJvbVBhdGNoRmlsZW5hbWUoXG4gICAgICAgICAgXCJ0eXBlc2NyaXB0KzMuMC4xLnBhdGNoXCIsXG4gICAgICAgICkhLFxuICAgICAgfSksXG4gICAgKS50b0JlKHRydWUpXG4gIH0pXG4gIGl0KFwicmV0dXJucyBmYWxzZSBpZiBwYWNrYWdlIGlzIG5vdCBhIGRldiBkZXBlbmRlbmN5XCIsICgpID0+IHtcbiAgICBleHBlY3QoXG4gICAgICBwYWNrYWdlSXNEZXZEZXBlbmRlbmN5KHtcbiAgICAgICAgYXBwUGF0aCxcbiAgICAgICAgcGFja2FnZURldGFpbHM6IGdldFBhY2thZ2VEZXRhaWxzRnJvbVBhdGNoRmlsZW5hbWUoXG4gICAgICAgICAgXCJjaGFsayszLjAuMS5wYXRjaFwiLFxuICAgICAgICApISxcbiAgICAgIH0pLFxuICAgICkudG9CZShmYWxzZSlcbiAgfSlcbiAgaXQoXCJyZXR1cm5zIGZhbHNlIGlmIHBhY2thZ2UgaXMgYSB0cmFuc2l0aXZlIGRlcGVuZGVuY3kgb2YgYSBkZXYgZGVwZW5kZW5jeVwiLCAoKSA9PiB7XG4gICAgZXhwZWN0KGV4aXN0c1N5bmMoam9pbihhcHBQYXRoLCBcIm5vZGVfbW9kdWxlcy9jb3NtaWNvbmZpZ1wiKSkpLnRvQmUodHJ1ZSlcbiAgICBleHBlY3QoXG4gICAgICBwYWNrYWdlSXNEZXZEZXBlbmRlbmN5KHtcbiAgICAgICAgYXBwUGF0aCxcbiAgICAgICAgcGFja2FnZURldGFpbHM6IGdldFBhY2thZ2VEZXRhaWxzRnJvbVBhdGNoRmlsZW5hbWUoXG4gICAgICAgICAgLy8gY29zbWljb25maWcgaXMgYSB0cmFuc2l0aXZlIGRlcCBvZiBsaW50LXN0YWdlZFxuICAgICAgICAgIFwiY29zbWljb25maWcrMy4wLjEucGF0Y2hcIixcbiAgICAgICAgKSEsXG4gICAgICB9KSxcbiAgICApLnRvQmUoZmFsc2UpXG4gIH0pXG59KVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZUlzRGV2RGVwZW5kZW5jeS50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3BhY2thZ2VJc0RldkRlcGVuZGVuY3kudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHFFQUFpRTtBQUNqRSxpQ0FBNkI7QUFDN0IsK0JBQWdDO0FBQ2hDLHFEQUFxRTtBQUNyRSwyQkFBK0I7QUFFL0IsTUFBTSxPQUFPLEdBQUcsZ0JBQVMsQ0FBQyxXQUFJLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUE7QUFFakQsUUFBUSxDQUFDLCtDQUFzQixFQUFFLEdBQUcsRUFBRTtJQUNwQyxFQUFFLENBQUMsNkNBQTZDLEVBQUUsR0FBRyxFQUFFO1FBQ3JELE1BQU0sQ0FDSiwrQ0FBc0IsQ0FBQztZQUNyQixPQUFPO1lBQ1AsWUFBWSxFQUFFLG1EQUFrQyxDQUM5Qyx3QkFBd0IsQ0FDeEI7U0FDSCxDQUFDLENBQ0gsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDZCxDQUFDLENBQUMsQ0FBQTtJQUNGLEVBQUUsQ0FBQyxrREFBa0QsRUFBRSxHQUFHLEVBQUU7UUFDMUQsTUFBTSxDQUNKLCtDQUFzQixDQUFDO1lBQ3JCLE9BQU87WUFDUCxZQUFZLEVBQUUsbURBQWtDLENBQUMsbUJBQW1CLENBQUU7U0FDdkUsQ0FBQyxDQUNILENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQ2YsQ0FBQyxDQUFDLENBQUE7SUFDRixFQUFFLENBQUMseUVBQXlFLEVBQUUsR0FBRyxFQUFFO1FBQ2pGLE1BQU0sQ0FBQyxlQUFVLENBQUMsV0FBSSxDQUFDLE9BQU8sRUFBRSwwQkFBMEIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDeEUsTUFBTSxDQUNKLCtDQUFzQixDQUFDO1lBQ3JCLE9BQU87WUFDUCxZQUFZLEVBQUUsbURBQWtDO1lBQzlDLGlEQUFpRDtZQUNqRCx5QkFBeUIsQ0FDekI7U0FDSCxDQUFDLENBQ0gsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDZixDQUFDLENBQUMsQ0FBQTtBQUNKLENBQUMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcGFja2FnZUlzRGV2RGVwZW5kZW5jeSB9IGZyb20gXCIuL3BhY2thZ2VJc0RldkRlcGVuZGVuY3lcIlxuaW1wb3J0IHsgam9pbiB9IGZyb20gXCIuL3BhdGhcIlxuaW1wb3J0IHsgbm9ybWFsaXplIH0gZnJvbSBcInBhdGhcIlxuaW1wb3J0IHsgZ2V0UGFja2FnZURldGFpbHNGcm9tUGF0Y2hGaWxlbmFtZSB9IGZyb20gXCIuL1BhY2thZ2VEZXRhaWxzXCJcbmltcG9ydCB7IGV4aXN0c1N5bmMgfSBmcm9tIFwiZnNcIlxuXG5jb25zdCBhcHBQYXRoID0gbm9ybWFsaXplKGpvaW4oX19kaXJuYW1lLCBcIi4uL1wiKSlcblxuZGVzY3JpYmUocGFja2FnZUlzRGV2RGVwZW5kZW5jeSwgKCkgPT4ge1xuICBpdChcInJldHVybnMgdHJ1ZSBpZiBwYWNrYWdlIGlzIGEgZGV2IGRlcGVuZGVuY3lcIiwgKCkgPT4ge1xuICAgIGV4cGVjdChcbiAgICAgIHBhY2thZ2VJc0RldkRlcGVuZGVuY3koe1xuICAgICAgICBhcHBQYXRoLFxuICAgICAgICBwYXRjaERldGFpbHM6IGdldFBhY2thZ2VEZXRhaWxzRnJvbVBhdGNoRmlsZW5hbWUoXG4gICAgICAgICAgXCJ0eXBlc2NyaXB0KzMuMC4xLnBhdGNoXCIsXG4gICAgICAgICkhLFxuICAgICAgfSksXG4gICAgKS50b0JlKHRydWUpXG4gIH0pXG4gIGl0KFwicmV0dXJucyBmYWxzZSBpZiBwYWNrYWdlIGlzIG5vdCBhIGRldiBkZXBlbmRlbmN5XCIsICgpID0+IHtcbiAgICBleHBlY3QoXG4gICAgICBwYWNrYWdlSXNEZXZEZXBlbmRlbmN5KHtcbiAgICAgICAgYXBwUGF0aCxcbiAgICAgICAgcGF0Y2hEZXRhaWxzOiBnZXRQYWNrYWdlRGV0YWlsc0Zyb21QYXRjaEZpbGVuYW1lKFwiY2hhbGsrMy4wLjEucGF0Y2hcIikhLFxuICAgICAgfSksXG4gICAgKS50b0JlKGZhbHNlKVxuICB9KVxuICBpdChcInJldHVybnMgZmFsc2UgaWYgcGFja2FnZSBpcyBhIHRyYW5zaXRpdmUgZGVwZW5kZW5jeSBvZiBhIGRldiBkZXBlbmRlbmN5XCIsICgpID0+IHtcbiAgICBleHBlY3QoZXhpc3RzU3luYyhqb2luKGFwcFBhdGgsIFwibm9kZV9tb2R1bGVzL2Nvc21pY29uZmlnXCIpKSkudG9CZSh0cnVlKVxuICAgIGV4cGVjdChcbiAgICAgIHBhY2thZ2VJc0RldkRlcGVuZGVuY3koe1xuICAgICAgICBhcHBQYXRoLFxuICAgICAgICBwYXRjaERldGFpbHM6IGdldFBhY2thZ2VEZXRhaWxzRnJvbVBhdGNoRmlsZW5hbWUoXG4gICAgICAgICAgLy8gY29zbWljb25maWcgaXMgYSB0cmFuc2l0aXZlIGRlcCBvZiBsaW50LXN0YWdlZFxuICAgICAgICAgIFwiY29zbWljb25maWcrMy4wLjEucGF0Y2hcIixcbiAgICAgICAgKSEsXG4gICAgICB9KSxcbiAgICApLnRvQmUoZmFsc2UpXG4gIH0pXG59KVxuIl19

@@ -10,9 +10,12 @@ "use strict";

const assertNever_1 = require("../assertNever");
const executeEffects = (effects, { dryRun }) => {
effects.forEach(eff => {
const executeEffects = (effects, { dryRun, cwd }) => {
const inCwd = (path) => (cwd ? path_1.join(cwd, path) : path);
const humanReadable = (path) => path_1.relative(process.cwd(), inCwd(path));
effects.forEach((eff) => {
switch (eff.type) {
case "file deletion":
if (dryRun) {
if (!fs_extra_1.default.existsSync(eff.path)) {
throw new Error("Trying to delete file that doesn't exist: " + eff.path);
if (!fs_extra_1.default.existsSync(inCwd(eff.path))) {
throw new Error("Trying to delete file that doesn't exist: " +
humanReadable(eff.path));
}

@@ -22,3 +25,3 @@ }

// TODO: integrity checks
fs_extra_1.default.unlinkSync(eff.path);
fs_extra_1.default.unlinkSync(inCwd(eff.path));
}

@@ -29,8 +32,9 @@ break;

// TODO: see what patch files look like if moving to exising path
if (!fs_extra_1.default.existsSync(eff.fromPath)) {
throw new Error("Trying to move file that doesn't exist: " + eff.fromPath);
if (!fs_extra_1.default.existsSync(inCwd(eff.fromPath))) {
throw new Error("Trying to move file that doesn't exist: " +
humanReadable(eff.fromPath));
}
}
else {
fs_extra_1.default.moveSync(eff.fromPath, eff.toPath);
fs_extra_1.default.moveSync(inCwd(eff.fromPath), inCwd(eff.toPath));
}

@@ -40,4 +44,5 @@ break;

if (dryRun) {
if (fs_extra_1.default.existsSync(eff.path)) {
throw new Error("Trying to create file that already exists: " + eff.path);
if (fs_extra_1.default.existsSync(inCwd(eff.path))) {
throw new Error("Trying to create file that already exists: " +
humanReadable(eff.path));
}

@@ -51,17 +56,18 @@ // todo: check file contents matches

: "";
fs_extra_1.default.ensureDirSync(path_1.dirname(eff.path));
fs_extra_1.default.writeFileSync(eff.path, fileContents, { mode: eff.mode });
const path = inCwd(eff.path);
fs_extra_1.default.ensureDirSync(path_1.dirname(path));
fs_extra_1.default.writeFileSync(path, fileContents, { mode: eff.mode });
}
break;
case "patch":
applyPatch(eff, { dryRun });
applyPatch(eff, { dryRun, cwd });
break;
case "mode change":
const currentMode = fs_extra_1.default.statSync(eff.path).mode;
const currentMode = fs_extra_1.default.statSync(inCwd(eff.path)).mode;
if (((isExecutable(eff.newMode) && isExecutable(currentMode)) ||
(!isExecutable(eff.newMode) && !isExecutable(currentMode))) &&
dryRun) {
console.warn(`Mode change is not required for file ${eff.path}`);
console.warn(`Mode change is not required for file ${humanReadable(eff.path)}`);
}
fs_extra_1.default.chmodSync(eff.path, eff.newMode);
fs_extra_1.default.chmodSync(inCwd(eff.path), eff.newMode);
break;

@@ -103,3 +109,4 @@ default:

*/
function applyPatch({ hunks, path }, { dryRun }) {
function applyPatch({ hunks, path }, { dryRun, cwd }) {
path = cwd ? path_1.resolve(cwd, path) : path;
// modifying the file in place

@@ -121,3 +128,3 @@ const fileContents = fs_extra_1.default.readFileSync(path).toString();

if (Math.abs(fuzzingOffset) > 20) {
throw new Error(`Cant apply hunk ${hunks.indexOf(hunk)} for file ${path}`);
throw new Error(`Cant apply hunk ${hunks.indexOf(hunk)} for file ${path_1.relative(process.cwd(), path)}`);
}

@@ -204,2 +211,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply.js","sourceRoot":"","sources":["../../src/patch/apply.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from \"fs-extra\"\nimport { dirname } from \"path\"\nimport { ParsedPatchFile, FilePatch, Hunk } from \"./parse\"\nimport { assertNever } from \"../assertNever\"\n\nexport const executeEffects = (\n  effects: ParsedPatchFile,\n  { dryRun }: { dryRun: boolean },\n) => {\n  effects.forEach(eff => {\n    switch (eff.type) {\n      case \"file deletion\":\n        if (dryRun) {\n          if (!fs.existsSync(eff.path)) {\n            throw new Error(\n              \"Trying to delete file that doesn't exist: \" + eff.path,\n            )\n          }\n        } else {\n          // TODO: integrity checks\n          fs.unlinkSync(eff.path)\n        }\n        break\n      case \"rename\":\n        if (dryRun) {\n          // TODO: see what patch files look like if moving to exising path\n          if (!fs.existsSync(eff.fromPath)) {\n            throw new Error(\n              \"Trying to move file that doesn't exist: \" + eff.fromPath,\n            )\n          }\n        } else {\n          fs.moveSync(eff.fromPath, eff.toPath)\n        }\n        break\n      case \"file creation\":\n        if (dryRun) {\n          if (fs.existsSync(eff.path)) {\n            throw new Error(\n              \"Trying to create file that already exists: \" + eff.path,\n            )\n          }\n          // todo: check file contents matches\n        } else {\n          const fileContents = eff.hunk\n            ? eff.hunk.parts[0].lines.join(\"\\n\") +\n              (eff.hunk.parts[0].noNewlineAtEndOfFile ? \"\" : \"\\n\")\n            : \"\"\n          fs.ensureDirSync(dirname(eff.path))\n          fs.writeFileSync(eff.path, fileContents, { mode: eff.mode })\n        }\n        break\n      case \"patch\":\n        applyPatch(eff, { dryRun })\n        break\n      case \"mode change\":\n        const currentMode = fs.statSync(eff.path).mode\n        if (\n          ((isExecutable(eff.newMode) && isExecutable(currentMode)) ||\n            (!isExecutable(eff.newMode) && !isExecutable(currentMode))) &&\n          dryRun\n        ) {\n          console.warn(`Mode change is not required for file ${eff.path}`)\n        }\n        fs.chmodSync(eff.path, eff.newMode)\n        break\n      default:\n        assertNever(eff)\n    }\n  })\n}\n\nfunction isExecutable(fileMode: number) {\n  // tslint:disable-next-line:no-bitwise\n  return (fileMode & 0b001_000_000) > 0\n}\n\nconst trimRight = (s: string) => s.replace(/\\s+$/, \"\")\nfunction linesAreEqual(a: string, b: string) {\n  return trimRight(a) === trimRight(b)\n}\n\n/**\n * How does noNewLineAtEndOfFile work?\n *\n * if you remove the newline from a file that had one without editing other bits:\n *\n *    it creates an insertion/removal pair where the insertion has \\ No new line at end of file\n *\n * if you edit a file that didn't have a new line and don't add one:\n *\n *    both insertion and deletion have \\ No new line at end of file\n *\n * if you edit a file that didn't have a new line and add one:\n *\n *    deletion has \\ No new line at end of file\n *    but not insertion\n *\n * if you edit a file that had a new line and leave it in:\n *\n *    neither insetion nor deletion have the annoation\n *\n */\n\nfunction applyPatch(\n  { hunks, path }: FilePatch,\n  { dryRun }: { dryRun: boolean },\n): void {\n  // modifying the file in place\n  const fileContents = fs.readFileSync(path).toString()\n  const mode = fs.statSync(path).mode\n\n  const fileLines: string[] = fileContents.split(/\\n/)\n\n  const result: Modificaiton[][] = []\n\n  for (const hunk of hunks) {\n    let fuzzingOffset = 0\n    while (true) {\n      const modifications = evaluateHunk(hunk, fileLines, fuzzingOffset)\n      if (modifications) {\n        result.push(modifications)\n        break\n      }\n\n      fuzzingOffset =\n        fuzzingOffset < 0 ? fuzzingOffset * -1 : fuzzingOffset * -1 - 1\n\n      if (Math.abs(fuzzingOffset) > 20) {\n        throw new Error(\n          `Cant apply hunk ${hunks.indexOf(hunk)} for file ${path}`,\n        )\n      }\n    }\n  }\n\n  if (dryRun) {\n    return\n  }\n\n  let diffOffset = 0\n\n  for (const modifications of result) {\n    for (const modification of modifications) {\n      switch (modification.type) {\n        case \"splice\":\n          fileLines.splice(\n            modification.index + diffOffset,\n            modification.numToDelete,\n            ...modification.linesToInsert,\n          )\n          diffOffset +=\n            modification.linesToInsert.length - modification.numToDelete\n          break\n        case \"pop\":\n          fileLines.pop()\n          break\n        case \"push\":\n          fileLines.push(modification.line)\n          break\n        default:\n          assertNever(modification)\n      }\n    }\n  }\n\n  fs.writeFileSync(path, fileLines.join(\"\\n\"), { mode })\n}\n\ninterface Push {\n  type: \"push\"\n  line: string\n}\ninterface Pop {\n  type: \"pop\"\n}\ninterface Splice {\n  type: \"splice\"\n  index: number\n  numToDelete: number\n  linesToInsert: string[]\n}\n\ntype Modificaiton = Push | Pop | Splice\n\nfunction evaluateHunk(\n  hunk: Hunk,\n  fileLines: string[],\n  fuzzingOffset: number,\n): Modificaiton[] | null {\n  const result: Modificaiton[] = []\n  let contextIndex = hunk.header.original.start - 1 + fuzzingOffset\n  // do bounds checks for index\n  if (contextIndex < 0) {\n    return null\n  }\n  if (fileLines.length - contextIndex < hunk.header.original.length) {\n    return null\n  }\n\n  for (const part of hunk.parts) {\n    switch (part.type) {\n      case \"deletion\":\n      case \"context\":\n        for (const line of part.lines) {\n          const originalLine = fileLines[contextIndex]\n          if (!linesAreEqual(originalLine, line)) {\n            return null\n          }\n          contextIndex++\n        }\n\n        if (part.type === \"deletion\") {\n          result.push({\n            type: \"splice\",\n            index: contextIndex - part.lines.length,\n            numToDelete: part.lines.length,\n            linesToInsert: [],\n          })\n\n          if (part.noNewlineAtEndOfFile) {\n            result.push({\n              type: \"push\",\n              line: \"\",\n            })\n          }\n        }\n        break\n      case \"insertion\":\n        result.push({\n          type: \"splice\",\n          index: contextIndex,\n          numToDelete: 0,\n          linesToInsert: part.lines,\n        })\n        if (part.noNewlineAtEndOfFile) {\n          result.push({ type: \"pop\" })\n        }\n        break\n      default:\n        assertNever(part.type)\n    }\n  }\n\n  return result\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply.js","sourceRoot":"","sources":["../../src/patch/apply.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from \"fs-extra\"\nimport { dirname, join, relative, resolve } from \"path\"\nimport { ParsedPatchFile, FilePatch, Hunk } from \"./parse\"\nimport { assertNever } from \"../assertNever\"\n\nexport const executeEffects = (\n  effects: ParsedPatchFile,\n  { dryRun, cwd }: { dryRun: boolean; cwd?: string },\n) => {\n  const inCwd = (path: string) => (cwd ? join(cwd, path) : path)\n  const humanReadable = (path: string) => relative(process.cwd(), inCwd(path))\n  effects.forEach((eff) => {\n    switch (eff.type) {\n      case \"file deletion\":\n        if (dryRun) {\n          if (!fs.existsSync(inCwd(eff.path))) {\n            throw new Error(\n              \"Trying to delete file that doesn't exist: \" +\n                humanReadable(eff.path),\n            )\n          }\n        } else {\n          // TODO: integrity checks\n          fs.unlinkSync(inCwd(eff.path))\n        }\n        break\n      case \"rename\":\n        if (dryRun) {\n          // TODO: see what patch files look like if moving to exising path\n          if (!fs.existsSync(inCwd(eff.fromPath))) {\n            throw new Error(\n              \"Trying to move file that doesn't exist: \" +\n                humanReadable(eff.fromPath),\n            )\n          }\n        } else {\n          fs.moveSync(inCwd(eff.fromPath), inCwd(eff.toPath))\n        }\n        break\n      case \"file creation\":\n        if (dryRun) {\n          if (fs.existsSync(inCwd(eff.path))) {\n            throw new Error(\n              \"Trying to create file that already exists: \" +\n                humanReadable(eff.path),\n            )\n          }\n          // todo: check file contents matches\n        } else {\n          const fileContents = eff.hunk\n            ? eff.hunk.parts[0].lines.join(\"\\n\") +\n              (eff.hunk.parts[0].noNewlineAtEndOfFile ? \"\" : \"\\n\")\n            : \"\"\n          const path = inCwd(eff.path)\n          fs.ensureDirSync(dirname(path))\n          fs.writeFileSync(path, fileContents, { mode: eff.mode })\n        }\n        break\n      case \"patch\":\n        applyPatch(eff, { dryRun, cwd })\n        break\n      case \"mode change\":\n        const currentMode = fs.statSync(inCwd(eff.path)).mode\n        if (\n          ((isExecutable(eff.newMode) && isExecutable(currentMode)) ||\n            (!isExecutable(eff.newMode) && !isExecutable(currentMode))) &&\n          dryRun\n        ) {\n          console.warn(\n            `Mode change is not required for file ${humanReadable(eff.path)}`,\n          )\n        }\n        fs.chmodSync(inCwd(eff.path), eff.newMode)\n        break\n      default:\n        assertNever(eff)\n    }\n  })\n}\n\nfunction isExecutable(fileMode: number) {\n  // tslint:disable-next-line:no-bitwise\n  return (fileMode & 0b001_000_000) > 0\n}\n\nconst trimRight = (s: string) => s.replace(/\\s+$/, \"\")\nfunction linesAreEqual(a: string, b: string) {\n  return trimRight(a) === trimRight(b)\n}\n\n/**\n * How does noNewLineAtEndOfFile work?\n *\n * if you remove the newline from a file that had one without editing other bits:\n *\n *    it creates an insertion/removal pair where the insertion has \\ No new line at end of file\n *\n * if you edit a file that didn't have a new line and don't add one:\n *\n *    both insertion and deletion have \\ No new line at end of file\n *\n * if you edit a file that didn't have a new line and add one:\n *\n *    deletion has \\ No new line at end of file\n *    but not insertion\n *\n * if you edit a file that had a new line and leave it in:\n *\n *    neither insetion nor deletion have the annoation\n *\n */\n\nfunction applyPatch(\n  { hunks, path }: FilePatch,\n  { dryRun, cwd }: { dryRun: boolean; cwd?: string },\n): void {\n  path = cwd ? resolve(cwd, path) : path\n  // modifying the file in place\n  const fileContents = fs.readFileSync(path).toString()\n  const mode = fs.statSync(path).mode\n\n  const fileLines: string[] = fileContents.split(/\\n/)\n\n  const result: Modificaiton[][] = []\n\n  for (const hunk of hunks) {\n    let fuzzingOffset = 0\n    while (true) {\n      const modifications = evaluateHunk(hunk, fileLines, fuzzingOffset)\n      if (modifications) {\n        result.push(modifications)\n        break\n      }\n\n      fuzzingOffset =\n        fuzzingOffset < 0 ? fuzzingOffset * -1 : fuzzingOffset * -1 - 1\n\n      if (Math.abs(fuzzingOffset) > 20) {\n        throw new Error(\n          `Cant apply hunk ${hunks.indexOf(hunk)} for file ${relative(\n            process.cwd(),\n            path,\n          )}`,\n        )\n      }\n    }\n  }\n\n  if (dryRun) {\n    return\n  }\n\n  let diffOffset = 0\n\n  for (const modifications of result) {\n    for (const modification of modifications) {\n      switch (modification.type) {\n        case \"splice\":\n          fileLines.splice(\n            modification.index + diffOffset,\n            modification.numToDelete,\n            ...modification.linesToInsert,\n          )\n          diffOffset +=\n            modification.linesToInsert.length - modification.numToDelete\n          break\n        case \"pop\":\n          fileLines.pop()\n          break\n        case \"push\":\n          fileLines.push(modification.line)\n          break\n        default:\n          assertNever(modification)\n      }\n    }\n  }\n\n  fs.writeFileSync(path, fileLines.join(\"\\n\"), { mode })\n}\n\ninterface Push {\n  type: \"push\"\n  line: string\n}\ninterface Pop {\n  type: \"pop\"\n}\ninterface Splice {\n  type: \"splice\"\n  index: number\n  numToDelete: number\n  linesToInsert: string[]\n}\n\ntype Modificaiton = Push | Pop | Splice\n\nfunction evaluateHunk(\n  hunk: Hunk,\n  fileLines: string[],\n  fuzzingOffset: number,\n): Modificaiton[] | null {\n  const result: Modificaiton[] = []\n  let contextIndex = hunk.header.original.start - 1 + fuzzingOffset\n  // do bounds checks for index\n  if (contextIndex < 0) {\n    return null\n  }\n  if (fileLines.length - contextIndex < hunk.header.original.length) {\n    return null\n  }\n\n  for (const part of hunk.parts) {\n    switch (part.type) {\n      case \"deletion\":\n      case \"context\":\n        for (const line of part.lines) {\n          const originalLine = fileLines[contextIndex]\n          if (!linesAreEqual(originalLine, line)) {\n            return null\n          }\n          contextIndex++\n        }\n\n        if (part.type === \"deletion\") {\n          result.push({\n            type: \"splice\",\n            index: contextIndex - part.lines.length,\n            numToDelete: part.lines.length,\n            linesToInsert: [],\n          })\n\n          if (part.noNewlineAtEndOfFile) {\n            result.push({\n              type: \"push\",\n              line: \"\",\n            })\n          }\n        }\n        break\n      case \"insertion\":\n        result.push({\n          type: \"splice\",\n          index: contextIndex,\n          numToDelete: 0,\n          linesToInsert: part.lines,\n        })\n        if (part.noNewlineAtEndOfFile) {\n          result.push({ type: \"pop\" })\n        }\n        break\n      default:\n        assertNever(part.type)\n    }\n  }\n\n  return result\n}\n"]}

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

const parse_1 = require("./parse");
function readPatch({ patchFilePath, packageDetails, patchDir, }) {
function readPatch({ patchFilePath, patchDetails, patchDir, }) {
try {

@@ -25,3 +25,3 @@ return parse_1.parsePatchFile(fs_extra_1.readFileSync(patchFilePath).toString());

fixupSteps.push(`patch -p1 -i ${relativePatchFilePath.slice(relativePatchFilePath.indexOf(patchDir))}`);
fixupSteps.push(`npx patch-package ${packageDetails.pathSpecifier}`);
fixupSteps.push(`npx patch-package ${patchDetails.pathSpecifier}`);
if (patchBaseDir) {

@@ -31,3 +31,3 @@ fixupSteps.push(`cd ${path_1.relative(path_1.resolve(process.cwd(), patchBaseDir), process.cwd())}`);

console.error(`
${chalk_1.default.red.bold("**ERROR**")} ${chalk_1.default.red(`Failed to apply patch for package ${chalk_1.default.bold(packageDetails.humanReadablePathSpecifier)}`)}
${chalk_1.default.red.bold("**ERROR**")} ${chalk_1.default.red(`Failed to apply patch for package ${chalk_1.default.bold(patchDetails.humanReadablePathSpecifier)}`)}

@@ -52,2 +52,2 @@ This happened because the patch file ${relativePatchFilePath} could not be parsed.

exports.readPatch = readPatch;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYXRjaC9yZWFkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLGtEQUF5QjtBQUN6Qix1Q0FBdUM7QUFDdkMsa0NBQTJDO0FBQzNDLCtCQUFnQztBQUVoQyxtQ0FBdUQ7QUFFdkQsU0FBZ0IsU0FBUyxDQUFDLEVBQ3hCLGFBQWEsRUFDYixjQUFjLEVBQ2QsUUFBUSxHQUtUO0lBQ0MsSUFBSTtRQUNGLE9BQU8sc0JBQWMsQ0FBQyx1QkFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUE7S0FDOUQ7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNWLE1BQU0sVUFBVSxHQUFhLEVBQUUsQ0FBQTtRQUMvQixNQUFNLHFCQUFxQixHQUFHLGdCQUFTLENBQ3JDLGVBQVEsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEVBQUUsYUFBYSxDQUFDLENBQ3ZDLENBQUE7UUFDRCxNQUFNLFlBQVksR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQzlDLENBQUMsRUFDRCxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQ3hDLENBQUE7UUFDRCxJQUFJLFlBQVksRUFBRTtZQUNoQixVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sWUFBWSxFQUFFLENBQUMsQ0FBQTtTQUN0QztRQUNELFVBQVUsQ0FBQyxJQUFJLENBQ2IsZ0JBQWdCLHFCQUFxQixDQUFDLEtBQUssQ0FDekMscUJBQXFCLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUN4QyxFQUFFLENBQ0osQ0FBQTtRQUNELFVBQVUsQ0FBQyxJQUFJLENBQUMscUJBQXFCLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFBO1FBQ3BFLElBQUksWUFBWSxFQUFFO1lBQ2hCLFVBQVUsQ0FBQyxJQUFJLENBQ2IsTUFBTSxlQUFRLENBQUMsY0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxZQUFZLENBQUMsRUFBRSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUN0RSxDQUFBO1NBQ0Y7UUFFRCxPQUFPLENBQUMsS0FBSyxDQUFDO0VBQ2hCLGVBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLGVBQUssQ0FBQyxHQUFHLENBQ3BDLHFDQUFxQyxlQUFLLENBQUMsSUFBSSxDQUM3QyxjQUFjLENBQUMsMEJBQTBCLENBQzFDLEVBQUUsQ0FDSjs7eUNBRW9DLHFCQUFxQjs7OztNQUl4RCxVQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQzs7Ozs7Ozs7Q0FROUIsQ0FBQyxDQUFBO1FBQ0UsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtLQUNoQjtJQUNELE9BQU8sRUFBRSxDQUFBO0FBQ1gsQ0FBQztBQTFERCw4QkEwREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2hhbGsgZnJvbSBcImNoYWxrXCJcbmltcG9ydCB7IHJlYWRGaWxlU3luYyB9IGZyb20gXCJmcy1leHRyYVwiXG5pbXBvcnQgeyByZWxhdGl2ZSwgcmVzb2x2ZSB9IGZyb20gXCIuLi9wYXRoXCJcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gXCJwYXRoXCJcbmltcG9ydCB7IFBhY2thZ2VEZXRhaWxzIH0gZnJvbSBcIi4uL1BhY2thZ2VEZXRhaWxzXCJcbmltcG9ydCB7IHBhcnNlUGF0Y2hGaWxlLCBQYXRjaEZpbGVQYXJ0IH0gZnJvbSBcIi4vcGFyc2VcIlxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFBhdGNoKHtcbiAgcGF0Y2hGaWxlUGF0aCxcbiAgcGFja2FnZURldGFpbHMsXG4gIHBhdGNoRGlyLFxufToge1xuICBwYXRjaEZpbGVQYXRoOiBzdHJpbmdcbiAgcGFja2FnZURldGFpbHM6IFBhY2thZ2VEZXRhaWxzXG4gIHBhdGNoRGlyOiBzdHJpbmdcbn0pOiBQYXRjaEZpbGVQYXJ0W10ge1xuICB0cnkge1xuICAgIHJldHVybiBwYXJzZVBhdGNoRmlsZShyZWFkRmlsZVN5bmMocGF0Y2hGaWxlUGF0aCkudG9TdHJpbmcoKSlcbiAgfSBjYXRjaCAoZSkge1xuICAgIGNvbnN0IGZpeHVwU3RlcHM6IHN0cmluZ1tdID0gW11cbiAgICBjb25zdCByZWxhdGl2ZVBhdGNoRmlsZVBhdGggPSBub3JtYWxpemUoXG4gICAgICByZWxhdGl2ZShwcm9jZXNzLmN3ZCgpLCBwYXRjaEZpbGVQYXRoKSxcbiAgICApXG4gICAgY29uc3QgcGF0Y2hCYXNlRGlyID0gcmVsYXRpdmVQYXRjaEZpbGVQYXRoLnNsaWNlKFxuICAgICAgMCxcbiAgICAgIHJlbGF0aXZlUGF0Y2hGaWxlUGF0aC5pbmRleE9mKHBhdGNoRGlyKSxcbiAgICApXG4gICAgaWYgKHBhdGNoQmFzZURpcikge1xuICAgICAgZml4dXBTdGVwcy5wdXNoKGBjZCAke3BhdGNoQmFzZURpcn1gKVxuICAgIH1cbiAgICBmaXh1cFN0ZXBzLnB1c2goXG4gICAgICBgcGF0Y2ggLXAxIC1pICR7cmVsYXRpdmVQYXRjaEZpbGVQYXRoLnNsaWNlKFxuICAgICAgICByZWxhdGl2ZVBhdGNoRmlsZVBhdGguaW5kZXhPZihwYXRjaERpciksXG4gICAgICApfWAsXG4gICAgKVxuICAgIGZpeHVwU3RlcHMucHVzaChgbnB4IHBhdGNoLXBhY2thZ2UgJHtwYWNrYWdlRGV0YWlscy5wYXRoU3BlY2lmaWVyfWApXG4gICAgaWYgKHBhdGNoQmFzZURpcikge1xuICAgICAgZml4dXBTdGVwcy5wdXNoKFxuICAgICAgICBgY2QgJHtyZWxhdGl2ZShyZXNvbHZlKHByb2Nlc3MuY3dkKCksIHBhdGNoQmFzZURpciksIHByb2Nlc3MuY3dkKCkpfWAsXG4gICAgICApXG4gICAgfVxuXG4gICAgY29uc29sZS5lcnJvcihgXG4ke2NoYWxrLnJlZC5ib2xkKFwiKipFUlJPUioqXCIpfSAke2NoYWxrLnJlZChcbiAgICAgIGBGYWlsZWQgdG8gYXBwbHkgcGF0Y2ggZm9yIHBhY2thZ2UgJHtjaGFsay5ib2xkKFxuICAgICAgICBwYWNrYWdlRGV0YWlscy5odW1hblJlYWRhYmxlUGF0aFNwZWNpZmllcixcbiAgICAgICl9YCxcbiAgICApfVxuICAgIFxuICBUaGlzIGhhcHBlbmVkIGJlY2F1c2UgdGhlIHBhdGNoIGZpbGUgJHtyZWxhdGl2ZVBhdGNoRmlsZVBhdGh9IGNvdWxkIG5vdCBiZSBwYXJzZWQuXG4gICBcbiAgSWYgeW91IGp1c3QgdXBncmFkZWQgcGF0Y2gtcGFja2FnZSwgeW91IGNhbiB0cnkgcnVubmluZzpcbiAgXG4gICAgJHtmaXh1cFN0ZXBzLmpvaW4oXCJcXG4gICAgXCIpfVxuICAgIFxuICBPdGhlcndpc2UsIHRyeSBtYW51YWxseSBjcmVhdGluZyB0aGUgcGF0Y2ggZmlsZSBhZ2Fpbi5cbiAgXG4gIElmIHRoZSBwcm9ibGVtIHBlcnNpc3RzLCBwbGVhc2Ugc3VibWl0IGEgYnVnIHJlcG9ydDpcbiAgXG4gICAgaHR0cHM6Ly9naXRodWIuY29tL2RzMzAwL3BhdGNoLXBhY2thZ2UvaXNzdWVzL25ldz90aXRsZT1QYXRjaCtmaWxlK3BhcnNlK2Vycm9yJmJvZHk9JTNDUGxlYXNlK2F0dGFjaCt0aGUrcGF0Y2grZmlsZStpbitxdWVzdGlvbiUzRVxuXG5gKVxuICAgIHByb2Nlc3MuZXhpdCgxKVxuICB9XG4gIHJldHVybiBbXVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYXRjaC9yZWFkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLGtEQUF5QjtBQUN6Qix1Q0FBdUM7QUFDdkMsa0NBQTJDO0FBQzNDLCtCQUFnQztBQUVoQyxtQ0FBdUQ7QUFFdkQsU0FBZ0IsU0FBUyxDQUFDLEVBQ3hCLGFBQWEsRUFDYixZQUFZLEVBQ1osUUFBUSxHQUtUO0lBQ0MsSUFBSTtRQUNGLE9BQU8sc0JBQWMsQ0FBQyx1QkFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUE7S0FDOUQ7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNWLE1BQU0sVUFBVSxHQUFhLEVBQUUsQ0FBQTtRQUMvQixNQUFNLHFCQUFxQixHQUFHLGdCQUFTLENBQ3JDLGVBQVEsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEVBQUUsYUFBYSxDQUFDLENBQ3ZDLENBQUE7UUFDRCxNQUFNLFlBQVksR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQzlDLENBQUMsRUFDRCxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQ3hDLENBQUE7UUFDRCxJQUFJLFlBQVksRUFBRTtZQUNoQixVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sWUFBWSxFQUFFLENBQUMsQ0FBQTtTQUN0QztRQUNELFVBQVUsQ0FBQyxJQUFJLENBQ2IsZ0JBQWdCLHFCQUFxQixDQUFDLEtBQUssQ0FDekMscUJBQXFCLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUN4QyxFQUFFLENBQ0osQ0FBQTtRQUNELFVBQVUsQ0FBQyxJQUFJLENBQUMscUJBQXFCLFlBQVksQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFBO1FBQ2xFLElBQUksWUFBWSxFQUFFO1lBQ2hCLFVBQVUsQ0FBQyxJQUFJLENBQ2IsTUFBTSxlQUFRLENBQUMsY0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxZQUFZLENBQUMsRUFBRSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUN0RSxDQUFBO1NBQ0Y7UUFFRCxPQUFPLENBQUMsS0FBSyxDQUFDO0VBQ2hCLGVBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLGVBQUssQ0FBQyxHQUFHLENBQ3BDLHFDQUFxQyxlQUFLLENBQUMsSUFBSSxDQUM3QyxZQUFZLENBQUMsMEJBQTBCLENBQ3hDLEVBQUUsQ0FDSjs7eUNBRW9DLHFCQUFxQjs7OztNQUl4RCxVQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQzs7Ozs7Ozs7Q0FROUIsQ0FBQyxDQUFBO1FBQ0UsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtLQUNoQjtJQUNELE9BQU8sRUFBRSxDQUFBO0FBQ1gsQ0FBQztBQTFERCw4QkEwREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2hhbGsgZnJvbSBcImNoYWxrXCJcbmltcG9ydCB7IHJlYWRGaWxlU3luYyB9IGZyb20gXCJmcy1leHRyYVwiXG5pbXBvcnQgeyByZWxhdGl2ZSwgcmVzb2x2ZSB9IGZyb20gXCIuLi9wYXRoXCJcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gXCJwYXRoXCJcbmltcG9ydCB7IFBhY2thZ2VEZXRhaWxzIH0gZnJvbSBcIi4uL1BhY2thZ2VEZXRhaWxzXCJcbmltcG9ydCB7IHBhcnNlUGF0Y2hGaWxlLCBQYXRjaEZpbGVQYXJ0IH0gZnJvbSBcIi4vcGFyc2VcIlxuXG5leHBvcnQgZnVuY3Rpb24gcmVhZFBhdGNoKHtcbiAgcGF0Y2hGaWxlUGF0aCxcbiAgcGF0Y2hEZXRhaWxzLFxuICBwYXRjaERpcixcbn06IHtcbiAgcGF0Y2hGaWxlUGF0aDogc3RyaW5nXG4gIHBhdGNoRGV0YWlsczogUGFja2FnZURldGFpbHNcbiAgcGF0Y2hEaXI6IHN0cmluZ1xufSk6IFBhdGNoRmlsZVBhcnRbXSB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIHBhcnNlUGF0Y2hGaWxlKHJlYWRGaWxlU3luYyhwYXRjaEZpbGVQYXRoKS50b1N0cmluZygpKVxuICB9IGNhdGNoIChlKSB7XG4gICAgY29uc3QgZml4dXBTdGVwczogc3RyaW5nW10gPSBbXVxuICAgIGNvbnN0IHJlbGF0aXZlUGF0Y2hGaWxlUGF0aCA9IG5vcm1hbGl6ZShcbiAgICAgIHJlbGF0aXZlKHByb2Nlc3MuY3dkKCksIHBhdGNoRmlsZVBhdGgpLFxuICAgIClcbiAgICBjb25zdCBwYXRjaEJhc2VEaXIgPSByZWxhdGl2ZVBhdGNoRmlsZVBhdGguc2xpY2UoXG4gICAgICAwLFxuICAgICAgcmVsYXRpdmVQYXRjaEZpbGVQYXRoLmluZGV4T2YocGF0Y2hEaXIpLFxuICAgIClcbiAgICBpZiAocGF0Y2hCYXNlRGlyKSB7XG4gICAgICBmaXh1cFN0ZXBzLnB1c2goYGNkICR7cGF0Y2hCYXNlRGlyfWApXG4gICAgfVxuICAgIGZpeHVwU3RlcHMucHVzaChcbiAgICAgIGBwYXRjaCAtcDEgLWkgJHtyZWxhdGl2ZVBhdGNoRmlsZVBhdGguc2xpY2UoXG4gICAgICAgIHJlbGF0aXZlUGF0Y2hGaWxlUGF0aC5pbmRleE9mKHBhdGNoRGlyKSxcbiAgICAgICl9YCxcbiAgICApXG4gICAgZml4dXBTdGVwcy5wdXNoKGBucHggcGF0Y2gtcGFja2FnZSAke3BhdGNoRGV0YWlscy5wYXRoU3BlY2lmaWVyfWApXG4gICAgaWYgKHBhdGNoQmFzZURpcikge1xuICAgICAgZml4dXBTdGVwcy5wdXNoKFxuICAgICAgICBgY2QgJHtyZWxhdGl2ZShyZXNvbHZlKHByb2Nlc3MuY3dkKCksIHBhdGNoQmFzZURpciksIHByb2Nlc3MuY3dkKCkpfWAsXG4gICAgICApXG4gICAgfVxuXG4gICAgY29uc29sZS5lcnJvcihgXG4ke2NoYWxrLnJlZC5ib2xkKFwiKipFUlJPUioqXCIpfSAke2NoYWxrLnJlZChcbiAgICAgIGBGYWlsZWQgdG8gYXBwbHkgcGF0Y2ggZm9yIHBhY2thZ2UgJHtjaGFsay5ib2xkKFxuICAgICAgICBwYXRjaERldGFpbHMuaHVtYW5SZWFkYWJsZVBhdGhTcGVjaWZpZXIsXG4gICAgICApfWAsXG4gICAgKX1cbiAgICBcbiAgVGhpcyBoYXBwZW5lZCBiZWNhdXNlIHRoZSBwYXRjaCBmaWxlICR7cmVsYXRpdmVQYXRjaEZpbGVQYXRofSBjb3VsZCBub3QgYmUgcGFyc2VkLlxuICAgXG4gIElmIHlvdSBqdXN0IHVwZ3JhZGVkIHBhdGNoLXBhY2thZ2UsIHlvdSBjYW4gdHJ5IHJ1bm5pbmc6XG4gIFxuICAgICR7Zml4dXBTdGVwcy5qb2luKFwiXFxuICAgIFwiKX1cbiAgICBcbiAgT3RoZXJ3aXNlLCB0cnkgbWFudWFsbHkgY3JlYXRpbmcgdGhlIHBhdGNoIGZpbGUgYWdhaW4uXG4gIFxuICBJZiB0aGUgcHJvYmxlbSBwZXJzaXN0cywgcGxlYXNlIHN1Ym1pdCBhIGJ1ZyByZXBvcnQ6XG4gIFxuICAgIGh0dHBzOi8vZ2l0aHViLmNvbS9kczMwMC9wYXRjaC1wYWNrYWdlL2lzc3Vlcy9uZXc/dGl0bGU9UGF0Y2grZmlsZStwYXJzZStlcnJvciZib2R5PSUzQ1BsZWFzZSthdHRhY2grdGhlK3BhdGNoK2ZpbGUraW4rcXVlc3Rpb24lM0VcblxuYClcbiAgICBwcm9jZXNzLmV4aXQoMSlcbiAgfVxuICByZXR1cm4gW11cbn1cbiJdfQ==

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

Object.defineProperty(exports, "__esModule", { value: true });
exports.getPatchFiles = void 0;
exports.getGroupedPatches = exports.getPatchFiles = void 0;
const PackageDetails_1 = require("./PackageDetails");
const path_1 = require("./path");

@@ -14,3 +15,3 @@ const klaw_sync_1 = __importDefault(require("klaw-sync"));

.map(({ path }) => path_1.relative(patchesDir, path))
.filter(path => path.endsWith(".patch"));
.filter((path) => path.endsWith(".patch"));
}

@@ -22,2 +23,37 @@ catch (e) {

exports.getPatchFiles = getPatchFiles;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0Y2hGcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9wYXRjaEZzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLGlDQUFpQztBQUNqQywwREFBZ0M7QUFFekIsTUFBTSxhQUFhLEdBQUcsQ0FBQyxVQUFrQixFQUFFLEVBQUU7SUFDbEQsSUFBSTtRQUNGLE9BQU8sbUJBQVEsQ0FBQyxVQUFVLEVBQUUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7YUFDekMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsZUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQzthQUM3QyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUE7S0FDM0M7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNWLE9BQU8sRUFBRSxDQUFBO0tBQ1Y7QUFDSCxDQUFDLENBQUE7QUFSWSxRQUFBLGFBQWEsaUJBUXpCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVsYXRpdmUgfSBmcm9tIFwiLi9wYXRoXCJcbmltcG9ydCBrbGF3U3luYyBmcm9tIFwia2xhdy1zeW5jXCJcblxuZXhwb3J0IGNvbnN0IGdldFBhdGNoRmlsZXMgPSAocGF0Y2hlc0Rpcjogc3RyaW5nKSA9PiB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIGtsYXdTeW5jKHBhdGNoZXNEaXIsIHsgbm9kaXI6IHRydWUgfSlcbiAgICAgIC5tYXAoKHsgcGF0aCB9KSA9PiByZWxhdGl2ZShwYXRjaGVzRGlyLCBwYXRoKSlcbiAgICAgIC5maWx0ZXIocGF0aCA9PiBwYXRoLmVuZHNXaXRoKFwiLnBhdGNoXCIpKVxuICB9IGNhdGNoIChlKSB7XG4gICAgcmV0dXJuIFtdXG4gIH1cbn1cbiJdfQ==
const getGroupedPatches = (patchesDirectory) => {
const files = exports.getPatchFiles(patchesDirectory);
if (files.length === 0) {
return {
numPatchFiles: 0,
pathSpecifierToPatchFiles: {},
warnings: [],
};
}
const warnings = [];
const pathSpecifierToPatchFiles = {};
for (const file of files) {
const details = PackageDetails_1.getPackageDetailsFromPatchFilename(file);
if (!details) {
warnings.push(`Unrecognized patch file in patches directory ${file}`);
continue;
}
if (!pathSpecifierToPatchFiles[details.pathSpecifier]) {
pathSpecifierToPatchFiles[details.pathSpecifier] = [];
}
pathSpecifierToPatchFiles[details.pathSpecifier].push(details);
}
for (const arr of Object.values(pathSpecifierToPatchFiles)) {
arr.sort((a, b) => {
var _a, _b;
return ((_a = a.sequenceNumber) !== null && _a !== void 0 ? _a : 0) - ((_b = b.sequenceNumber) !== null && _b !== void 0 ? _b : 0);
});
}
return {
numPatchFiles: files.length,
pathSpecifierToPatchFiles,
warnings,
};
};
exports.getGroupedPatches = getGroupedPatches;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0Y2hGcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9wYXRjaEZzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHFEQUd5QjtBQUN6QixpQ0FBaUM7QUFDakMsMERBQWdDO0FBRXpCLE1BQU0sYUFBYSxHQUFHLENBQUMsVUFBa0IsRUFBRSxFQUFFO0lBQ2xELElBQUk7UUFDRixPQUFPLG1CQUFRLENBQUMsVUFBVSxFQUFFLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDO2FBQ3pDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLGVBQVEsQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7YUFDN0MsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUE7S0FDN0M7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNWLE9BQU8sRUFBRSxDQUFBO0tBQ1Y7QUFDSCxDQUFDLENBQUE7QUFSWSxRQUFBLGFBQWEsaUJBUXpCO0FBT00sTUFBTSxpQkFBaUIsR0FBRyxDQUFDLGdCQUF3QixFQUFrQixFQUFFO0lBQzVFLE1BQU0sS0FBSyxHQUFHLHFCQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQTtJQUU3QyxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3RCLE9BQU87WUFDTCxhQUFhLEVBQUUsQ0FBQztZQUNoQix5QkFBeUIsRUFBRSxFQUFFO1lBQzdCLFFBQVEsRUFBRSxFQUFFO1NBQ2IsQ0FBQTtLQUNGO0lBRUQsTUFBTSxRQUFRLEdBQWEsRUFBRSxDQUFBO0lBRTdCLE1BQU0seUJBQXlCLEdBQTRDLEVBQUUsQ0FBQTtJQUM3RSxLQUFLLE1BQU0sSUFBSSxJQUFJLEtBQUssRUFBRTtRQUN4QixNQUFNLE9BQU8sR0FBRyxtREFBa0MsQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUN4RCxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ1osUUFBUSxDQUFDLElBQUksQ0FBQyxnREFBZ0QsSUFBSSxFQUFFLENBQUMsQ0FBQTtZQUNyRSxTQUFRO1NBQ1Q7UUFDRCxJQUFJLENBQUMseUJBQXlCLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxFQUFFO1lBQ3JELHlCQUF5QixDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsR0FBRyxFQUFFLENBQUE7U0FDdEQ7UUFDRCx5QkFBeUIsQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0tBQy9EO0lBQ0QsS0FBSyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLHlCQUF5QixDQUFDLEVBQUU7UUFDMUQsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTs7WUFDaEIsT0FBTyxDQUFDLE1BQUEsQ0FBQyxDQUFDLGNBQWMsbUNBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxNQUFBLENBQUMsQ0FBQyxjQUFjLG1DQUFJLENBQUMsQ0FBQyxDQUFBO1FBQzFELENBQUMsQ0FBQyxDQUFBO0tBQ0g7SUFFRCxPQUFPO1FBQ0wsYUFBYSxFQUFFLEtBQUssQ0FBQyxNQUFNO1FBQzNCLHlCQUF5QjtRQUN6QixRQUFRO0tBQ1QsQ0FBQTtBQUNILENBQUMsQ0FBQTtBQXBDWSxRQUFBLGlCQUFpQixxQkFvQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgUGF0Y2hlZFBhY2thZ2VEZXRhaWxzLFxuICBnZXRQYWNrYWdlRGV0YWlsc0Zyb21QYXRjaEZpbGVuYW1lLFxufSBmcm9tIFwiLi9QYWNrYWdlRGV0YWlsc1wiXG5pbXBvcnQgeyByZWxhdGl2ZSB9IGZyb20gXCIuL3BhdGhcIlxuaW1wb3J0IGtsYXdTeW5jIGZyb20gXCJrbGF3LXN5bmNcIlxuXG5leHBvcnQgY29uc3QgZ2V0UGF0Y2hGaWxlcyA9IChwYXRjaGVzRGlyOiBzdHJpbmcpID0+IHtcbiAgdHJ5IHtcbiAgICByZXR1cm4ga2xhd1N5bmMocGF0Y2hlc0RpciwgeyBub2RpcjogdHJ1ZSB9KVxuICAgICAgLm1hcCgoeyBwYXRoIH0pID0+IHJlbGF0aXZlKHBhdGNoZXNEaXIsIHBhdGgpKVxuICAgICAgLmZpbHRlcigocGF0aCkgPT4gcGF0aC5lbmRzV2l0aChcIi5wYXRjaFwiKSlcbiAgfSBjYXRjaCAoZSkge1xuICAgIHJldHVybiBbXVxuICB9XG59XG5cbmludGVyZmFjZSBHcm91cGVkUGF0Y2hlcyB7XG4gIG51bVBhdGNoRmlsZXM6IG51bWJlclxuICBwYXRoU3BlY2lmaWVyVG9QYXRjaEZpbGVzOiBSZWNvcmQ8c3RyaW5nLCBQYXRjaGVkUGFja2FnZURldGFpbHNbXT5cbiAgd2FybmluZ3M6IHN0cmluZ1tdXG59XG5leHBvcnQgY29uc3QgZ2V0R3JvdXBlZFBhdGNoZXMgPSAocGF0Y2hlc0RpcmVjdG9yeTogc3RyaW5nKTogR3JvdXBlZFBhdGNoZXMgPT4ge1xuICBjb25zdCBmaWxlcyA9IGdldFBhdGNoRmlsZXMocGF0Y2hlc0RpcmVjdG9yeSlcblxuICBpZiAoZmlsZXMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG51bVBhdGNoRmlsZXM6IDAsXG4gICAgICBwYXRoU3BlY2lmaWVyVG9QYXRjaEZpbGVzOiB7fSxcbiAgICAgIHdhcm5pbmdzOiBbXSxcbiAgICB9XG4gIH1cblxuICBjb25zdCB3YXJuaW5nczogc3RyaW5nW10gPSBbXVxuXG4gIGNvbnN0IHBhdGhTcGVjaWZpZXJUb1BhdGNoRmlsZXM6IFJlY29yZDxzdHJpbmcsIFBhdGNoZWRQYWNrYWdlRGV0YWlsc1tdPiA9IHt9XG4gIGZvciAoY29uc3QgZmlsZSBvZiBmaWxlcykge1xuICAgIGNvbnN0IGRldGFpbHMgPSBnZXRQYWNrYWdlRGV0YWlsc0Zyb21QYXRjaEZpbGVuYW1lKGZpbGUpXG4gICAgaWYgKCFkZXRhaWxzKSB7XG4gICAgICB3YXJuaW5ncy5wdXNoKGBVbnJlY29nbml6ZWQgcGF0Y2ggZmlsZSBpbiBwYXRjaGVzIGRpcmVjdG9yeSAke2ZpbGV9YClcbiAgICAgIGNvbnRpbnVlXG4gICAgfVxuICAgIGlmICghcGF0aFNwZWNpZmllclRvUGF0Y2hGaWxlc1tkZXRhaWxzLnBhdGhTcGVjaWZpZXJdKSB7XG4gICAgICBwYXRoU3BlY2lmaWVyVG9QYXRjaEZpbGVzW2RldGFpbHMucGF0aFNwZWNpZmllcl0gPSBbXVxuICAgIH1cbiAgICBwYXRoU3BlY2lmaWVyVG9QYXRjaEZpbGVzW2RldGFpbHMucGF0aFNwZWNpZmllcl0ucHVzaChkZXRhaWxzKVxuICB9XG4gIGZvciAoY29uc3QgYXJyIG9mIE9iamVjdC52YWx1ZXMocGF0aFNwZWNpZmllclRvUGF0Y2hGaWxlcykpIHtcbiAgICBhcnIuc29ydCgoYSwgYikgPT4ge1xuICAgICAgcmV0dXJuIChhLnNlcXVlbmNlTnVtYmVyID8/IDApIC0gKGIuc2VxdWVuY2VOdW1iZXIgPz8gMClcbiAgICB9KVxuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBudW1QYXRjaEZpbGVzOiBmaWxlcy5sZW5ndGgsXG4gICAgcGF0aFNwZWNpZmllclRvUGF0Y2hGaWxlcyxcbiAgICB3YXJuaW5ncyxcbiAgfVxufVxuIl19
{
"name": "patch-package",
"version": "7.0.0",
"version": "8.0.0-canary.0",
"description": "Fix broken node modules with no fuss",

@@ -5,0 +5,0 @@ "main": "dist/index.js",

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc