* @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:----bkGLsEurPJZyXhvQ8w/JD8lwYYGugu10c8iT1nCUUbDh2NXD3Qfim/dUS2sZ3Oky2IWFtag5cuOJuMatN+7iv6ioPCMKoM35NOSqxANPqMN9LVdvub+2/pqdjAr6ydsWC9+s4iMOQqzY9llwJoouOUjJfbbHWLU93Epcoj/j69fXtp9+up/XzuBbOGk5Frte4sKWhQSNCkOx/04/kXeW9GHdF+WBhnUX3RJeUSFbiOdJAeLW+bn8XuAUmm/hE1z5jCCg+jXBKpBzJA/Wsr+FUNErms1NQZ7ENzcO+22WHTYDW+dTyjNykEOZZJQDl9+FTmYob4jhdUJIoD25VqQ0SHLOK64gAWVKeOUbpgbbWF9G6E2gr9g+qAARP1G0cKNtGqpoFfwhRD6fVrtqo06HbUsq4NsIRn09GOeIO+HUZ6DYYOjITxxjbkS2AaxSycVz+c6bTnKwW33Lh0v6Cogj1GsfXeNwUOLX8pji6BrBKvqi6Z5HiSNEsgx4gMUU8tZGJGB/TSs+9uZaN5cd11oSfTD+JOYfgOrbEsklCaKB9BKOg+dnur7LsOIB4jYl01kGPioEzRJQR/koByA8qwKM+mIrZWiIPz7pZ1I5RlI1QPvcwHuEvw+NnFXrxYAH0KhNZT0s/s/5F+/vXDObd8U6KMN3T0S4hi/Myai9B7e9YZI=----ATTACHMENT:----NTg1Njk1NjM1ODIyNTA3NSA2NDYzNzAxMDc2MjUzNjk4IDMwMDY5MDMwMTQ4Njk3MzQ=