From 6eb8577737db27a196749fc9058befd1d771819c Mon Sep 17 00:00:00 2001 From: Sebastian Bergmann Date: Sun, 19 Jun 2022 13:19:14 +0200 Subject: [PATCH] Eliminate code duplication --- build/scripts/phar-manifest.php | 56 +++++++++++++++++++-------------- 1 file changed, 32 insertions(+), 24 deletions(-) diff --git a/build/scripts/phar-manifest.php b/build/scripts/phar-manifest.php index 1d37f263fd4..994e5322379 100755 --- a/build/scripts/phar-manifest.php +++ b/build/scripts/phar-manifest.php @@ -29,13 +29,14 @@ function manifest(string $outputFilename, array $package, string $version, array ); foreach ($dependencies as $dependency) { - $buffer .= $dependency['name'] . ': ' . $dependency['version']; - - if (!preg_match('/^[v= ]*(([0-9]+)(\\.([0-9]+)(\\.([0-9]+)(-([0-9]+))?(-?([a-zA-Z-+][a-zA-Z0-9.\\-:]*)?)?)?)?)$/', $dependency['version'])) { - $buffer .= '@' . $dependency['source']['reference']; - } - - $buffer .= "\n"; + $buffer .= sprintf( + '%s: %s' . "\n", + $dependency['name'], + versionWithReference( + $dependency['version'], + $dependency['source']['reference'] + ) + ); } file_put_contents($outputFilename, $buffer); @@ -64,18 +65,16 @@ function sbom(string $outputFilename, array $package, string $version, array $de ); foreach ($dependencies as $dependency) { - [$group, $name] = explode('/', $dependency['name']); - $dependencyVersion = $dependency['version']; - - if (!preg_match('/^[v= ]*(([0-9]+)(\\.([0-9]+)(\\.([0-9]+)(-([0-9]+))?(-?([a-zA-Z-+][a-zA-Z0-9.\\-:]*)?)?)?)?)$/', $dependencyVersion)) { - $dependencyVersion .= '@' . $dependency['source']['reference']; - } + [$group, $name] = explode('/', $dependency['name']); writeComponent( $writer, $group, $name, - $dependencyVersion, + versionWithReference( + $dependency['version'], + $dependency['source']['reference'] + ), $dependency['description'], $dependency['license'] ); @@ -88,16 +87,6 @@ function sbom(string $outputFilename, array $package, string $version, array $de file_put_contents($outputFilename, $writer->outputMemory()); } -function dependencies(): array -{ - return json_decode( - file_get_contents( - __DIR__ . '/../../composer.lock' - ), - true - )['packages']; -} - function package(): array { $data = json_decode( @@ -131,6 +120,25 @@ function version(): string return $branch . '@' . $hash; } +function dependencies(): array +{ + return json_decode( + file_get_contents( + __DIR__ . '/../../composer.lock' + ), + true + )['packages']; +} + +function versionWithReference(string $version, string $reference): string +{ + if (!preg_match('/^[v= ]*(([0-9]+)(\\.([0-9]+)(\\.([0-9]+)(-([0-9]+))?(-?([a-zA-Z-+][a-zA-Z0-9.\\-:]*)?)?)?)?)$/', $version)) { + $version .= '@' . $reference; + } + + return $version; +} + function writeComponent(XMLWriter $writer, string $group, string $name, string $version, string $description, array $licenses): void { $writer->startElement('component');