Update of /home/spip-cvs/spip
In directory alan:/tmp/cvs-serv11537
Modified Files:
inc-calcul.php3
Log Message:
fonctions d'abstraction dans un fichier séparé
Index: inc-calcul.php3
RCS file: /home/spip-cvs/spip/inc-calcul.php3,v
retrieving revision 1.117
retrieving revision 1.118
diff -u -d -r1.117 -r1.118
--- inc-calcul.php3 10 Oct 2004 07:02:33 -0000 1.117
+++ inc-calcul.php3 22 Oct 2004 08:49:24 -0000 1.118
@@ -14,6 +14,7 @@
include_ecrire("inc_filtres.php3");
include_ecrire("inc_lang.php3");
include_ecrire("inc_documents.php3");
+include_ecrire("inc_abstract_sql.php3");
include_local("inc-forum.php3");
include_local("inc-calcul-outils.php3");
include_local("inc-admin.php3");
@@ -270,99 +271,4 @@
return $page;
}
-
-
-## tout ce qui suit devrait etre ailleurs : ecrire/inc_db_(mysql|pgsql).php3
-// Cette fonction est systematiquement appelee par les squelettes
-// pour constuire une requete SQL de type "lecture" (SELECT) a partir
-// de chaque boucle.
-// Elle construit et exe'cute une reque^te SQL correspondant a` une balise
-// Boucle ; elle notifie une erreur SQL dans le flux de sortie et termine
-// le processus.
-// Sinon, retourne la ressource interrogeable par spip_abstract_fetch.
-// Recoit en argument:
-// - le tableau des champs a` ramener
-// - le tableau des tables a` consulter
-// - le tableau des conditions a` remplir
-// - le crite`re de regroupement
-// - le crite`re de classement
-// - le crite`re de limite
-// - une sous-requete e'ventuelle (MySQL > 4.1)
-// - un compteur de sous-requete
-// - le nom de la table
-// - le nom de la boucle (pour le message d'erreur e'ventuel)
-// - le serveur sollicite
-
-function spip_abstract_select (
- $select = array(), $from = array(), $where = '',
- $groupby = '', $orderby = '', $limit = '',
- $sousrequete = '', $cpt = '',
- $table = '', $id = '', $serveur='') {
-
- if (!$serveur)
- // le serveur par defaut est celui de inc_connect.php
- // tout est deja pret, notamment la fonction suivante:
- $f = 'spip_mysql_select';
- else {
- // c'est un autre; est-il deja charge ?
- $f = 'spip_' . $serveur . '_select';
- if (!function_exists($f)) {
- // non, il est decrit dans le fichier ad hoc
- $d = 'inc_connect-' . $serveur .'.php3';
- if (@file_exists('ecrire/' . $d))
- include_ecrire($d);
- $f = spip_abstract_serveur($f, $serveur);
- }
- }
- return $f($select, $from, $where,
- $groupby, $orderby, $limit,
- $sousrequete, $cpt,
- $table, $id, $serveur);
-}
-
-function spip_abstract_serveur($f, $serveur) {
- if (function_exists($f))
- return $f;
-
- erreur_squelette(_L(' serveur SQL indefini'), $serveur);
-
- // hack pour continuer la chasse aux erreurs
- return 'array';
-}
-
-// Les 3 fonctions suivantes exploitent le resultat de la precedente,
-// si l'include ne les a pas definies, erreur immediate
-
-function spip_abstract_fetch($res, $serveur='')
-{
- if (!$serveur) return spip_fetch_array($res);
- $f = spip_abstract_serveur('spip_' . $serveur . '_fetch', $serveur);
- return $f($res);
-}
-
-function spip_abstract_count($res, $serveur='')
-{
- if (!$serveur) return spip_num_rows($res);
- $f = spip_abstract_serveur('spip_' . $serveur . '_count', $serveur);
- return $f($res);
-}
-
-function spip_abstract_free($res, $serveur='')
-{
- if (!$serveur) return spip_free_result($res);
- $f = spip_abstract_serveur('spip_' . $serveur . '_free', $serveur);
- return $f($res);
-}
-
-# une composition tellement frequente...
-function spip_abstract_fetsel(
- $select = array(), $from = array(), $where = '',
- $groupby = '', $orderby = '', $limit = '',
- $sousrequete = '', $cpt = '',
- $table = '', $id = '', $serveur='') {
- return spip_abstract_fetch(spip_abstract_select(
-$select, $from, $where, $groupby, $orderby, $limit,
-$sousrequete, $cpt, $table, $id, $serveur),
- $serveur);
-}
?>