Subversion Repositories Sites.tela-botanica.org

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
4 david 1
<?php
2
 
3
/***************************************************************************\
4
 *  SPIP, Systeme de publication pour l'internet                           *
5
 *                                                                         *
6
 *  Copyright (c) 2001-2005                                                *
7
 *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
8
 *                                                                         *
9
 *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
10
 *  Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne.   *
11
\***************************************************************************/
12
 
13
 
14
// Ce fichier ne sera execute qu'une fois
15
if (defined("_INC_ABSTRACT_SQL")) return;
16
define("_INC_ABSTRACT_SQL", "1");
17
 
18
// Cette fonction est systematiquement appelee par les squelettes
19
// pour constuire une requete SQL de type "lecture" (SELECT) a partir
20
// de chaque boucle.
21
// Elle construit et exe'cute une reque^te SQL correspondant a` une balise
22
// Boucle ; elle notifie une erreur SQL dans le flux de sortie et termine
23
// le processus.
24
// Sinon, retourne la ressource interrogeable par spip_abstract_fetch.
25
// Recoit en argument:
26
// - le tableau des champs a` ramener
27
// - le tableau des tables a` consulter
28
// - le tableau des conditions a` remplir
29
// - le crite`re de regroupement
30
// - le crite`re de classement
31
// - le crite`re de limite
32
// - une sous-requete e'ventuelle (MySQL > 4.1)
33
// - un compteur de sous-requete
34
// - le nom de la table
35
// - le nom de la boucle (pour le message d'erreur e'ventuel)
36
// - le serveur sollicite
37
 
38
function spip_abstract_select (
39
	$select = array(), $from = array(), $where = '',
40
	$groupby = '', $orderby = array(), $limit = '',
41
	$sousrequete = '', $cpt = '',
42
	$table = '', $id = '', $serveur='') {
43
 
44
	if (!$serveur)
45
	  // le serveur par defaut est celui de inc_connect.php
46
	  // tout est deja pret, notamment la fonction suivante:
47
	  $f = 'spip_mysql_select';
48
	else {
49
	  // c'est un autre; est-il deja charge ?
50
		$f = 'spip_' . $serveur . '_select';
51
		if (!function_exists($f)) {
52
		  // non, il est decrit dans le fichier ad hoc
53
			$d = _DIR_RESTREINT . 'inc_connect-' . $serveur .'.php3';
54
			if (@file_exists($d)) include($d);
55
			$f = spip_abstract_serveur($f, $serveur);
56
		}
57
	}
58
	return $f($select, $from, $where,
59
		  $groupby, array_filter($orderby), $limit,
60
		  $sousrequete, $cpt,
61
		  $table, $id, $serveur);
62
}
63
 
64
function spip_abstract_serveur($f, $serveur) {
65
	if (function_exists($f))
66
		return $f;
67
 
68
	erreur_squelette(' '._T('zbug_serveur_indefini'), $serveur);
69
 
70
	// hack pour continuer la chasse aux erreurs
71
	return 'array';
72
}
73
 
74
// Les 3 fonctions suivantes exploitent le resultat de la precedente,
75
// si l'include ne les a pas definies, erreur immediate
76
 
77
function spip_abstract_fetch($res, $serveur='')
78
{
79
  if (!$serveur) return spip_fetch_array($res);
80
  $f = spip_abstract_serveur('spip_' . $serveur . '_fetch', $serveur);
81
  return $f($res);
82
}
83
 
84
function spip_abstract_count($res, $serveur='')
85
{
86
  if (!$serveur) return spip_num_rows($res);
87
  $f = spip_abstract_serveur('spip_' . $serveur . '_count', $serveur);
88
  return $f($res);
89
}
90
 
91
function spip_abstract_free($res, $serveur='')
92
{
93
  if (!$serveur) return spip_free_result($res);
94
  $f = spip_abstract_serveur('spip_' . $serveur . '_free', $serveur);
95
  return $f($res);
96
}
97
 
98
function spip_abstract_insert($table, $noms, $valeurs, $serveur='')
99
{
100
  $f = (!$serveur ? 'spip_mysql_insert' :
101
	spip_abstract_serveur('spip_' . $serveur . '_insert', $serveur));
102
  return $f($table, $noms, $valeurs);
103
}
104
 
105
# une composition tellement frequente...
106
function spip_abstract_fetsel(
107
	$select = array(), $from = array(), $where = '',
108
	$groupby = '', $orderby = array(), $limit = '',
109
	$sousrequete = '', $cpt = '',
110
	$table = '', $id = '', $serveur='') {
111
	return spip_abstract_fetch(spip_abstract_select(
112
$select, $from, $where,	$groupby, $orderby, $limit,
113
$sousrequete, $cpt, $table, $id, $serveur),
114
				   $serveur);
115
}
116
?>