From: Raphaƫl Gertz Date: Fri, 18 Oct 2024 04:26:10 +0000 (+0200) Subject: Add header and trailer to range command output X-Git-Tag: 0.5.2~2 X-Git-Url: https://git.rapsys.eu/packbundle/commitdiff_plain/d2c18aaacbee5386b7b27edd6461ccd3630bc5d7?ds=sidebyside Add header and trailer to range command output --- 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, '\\')) {