diff options
author | Andrey Andreev <narf@devilix.net> | 2014-02-19 22:49:31 +0100 |
---|---|---|
committer | Andrey Andreev <narf@devilix.net> | 2014-02-19 22:49:31 +0100 |
commit | 02545895c1c6551be3b167bcada171fe9423d443 (patch) | |
tree | 5b20681d01f237602d45f93d06ec59c772f19569 /system/core | |
parent | e75255684d55fa075dcc7c03274c41201825d430 (diff) |
Add compatibility layer for array_column(), array_replace(), array_replace_recursive()
Diffstat (limited to 'system/core')
-rw-r--r-- | system/core/CodeIgniter.php | 1 | ||||
-rw-r--r-- | system/core/Common.php | 2 | ||||
-rw-r--r-- | system/core/compat/array.php | 246 |
3 files changed, 248 insertions, 1 deletions
diff --git a/system/core/CodeIgniter.php b/system/core/CodeIgniter.php index 2bdd76463..eb3927e47 100644 --- a/system/core/CodeIgniter.php +++ b/system/core/CodeIgniter.php @@ -191,6 +191,7 @@ defined('BASEPATH') OR exit('No direct script access allowed'); require_once(BASEPATH.'core/compat/mbstring.php'); require_once(BASEPATH.'core/compat/hash.php'); require_once(BASEPATH.'core/compat/password.php'); + require_once(BASEPATH.'core/compat/array.php'); /* * ------------------------------------------------------ diff --git a/system/core/Common.php b/system/core/Common.php index c83d80a3d..7591cd794 100644 --- a/system/core/Common.php +++ b/system/core/Common.php @@ -587,7 +587,7 @@ if ( ! function_exists('_exception_handler')) if ($is_error) { set_status_header(500); - } + } // Should we ignore the error? We'll get the current error_reporting // level and add its bits with the severity bits to find out. diff --git a/system/core/compat/array.php b/system/core/compat/array.php new file mode 100644 index 000000000..b291703ed --- /dev/null +++ b/system/core/compat/array.php @@ -0,0 +1,246 @@ +<?php +/** + * CodeIgniter + * + * An open source application development framework for PHP 5.2.4 or newer + * + * NOTICE OF LICENSE + * + * Licensed under the Open Software License version 3.0 + * + * This source file is subject to the Open Software License (OSL 3.0) that is + * bundled with this package in the files license.txt / license.rst. It is + * also available through the world wide web at this URL: + * http://opensource.org/licenses/OSL-3.0 + * If you did not receive a copy of the license and are unable to obtain it + * through the world wide web, please send an email to + * licensing@ellislab.com so we can send you a copy immediately. + * + * @package CodeIgniter + * @author EllisLab Dev Team + * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (http://ellislab.com/) + * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) + * @link http://codeigniter.com + * @since Version 3.0 + * @filesource + */ +defined('BASEPATH') OR exit('No direct script access allowed'); + +/** + * PHP ext/standard/array compatibility package + * + * @package CodeIgniter + * @subpackage CodeIgniter + * @category Compatibility + * @author Andrey Andreev + * @link http://codeigniter.com/user_guide/ + * @link http://php.net/book.array + */ + +// ------------------------------------------------------------------------ + +if (is_php('5.5')) +{ + return; +} + +// ------------------------------------------------------------------------ + +if ( ! function_exists('array_column')) +{ + /** + * array_column() + * + * @link http://php.net/array_column + * @param string $array + * @param mixed $column_key + * @param mixed $index_key + * @return array + */ + function array_column(array $array, $column_key, $index_key = NULL) + { + if ( ! in_array($type = gettype($column_key), array('integer', 'string', 'NULL'), TRUE)) + { + if ($type === 'double') + { + $column_key = (int) $column_key; + } + elseif ($type === 'object' && method_exists($column_key, '__toString')) + { + $column_key = (string) $column_key; + } + else + { + trigger_error('array_column(): The column key should be either a string or an integer', E_USER_WARNING); + return FALSE; + } + } + + if ( ! in_array($type = gettype($index_key), array('integer', 'string', 'NULL'), TRUE)) + { + if ($type === 'double') + { + $index_key = (int) $index_key; + } + elseif ($type === 'object' && method_exists($index_key, '__toString')) + { + $index_key = (string) $index_key; + } + else + { + trigger_error('array_column(): The index key should be either a string or an integer', E_USER_WARNING); + return FALSE; + } + } + + $result = array(); + foreach ($array as &$a) + { + if ($column_key === NULL) + { + $value = $a; + } + elseif (is_array($a) && array_key_exists($column_key, $a)) + { + $value = $a[$column_key]; + } + else + { + continue; + } + + if ($index_key === NULL OR ! array_key_exists($index_key, $a)) + { + $result[] = $value; + } + else + { + $result[$a[$index_key]] = $value; + } + } + + return $result; + } +} + +// ------------------------------------------------------------------------ + +if (is_php('5.3')) +{ + return; +} + +// ------------------------------------------------------------------------ + +if ( ! function_exists('array_replace')) +{ + /** + * array_replace() + * + * @link http://php.net/array_replace + * @return array + */ + function array_replace() + { + $arrays = func_get_args(); + + if (($c = count($arrays)) === 0) + { + trigger_error('array_replace() expects at least 1 parameter, 0 given', E_USER_WARNING); + return NULL; + } + elseif ($c === 1) + { + if ( ! is_array($arrays[0])) + { + trigger_error('array_replace(): Argument #1 is not an array', E_USER_WARNING); + return NULL; + } + + return $arrays[0]; + } + + $array = array_shift($arrays); + $c--; + + for ($i = 0, $c = count($arrays); $i < $c; $i++) + { + if ( ! is_array($arrays[$i])) + { + trigger_error('array_replace(): Argument #'.($i + 2).' is not an array', E_USER_WARNING); + return NULL; + } + elseif (empty($arrays[$i])) + { + continue; + } + + foreach (array_keys($arrays[$i]) as $key) + { + $array[$key] = $arrays[$i][$key]; + } + } + + return $array; + } +} + +// ------------------------------------------------------------------------ + +if ( ! function_exists('array_replace_recursive')) +{ + /** + * array_replace_recursive() + * + * @link http://php.net/array_replace_recursive + * @return array + */ + function array_replace_recursive() + { + $arrays = func_get_args(); + + if (($c = count($arrays)) === 0) + { + trigger_error('array_replace_recursive() expects at least 1 parameter, 0 given', E_USER_WARNING); + return NULL; + } + elseif ($c === 1) + { + if ( ! is_array($arrays[0])) + { + trigger_error('array_replace_recursive(): Argument #1 is not an array', E_USER_WARNING); + return NULL; + } + + return $arrays[0]; + } + + $array = array_shift($arrays); + $c--; + + for ($i = 0, $c = count($arrays); $i < $c; $i++) + { + if ( ! is_array($arrays[$i])) + { + trigger_error('array_replace_recursive(): Argument #'.($i + 2).' is not an array', E_USER_WARNING); + return NULL; + } + elseif (empty($arrays[$i])) + { + continue; + } + + foreach (array_keys($arrays[$i]) as $key) + { + $array[$key] = (is_array($arrays[$i][$key]) && isset($array[$key]) && is_array($array[$key])) + ? array_replace_recursive($array[$key], $arrays[$i][$key]) + : $arrays[$i][$key]; + } + } + + return $array; + } +} + +/* End of file array.php */ +/* Location: ./system/core/compat/array.php */
\ No newline at end of file |