Commit a7e98e8e by Taylor Otwell

fixing bugs and refactoring.

parent b40e69c4
...@@ -3,20 +3,20 @@ ...@@ -3,20 +3,20 @@
class Config { class Config {
/** /**
* The paths to the configuration files. * All of the loaded configuration items.
*
* The configuration arrays are keyed by their owning file name.
* *
* @var array * @var array
*/ */
public static $paths = array(SYS_CONFIG_PATH, CONFIG_PATH); public static $items = array();
/** /**
* All of the loaded configuration items. * The paths to the configuration files.
*
* The configuration arrays are keyed by their owning file name.
* *
* @var array * @var array
*/ */
public static $items = array(); public static $paths = array(SYS_CONFIG_PATH, CONFIG_PATH);
/** /**
* Determine if a configuration item or file exists. * Determine if a configuration item or file exists.
...@@ -114,9 +114,14 @@ class Config { ...@@ -114,9 +114,14 @@ class Config {
{ {
$segments = explode('.', $key); $segments = explode('.', $key);
$key = (count($segments) > 1) ? implode('.', array_slice($segments, 1)) : null; if (count($segments) >= 2)
{
return array($segments[0], $key); return array($segments[0], implode('.', array_slice($segments, 1)));
}
else
{
return array($segments[0], null);
}
} }
/** /**
......
...@@ -71,7 +71,7 @@ class Cookie { ...@@ -71,7 +71,7 @@ class Cookie {
* *
* If a negative number of minutes is specified, the cookie will be deleted. * If a negative number of minutes is specified, the cookie will be deleted.
* *
* Note: This method's signature is very similar to the PHP setcookie method. * This method's signature is very similar to the PHP setcookie method.
* However, you simply need to pass the number of minutes for which you * However, you simply need to pass the number of minutes for which you
* wish the cookie to be valid. No funky time calculation is required. * wish the cookie to be valid. No funky time calculation is required.
* *
......
...@@ -43,7 +43,9 @@ class Form { ...@@ -43,7 +43,9 @@ class Form {
*/ */
public static function open($action = null, $method = 'POST', $attributes = array(), $https = false) public static function open($action = null, $method = 'POST', $attributes = array(), $https = false)
{ {
list($attributes['action'], $attributes['method']) = array(static::action($action, $https), static::method($method)); $attributes['action'] = static::action($action, $https);
$attributes['method'] = static::method($method);
if ( ! array_key_exists('accept-charset', $attributes)) if ( ! array_key_exists('accept-charset', $attributes))
{ {
...@@ -433,7 +435,9 @@ class Form { ...@@ -433,7 +435,9 @@ class Form {
*/ */
protected static function checkable($type, $name, $value, $checked, $attributes) protected static function checkable($type, $name, $value, $checked, $attributes)
{ {
$attributes = array_merge($attributes, array('id' => static::id($name, $attributes), 'checked' => ($checked) ? 'checked' : null)); if ($checked) $attributes['checked'] = 'checked';
$attributes['id'] = static::id($name, $attributes);
return static::input($type, $name, $value, $attributes); return static::input($type, $name, $value, $attributes);
} }
...@@ -508,9 +512,15 @@ class Form { ...@@ -508,9 +512,15 @@ class Form {
*/ */
protected static function id($name, $attributes) protected static function id($name, $attributes)
{ {
if (array_key_exists('id', $attributes)) return $attributes['id']; if (array_key_exists('id', $attributes))
{
return $attributes['id'];
}
if (in_array($name, static::$labels)) return $name; if (in_array($name, static::$labels))
{
return $name;
}
} }
} }
\ No newline at end of file
...@@ -7,7 +7,7 @@ class Input { ...@@ -7,7 +7,7 @@ class Input {
* *
* @var array * @var array
*/ */
protected static $input; public static $input;
/** /**
* The key used to store old input in the session. * The key used to store old input in the session.
...@@ -17,17 +17,6 @@ class Input { ...@@ -17,17 +17,6 @@ class Input {
const old_input = 'laravel_old_input'; const old_input = 'laravel_old_input';
/** /**
* Set the input for the current request.
*
* @param array $input
* @return void
*/
public static function set($input)
{
static::$input = $input;
}
/**
* Get all of the input data for the request. * Get all of the input data for the request.
* *
* This method returns a merged array containing Input::get() and Input::files(). * This method returns a merged array containing Input::get() and Input::files().
......
...@@ -72,7 +72,7 @@ class Lang { ...@@ -72,7 +72,7 @@ class Lang {
*/ */
public static function line($key, $replacements = array(), $language = null) public static function line($key, $replacements = array(), $language = null)
{ {
if (is_null($language)) $language = Config::get('application.language'); if (is_null($language)) $language = Config::$items['application']['language'];
return new static($key, $replacements, $language); return new static($key, $replacements, $language);
} }
......
...@@ -78,7 +78,7 @@ switch (Request::method()) ...@@ -78,7 +78,7 @@ switch (Request::method())
*/ */
unset($input[Request::spoofer]); unset($input[Request::spoofer]);
Input::set($input); Input::$input = $input;
/** /**
* Route the request to the proper route in the application. If a * Route the request to the proper route in the application. If a
...@@ -88,7 +88,7 @@ Input::set($input); ...@@ -88,7 +88,7 @@ Input::set($input);
*/ */
Routing\Filter::register(require APP_PATH.'filters'.EXT); Routing\Filter::register(require APP_PATH.'filters'.EXT);
list($method, $uri) = array(Request::method(), Request::uri()); list($uri, $method) = array(Request::uri(), Request::method());
$route = IoC::container()->core('routing.router')->route($method, $uri); $route = IoC::container()->core('routing.router')->route($method, $uri);
......
...@@ -188,9 +188,28 @@ class Str { ...@@ -188,9 +188,28 @@ class Str {
*/ */
public static function random($length, $type = 'alnum') public static function random($length, $type = 'alnum')
{ {
$pool = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; return substr(str_shuffle(str_repeat(static::pool($type), 5)), 0, $length);
}
return substr(str_shuffle(str_repeat(($type == 'alnum') ? $pool.'0123456789' : $pool, 5)), 0, $length); /**
* Get the character pool for a given type of random string.
*
* @param string $type
* @return string
*/
protected static function pool($type)
{
switch ($type)
{
case 'alpha':
return 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
case 'alnum':
return '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
default:
throw new \Exception("Invalid random string type [$type].");
}
} }
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment