minor refactorings.
This commit is contained in:
34
laravel/cache/drivers/factory.php
vendored
34
laravel/cache/drivers/factory.php
vendored
@@ -1,34 +0,0 @@
|
||||
<?php namespace Laravel\Cache\Drivers;
|
||||
|
||||
use Laravel\Config;
|
||||
|
||||
class Factory {
|
||||
|
||||
/**
|
||||
* Create a new cache driver instance.
|
||||
*
|
||||
* @param string $driver
|
||||
* @return Driver
|
||||
*/
|
||||
public static function make($driver)
|
||||
{
|
||||
switch ($driver)
|
||||
{
|
||||
case 'apc':
|
||||
return new APC(Config::get('cache.key'));
|
||||
|
||||
case 'file':
|
||||
return new File(CACHE_PATH);
|
||||
|
||||
case 'memcached':
|
||||
return new Memcached(\Laravel\Memcached::instance(), Config::get('cache.key'));
|
||||
|
||||
case 'redis':
|
||||
return new Redis(\Laravel\Redis::db());
|
||||
|
||||
default:
|
||||
throw new \Exception("Cache driver {$driver} is not supported.");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
34
laravel/cache/manager.php
vendored
34
laravel/cache/manager.php
vendored
@@ -36,17 +36,39 @@ class Manager {
|
||||
|
||||
if ( ! array_key_exists($driver, static::$drivers))
|
||||
{
|
||||
if ( ! IoC::registered("laravel.cache.{$driver}"))
|
||||
{
|
||||
throw new \Exception("Cache driver [$driver] is not supported.");
|
||||
}
|
||||
|
||||
return static::$drivers[$driver] = Drivers\Factory::make($driver);
|
||||
return static::$drivers[$driver] = static::factory($driver);
|
||||
}
|
||||
|
||||
return static::$drivers[$driver];
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a new cache driver instance.
|
||||
*
|
||||
* @param string $driver
|
||||
* @return Driver
|
||||
*/
|
||||
protected static function factory($driver)
|
||||
{
|
||||
switch ($driver)
|
||||
{
|
||||
case 'apc':
|
||||
return new Drivers\APC(Config::get('cache.key'));
|
||||
|
||||
case 'file':
|
||||
return new Drivers\File(CACHE_PATH);
|
||||
|
||||
case 'memcached':
|
||||
return new Drivers\Memcached(Memcached::instance(), Config::get('cache.key'));
|
||||
|
||||
case 'redis':
|
||||
return new Drivers\Redis(Redis::db());
|
||||
|
||||
default:
|
||||
throw new \Exception("Cache driver {$driver} is not supported.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Pass all other methods to the default cache driver.
|
||||
*
|
||||
|
||||
@@ -1,29 +0,0 @@
|
||||
<?php namespace Laravel\Database\Connectors;
|
||||
|
||||
class Factory {
|
||||
|
||||
/**
|
||||
* Create a new database connector instance.
|
||||
*
|
||||
* @param string $driver
|
||||
* @return Connector
|
||||
*/
|
||||
public static function make($driver)
|
||||
{
|
||||
switch ($driver)
|
||||
{
|
||||
case 'sqlite':
|
||||
return new SQLite(DATABASE_PATH);
|
||||
|
||||
case 'mysql':
|
||||
return new MySQL;
|
||||
|
||||
case 'pgsql':
|
||||
return new Postgres;
|
||||
|
||||
default:
|
||||
throw new \Exception("Database driver [$driver] is not supported.");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@@ -65,7 +65,31 @@ class Manager {
|
||||
return call_user_func($config['connector'], $config);
|
||||
}
|
||||
|
||||
return Connectors\Factory::make($config['driver'])->connect($config);
|
||||
return static::connector($config['driver'])->connect($config);
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a new database connector instance.
|
||||
*
|
||||
* @param string $driver
|
||||
* @return Connector
|
||||
*/
|
||||
protected static function connector($driver)
|
||||
{
|
||||
switch ($driver)
|
||||
{
|
||||
case 'sqlite':
|
||||
return new Connectors\SQLite(DATABASE_PATH);
|
||||
|
||||
case 'mysql':
|
||||
return new Connectors\MySQL;
|
||||
|
||||
case 'pgsql':
|
||||
return new Connectors\Postgres;
|
||||
|
||||
default:
|
||||
throw new \Exception("Database driver [$driver] is not supported.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user