Vous êtes connecté en tant que anonymous Se Deconnecter
vendor/illuminate/support/Manager.php
4f5a31d2
 <?php
 
 namespace Illuminate\Support;
 
 use Closure;
 use InvalidArgumentException;
 
 abstract class Manager
 {
     /**
      * The application instance.
      *
      * @var \Illuminate\Contracts\Foundation\Application
      */
     protected $app;
 
     /**
      * The registered custom driver creators.
      *
      * @var array
      */
     protected $customCreators = [];
 
     /**
      * The array of created "drivers".
      *
      * @var array
      */
     protected $drivers = [];
 
     /**
      * Create a new manager instance.
      *
      * @param  \Illuminate\Contracts\Foundation\Application  $app
      * @return void
      */
     public function __construct($app)
     {
         $this->app = $app;
     }
 
     /**
      * Get the default driver name.
      *
      * @return string
      */
     abstract public function getDefaultDriver();
 
     /**
      * Get a driver instance.
      *
      * @param  string  $driver
      * @return mixed
      *
      * @throws \InvalidArgumentException
      */
     public function driver($driver = null)
     {
         $driver = $driver ?: $this->getDefaultDriver();
 
         if (is_null($driver)) {
             throw new InvalidArgumentException(sprintf(
                 'Unable to resolve NULL driver for [%s].', static::class
             ));
         }
 
         // If the given driver has not been created before, we will create the instances
         // here and cache it so we can return it next time very quickly. If there is
         // already a driver created by this name, we'll just return that instance.
         if (! isset($this->drivers[$driver])) {
             $this->drivers[$driver] = $this->createDriver($driver);
         }
 
         return $this->drivers[$driver];
     }
 
     /**
      * Create a new driver instance.
      *
      * @param  string  $driver
      * @return mixed
      *
      * @throws \InvalidArgumentException
      */
     protected function createDriver($driver)
     {
         // First, we will determine if a custom driver creator exists for the given driver and
         // if it does not we will check for a creator method for the driver. Custom creator
         // callbacks allow developers to build their own "drivers" easily using Closures.
         if (isset($this->customCreators[$driver])) {
             return $this->callCustomCreator($driver);
         } else {
             $method = 'create'.Str::studly($driver).'Driver';
 
             if (method_exists($this, $method)) {
                 return $this->$method();
             }
         }
         throw new InvalidArgumentException("Driver [$driver] not supported.");
     }
 
     /**
      * Call a custom driver creator.
      *
      * @param  string  $driver
      * @return mixed
      */
     protected function callCustomCreator($driver)
     {
         return $this->customCreators[$driver]($this->app);
     }
 
     /**
      * Register a custom driver creator Closure.
      *
      * @param  string    $driver
      * @param  \Closure  $callback
      * @return $this
      */
     public function extend($driver, Closure $callback)
     {
         $this->customCreators[$driver] = $callback;
 
         return $this;
     }
 
     /**
      * Get all of the created "drivers".
      *
      * @return array
      */
     public function getDrivers()
     {
         return $this->drivers;
     }
 
     /**
      * Dynamically call the default driver instance.
      *
      * @param  string  $method
      * @param  array   $parameters
      * @return mixed
      */
     public function __call($method, $parameters)
     {
         return $this->driver()->$method(...$parameters);
     }
 }