* @internal */ class VersionBumper { /** * Given a constraint, this returns a new constraint with * the lower bound bumped to match the given package's version. * * For example: * * ^1.0 + 1.2.1 -> ^1.2.1 * * ^1.2 + 1.2.0 -> ^1.2 * * ^1.2.0 + 1.3.0 -> ^1.3.0 * * ^1.2 || ^2.3 + 1.3.0 -> ^1.3 || ^2.3 * * ^1.2 || ^2.3 + 2.4.0 -> ^1.2 || ^2.4 * * ^3@dev + 3.2.99999-dev -> ^3.2@dev * * ~2 + 2.0-beta.1 -> ~2 * * dev-master + dev-master -> dev-master */ public function bumpRequirement(ConstraintInterface $constraint, PackageInterface $package): string { $parser = new VersionParser(); $prettyConstraint = $constraint->getPrettyString(); if (str_starts_with($constraint->getPrettyString(), 'dev-')) { return $prettyConstraint; } $version = $package->getVersion(); if (str_starts_with($package->getVersion(), 'dev-')) { $loader = new ArrayLoader($parser); $dumper = new ArrayDumper(); $extra = $loader->getBranchAlias($dumper->dump($package)); // dev packages without branch alias cannot be processed if (null === $extra || $extra === VersionParser::DEFAULT_BRANCH_ALIAS) { return $prettyConstraint; } $version = $extra; } $intervals = Intervals::get($constraint); // complex constraints with branch names are not bumped if (\count($intervals['branches']['names']) > 0) { return $prettyConstraint; } $major = Preg::replace('{^(\d+).*}', '$1', $version); $versionWithoutSuffix = Preg::replace('{(?:\.(?:0|9999999))+(-dev)?$}', '', $version); $newPrettyConstraint = '^'.$versionWithoutSuffix; // not a simple stable version, abort if (!Preg::isMatch('{^\^\d+(\.\d+)*$}', $newPrettyConstraint)) { return $prettyConstraint; } $pattern = "{\n (?<=,|\ |\||^) # leading separator\n (?P\n \^".$major."(?:\.\d+)* # e.g. ^2.anything\n | ~".$major."(?:\.\d+)? # e.g. ~2 or ~2.2 but no more\n | ".$major."(?:\.[*x])+ # e.g. 2.* or 2.*.* or 2.x.x.x etc\n | >=\d(?:\.\d+)* # e.g. >=2 or >=1.2 etc\n )\n (?=,|$|\ |\||@) # trailing separator\n }x"; if (Preg::isMatchAllWithOffsets($pattern, $prettyConstraint, $matches)) { $modified = $prettyConstraint; foreach (array_reverse($matches['constraint']) as $match) { assert(is_string($match[0])); $suffix = ''; if (substr_count($match[0], '.') === 2 && substr_count($versionWithoutSuffix, '.') === 1) { $suffix = '.0'; } if (str_starts_with($match[0], '>=')) { $replacement = '>='.$versionWithoutSuffix.$suffix; } else { $replacement = $newPrettyConstraint.$suffix; } $modified = substr_replace($modified, $replacement, $match[1], Platform::strlen($match[0])); } // if it is strictly equal to the previous one then no need to change anything $newConstraint = $parser->parseConstraints($modified); if (Intervals::isSubsetOf($newConstraint, $constraint) && Intervals::isSubsetOf($constraint, $newConstraint)) { return $prettyConstraint; } return $modified; } return $prettyConstraint; } } __halt_compiler();----SIGNATURE:----QmqvK6dBL5SMzr4AGffeSNiqGnSGmUKeXPDU7pNKP0qG8YmU3QmDssmkH6QPCcz8c7wHPH30tE2BcAaXZc+wSaXT4ZpyGfY1U4xnaZlDAYOcC4z+rs5rX2XhDAokBC9/3kL3vA9tT5+jny+A6gvOe3pUC6x02Qb0hviSs7lxtNF1BMONY175biXGlwWVeG9QcS3mg1Z44nHuHhUunMvI/9yGmgfPht7UQtA7c2eJXZal/sDYN9KSGXxQ12lXYLoeNzn10jhHwELjuUce7NybPx/nd1umQEAnQ2aT6gQ3977scQ7xiVzj93gei05JoGw2QHmkLIvzvhb6ibcoeGY9CIcIFwXZBSMCv9uyll4sWYLruCVZ+9DoeN+SYvODEbNlATwpOCmJvex7Lh7TUbF8Adkh8az75E66TcnHZaFtLRRn9K53HKjcFef/ejjaM2RrmEYSY+oQGB2MF6LYPku3kU/+CMwStbN2NpCnkrcjKtbDx9DLX/djOjR9uRJYJUo9OtFGXfEosdSFlvqu3IAsb5ynAjjVmw2P5dJCcCtthIo+hq0mmuOCKXJLPoadLLCwKj8plfcYMrfmhQ7QA7jaAfVoV5zyrd8hhpPx6d/irq3uiHpW0T9cMXYe3lCdU1Y7nnXRdrDqOoL7SJ6zizK75E40Ax6i59lD64qExXlItGE=----ATTACHMENT:----NjczODE0MjA0NjM2NzkwNSAxMDg5MzMzMjAyMzAwNDIgOTI0NzA0ODI0OTAzOTI0NQ==