From fbaf263fcaefe3c6db97c5d18cde43bc832e04a5 Mon Sep 17 00:00:00 2001 From: woutersioen Date: Thu, 19 Mar 2020 12:01:06 +0100 Subject: [PATCH] Cache the output of the retrieved data This makes sure we can call these retrieves in loops without huge performance changes. --- src/Composer/DependencyTreeRetriever.php | 10 +++++++++- src/Composer/UsedLicensesRetriever.php | 10 +++++++++- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/src/Composer/DependencyTreeRetriever.php b/src/Composer/DependencyTreeRetriever.php index 58dae90..7ca8880 100644 --- a/src/Composer/DependencyTreeRetriever.php +++ b/src/Composer/DependencyTreeRetriever.php @@ -7,8 +7,14 @@ class DependencyTreeRetriever { + private static $output; + public function getDependencyTree(): string { + if (!is_null(self::$output)) { + return self::$output; + } + $process = new Process(['composer', 'show', '-t', '-f', 'json']); $process->run(); @@ -16,6 +22,8 @@ public function getDependencyTree(): string throw new ProcessFailedException($process); } - return $process->getOutput(); + self::$output = $process->getOutput(); + + return self::$output; } } diff --git a/src/Composer/UsedLicensesRetriever.php b/src/Composer/UsedLicensesRetriever.php index 12144db..3742b88 100644 --- a/src/Composer/UsedLicensesRetriever.php +++ b/src/Composer/UsedLicensesRetriever.php @@ -7,8 +7,14 @@ class UsedLicensesRetriever { + private static $output; + public function getComposerLicenses(): string { + if (!is_null(self::$output)) { + return self::$output; + } + $process = new Process(['composer', 'license', '-f', 'json']); $process->run(); @@ -16,6 +22,8 @@ public function getComposerLicenses(): string throw new ProcessFailedException($process); } - return $process->getOutput(); + self::$output = $process->getOutput(); + + return self::$output; } }