From 80486bd88c7f7173ed98b62c5a0df5b008ab9cd2 Mon Sep 17 00:00:00 2001 From: Aleksei Lebedev <1329824+LastDragon-ru@users.noreply.github.com> Date: Mon, 15 Jan 2024 11:28:03 +0400 Subject: [PATCH] fix(documentator): `requirements` command will use local `composer.json` for `HEAD`. To use the newest dependencies and avoid "Path exists on disk, but not in HEAD" git error. --- packages/documentator/src/Commands/Requirements.php | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/packages/documentator/src/Commands/Requirements.php b/packages/documentator/src/Commands/Requirements.php index 06afd41ae..99ba5b612 100644 --- a/packages/documentator/src/Commands/Requirements.php +++ b/packages/documentator/src/Commands/Requirements.php @@ -27,6 +27,7 @@ use function count; use function end; use function explode; +use function file_get_contents; use function getcwd; use function is_array; use function json_decode; @@ -45,7 +46,7 @@ description: 'Generates a table with the required versions of PHP/Laravel in Markdown format.', )] class Requirements extends Command { - public const Name = Package::Name.':requirements'; + public const Name = Package::Name.':requirements'; private const HEAD = 'HEAD'; /** @@ -175,10 +176,12 @@ protected function getPackageInfo(Git $git, string $tag, string $cwd): ?array { try { $root = Path::normalize($git->getRoot($cwd)); $path = Path::join($cwd, 'composer.json'); - $path = str_starts_with($path, $root) + $gitPath = str_starts_with($path, $root) ? mb_substr($path, mb_strlen($root) + 1) : $path; - $package = $git->getFile($path, $tag, $cwd); + $package = $tag !== self::HEAD + ? $git->getFile($gitPath, $tag, $cwd) + : (string) file_get_contents($path); $package = json_decode($package, true, flags: JSON_THROW_ON_ERROR); assert(is_array($package));