X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Farrays.php;h=a469905bcf03f004c3394c439f0beb9c38542b6f;hp=30df6f142e224308e1baeb484312e40834f62ab8;hb=5a56fd2877a5549ec39db5eb73c18659732a09c6;hpb=4b4abf93a9624311afef0c385023724ee46a2b60 diff --git a/functions/arrays.php b/functions/arrays.php index 30df6f14..a469905b 100644 --- a/functions/arrays.php +++ b/functions/arrays.php @@ -5,7 +5,7 @@ * * Contains utility functions for array operations * - * @copyright © 2004-2005 The SquirrelMail Project Team + * @copyright © 2004-2007 The SquirrelMail Project Team * @license http://opensource.org/licenses/gpl-license.php GNU Public License * @version $Id$ * @package squirrelmail @@ -40,7 +40,7 @@ * @param array $a (recursive) array * @param mixed $v value to move * @param int $p positions to move - * @return bool $succes + * @return bool $success * @author Marc Groot Koerkamp */ function sqm_array_kmove_value(&$a,$v,$p) { @@ -73,7 +73,7 @@ function sqm_array_kmove_value(&$a,$v,$p) { * @param array $a (recursive) array * @param mixed $v value to move * @param int $p positions to move - * @return bool $succes + * @return bool $success * @author Marc Groot Koerkamp */ function sqm_array_move_value(&$a,$v,$p) { @@ -122,7 +122,7 @@ if (!function_exists('array_combine')) { * * @param array $aK array keys * @param array $aV array values - * @return mixed $r combined array on succes, false on failure + * @return mixed $r combined array on success, false on failure * @author Marc Groot Koerkamp */ function array_combine($aK, $aV) { @@ -138,4 +138,66 @@ if (!function_exists('array_combine')) { } return $r; } -} \ No newline at end of file +} + + + /** + * Merges two variables into a single array + * + * Similar to PHP array_merge function, but provides same + * functionality as array_merge without losing array values + * with same key names. If the values under identical array + * keys are both strings and $concat_strings is TRUE, those + * values are concatenated together, otherwise they are placed + * in a sub-array and are merged (recursively) in the same manner. + * + * If either of the elements being merged is not an array, + * it will simply be added to the returned array. + * + * If both values are strings and $concat_strings is TRUE, + * a concatenated string is returned instead of an array. + * + * @param mixed $a First element to be merged + * @param mixed $b Second element to be merged + * @param boolean $concat_strings Whether or not string values + * should be concatenated instead + * of added to different array + * keys (default TRUE) + * + * @return array The merged $a and $b in one array + * + * @since 1.5.2 + * @author Paul Lesniewski + * + */ +function sqm_array_merge($a, $b, $concat_strings=true) { + + $ret = array(); + + if (is_array($a)) { + $ret = $a; + } else { + if (is_string($a) && is_string($b) && $concat_strings) { + return $a . $b; + } + $ret[] = $a; + } + + + if (is_array($b)) { + foreach ($b as $key => $value) { + if (isset($ret[$key])) { + $ret[$key] = sqm_array_merge($ret[$key], $value, $concat_strings); + } else { + $ret[$key] = $value; + } + } + } else { + $ret[] = $b; + } + + return $ret; + +} + +