+ $where = 'CASE WHEN ' . $min . ' = \'\'
+ OR ' . $min . ' = \'[\'
+ THEN \'1.9.0\' <= \'' . $version . '\'
+ ELSE TRIM(LEADING \'[\' FROM ' . $min . ') <= \'' . $version . '\'
+ END
+ AND
+ CASE WHEN ' . $max . ' = \'\'
+ OR ' . $max . ' = \']\'
+ THEN \'99.99.99\' >= \'' . $version . '\'
+ WHEN ' . $max . ' = \')\'
+ OR ' . $max . ' = \'[\'
+ THEN \'99.99.99\' > \'' . $version . '\'
+ WHEN RIGHT(' . $max . ', 1) = \')\'
+ OR RIGHT(' . $max . ', 1) = \'[\'
+ THEN LEFT(' . $max . ', LENGTH(' . $max . ') - 1) > \'' . $version . '\'
+ ELSE LEFT(' . $max . ', LENGTH(' . $max . ') - 1) >= \'' . $version . '\'
+ END';
+ } elseif (count(explode('.', $version)) == 2) {
+ // le critere s'applique a une branche x.y unique (par exemple 1.9)
+ $where = 'LOCATE(\'' . $version . '\', ' . $table . '.branches_spip) ' . $op . ' 0';
+ }
+ } else {
+ // Le critère concerne forcément une liste de branches (la liste n'est pas disponible pour une version).
+ $branches = explode(',', $version);
+ $where_liste = '';
+ foreach ($branches as $_branche) {
+ // On vérifie qu'on est bien en présence d'une branche.
+ if (count(explode('.', $_branche)) == 2) {
+ $where_liste .= ($where_liste ? ' AND ' : '') . 'LOCATE(\'' . $_branche . '\', ' . $table . '.branches_spip) ' . $op . ' 0';
+ }
+ }
+
+ // Si non vide, on renvoie le where calculé.
+ if ($where_liste) {
+ $where = $where_liste;
+ }
+ }
+