mail->domain || $dom == $globals->mail->domain2) { $res = XDB::query('SELECT prenom,IF(nom_usage="", nom, nom_usage), promo FROM auth_user_md5 AS u INNER JOIN aliases AS a ON u.user_id = a.id WHERE a.alias = {?}', $m); if(list($prenom, $nom, $promo) = $res->fetchOneRow()) { $key = $tri_promo ? $promo : strtoupper($nom{0}); $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $m, 'p' => (!$tri_promo ? $promo : null)); } else { $membres[0][] = Array('l' => $mem); } } else { $res = XDB::query('SELECT prenom, nom FROM groupex.membres WHERE email={?}', $mem); if (list($prenom, $nom) = $res->fetchOneRow()) { $key = $tri_promo ? 0 : strtoupper($nom{0}); $membres[$key][$nom.$m] = Array('n' => "$prenom $nom", 'l' => $mem, 'p' => (!$tri_promo ? 'non-X' : null)); } else { $membres[0][] = Array('l' => $mem, 'p' => (!$tri_promo ? 'non-X' : null)); } } } ksort($membres); foreach($membres as $key=>$val) ksort($membres[$key]); return $membres; } // }}} // {{{ function list_sort_members function list_sort_members(&$members, $tri_promo = true) { $member_list = array_map(create_function('$arr', 'return $arr[1];'), $members); return list_sort_owners($member_list, $tri_promo); } // }}} // {{{ function list_header_decode function _list_header_decode($charset, $c, $str) { $s = ($c == 'Q' || $c == 'q') ? quoted_printable_decode($str) : base64_decode($str); $s = iconv($charset, 'iso-8859-15', $s); return str_replace('_', ' ', $s); } function list_header_decode($value) { $val = preg_replace('/(=\?[^?]*\?[BQbq]\?[^?]*\?=) (=\?[^?]*\?[BQbq]\?[^?]*\?=)/', '\1\2', $value); return preg_replace('/=\?([^?]*)\?([BQbq])\?([^?]*)\?=/e', '_list_header_decode("\1", "\2", "\3")', $val); } // }}} ?>