8,19 → 8,19 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org> |
* @copyright Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org) |
* @license http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3 |
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2 |
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2 |
* @version $Id$ |
* @link /doc/framework/ |
*/ |
class Tableau { |
|
|
/** |
* Etend le tableau à étendre avec les données du tableau à copier. Si des clés sont identiques entre les deux tableaux |
* une erreur est déclenchée et la valeur du tableau à étendre est gardée. Si les deux tableaux ont des clés numériques |
* une erreur est déclenchée et la valeur du tableau à étendre est gardée. Si les deux tableaux ont des clés numériques |
* leurs valeurs sont gardées (à la différence de array_merge). |
* Les tableaux sont passés par références et le tableau à copier est progressivement détruit pour éviter la consomation |
* de mémoire. |
* |
* |
* @param array $tableau_a_etendre |
* @param array $tableau_a_copier |
* @return void |
40,7 → 40,7 |
trigger_error($e, E_USER_WARNING); |
} |
} |
|
|
/** |
* @deprecated Utiliser la méthode trierMD() |
* @see trierMD() |
48,10 → 48,10 |
public static function trierTableauMd($array, $cols) { |
return self::trierMD($array, $cols); |
} |
|
|
/** |
* Permet de trier un tableau multi-dimenssionnel en gardant l'ordre des clés. |
* |
* |
* @param Array $array le tableau à trier |
* @param Array $cols tableau indiquant en clé la colonne à trier et en valeur l'ordre avec SORT_ASC ou SORT_DESC |
* @return Array le tableau trié. |
69,7 → 69,10 |
$params = array(); |
foreach ($cols as $col => $order) { |
$params[] =& $colarr[$col]; |
$params = array_merge($params, (array)$order); |
$orders = (array) $order; |
foreach($orders as $orderElement) { |
$params[] =& $orderElement; |
} |
} |
call_user_func_array('array_multisort', $params); |
$ret = array(); |