X-Git-Url: https://git.rapsys.eu/.gitweb.cgi/packbundle/blobdiff_plain/575d559e5aea5e099ba7784547b1aa359d28fb8c..f3a69e0cab36d6aea72c072e1af929eed06953bd:/RapsysPackBundle.php?ds=sidebyside diff --git a/RapsysPackBundle.php b/RapsysPackBundle.php index c9e9ea1..b013585 100644 --- a/RapsysPackBundle.php +++ b/RapsysPackBundle.php @@ -1,9 +1,108 @@ - + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rapsys\PackBundle; +use Rapsys\PackBundle\DependencyInjection\RapsysPackExtension; + +use Symfony\Component\DependencyInjection\Extension\ExtensionInterface; use Symfony\Component\HttpKernel\Bundle\Bundle; -class RapsysPackBundle extends Bundle -{ +/** + * {@inheritdoc} + */ +class RapsysPackBundle extends Bundle { + /** + * {@inheritdoc} + */ + public function getContainerExtension(): ?ExtensionInterface { + //Return created container extension + return $this->createContainerExtension(); + } + + /** + * Return bundle alias + * + * @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, '\\')) { + //Set name pos + $npos++; + //Without namespace + } else { + $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; + } + + //Return lowercase bundle alias + return strtolower(substr(static::class, $npos, $bpos)); + } + + /** + * Return bundle version + * + * @return string The bundle version + */ + public static function getVersion(): string { + //Return version + return '0.5.1'; + } }