]> Raphaƫl G. Git Repositories - packbundle/blobdiff - RapsysPackBundle.php
Version 0.5.2
[packbundle] / RapsysPackBundle.php
index 260ce22420a1ecc50f1f57ae2453b4a68586378c..8de9fa3a280b61b8082044ba826e22e2ffac5fda 100644 (file)
 
 namespace Rapsys\PackBundle;
 
+use Rapsys\PackBundle\DependencyInjection\RapsysPackExtension;
+
+use Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
 use Symfony\Component\HttpKernel\Bundle\Bundle;
 
 /**
  * {@inheritdoc}
  */
-class RapsysPackBundle extends Bundle {}
+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.2';
+       }
+}