From d2c18aaacbee5386b7b27edd6461ccd3630bc5d7 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Rapha=C3=ABl=20Gertz?= Date: Fri, 18 Oct 2024 06:26:10 +0200 Subject: [PATCH] Add header and trailer to range command output --- Command/RangeCommand.php | 4 +++- RapsysPackBundle.php | 39 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+), 1 deletion(-) diff --git a/Command/RangeCommand.php b/Command/RangeCommand.php index 6ba5dd1..6ca6090 100644 --- a/Command/RangeCommand.php +++ b/Command/RangeCommand.php @@ -12,6 +12,7 @@ namespace Rapsys\PackBundle\Command; use Rapsys\PackBundle\Command; +use Rapsys\PackBundle\RapsysPackBundle; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputInterface; @@ -97,7 +98,8 @@ class RangeCommand extends Command { $content = preg_replace('/^(RAPSYSPACK_RANGE=.*)$/m', '#$1'."\n".strtr($string, ['\\' => '\\\\', '\\$' => '\\\\$']), $content); //Without match } else { - $content .= "\n".$string; + //Append string + $content .= (strlen($content)?"\n\n":'').'###> '.RapsysPackBundle::getBundleAlias().' ###'."\n".$string."\n".'###< '.RapsysPackBundle::getBundleAlias().' ###'; } //Write file content diff --git a/RapsysPackBundle.php b/RapsysPackBundle.php index d53a591..b013585 100644 --- a/RapsysPackBundle.php +++ b/RapsysPackBundle.php @@ -33,6 +33,45 @@ class RapsysPackBundle extends Bundle { * * @return string The bundle alias */ + public static function getBundleAlias(): string { + //With namespace + if ($npos = strrpos(static::class, '\\')) { + //Set name pos + $npos++; + + //With single namespace + $nspos = strpos(static::class, '\\'); + //Without namespace + } else { + //Set name pos + $npos = 0; + } + + //With trailing bundle + if (substr(static::class, -strlen('Bundle'), strlen('Bundle')) === 'Bundle') { + //Set bundle pos + $bpos = strlen(static::class) - $npos - strlen('Bundle'); + //Without bundle + } else { + //Set bundle pos + $bpos = strlen(static::class) - $npos; + } + + //With namespace + if ($npos) { + //Return prefixed class name + return strtolower(substr(static::class, 0, $nspos).'/'.substr(static::class, $npos, $bpos)); + } + + //Return class name + return strtolower(substr(static::class, $npos, $bpos)); + } + + /** + * Return alias + * + * @return string The alias + */ public static function getAlias(): string { //With namespace if ($npos = strrpos(static::class, '\\')) { -- 2.41.1