--- /dev/null
+<?php
+// Ce fichier contient des fonctions toujours compilees dans tmp/couteau-suisse/mes_fonctions.php
+if (!defined("_ECRIRE_INC_VERSION")) return;
+
+// compatibilite SPIP < 2.00
+if(!defined('_SPIP19300')) {
+ // #VAL{x} renvoie 'x' (permet d'appliquer un filtre a une chaine)
+ // Attention #VAL{1,2} renvoie '1', indiquer #VAL{'1,2'}
+ function balise_VAL($p){
+ $p->code = interprete_argument_balise(1,$p);
+ if (!strlen($p->code)) $p->code = "''";
+ $p->interdire_scripts = false;
+ return $p;
+ }
+ if(!function_exists('oui')) { function oui($code) { return $code?' ':''; } }
+ if(!function_exists('non')) { function non($code) { return $code?'':' '; } }
+}
+
+// fonction appelant une liste de fonctions qui permettent de nettoyer un texte original de ses raccourcis indesirables
+function cs_introduire($texte) {
+ // liste de filtres qui sert a la balise #INTRODUCTION
+ if(!is_array($GLOBALS['cs_introduire'])) return $texte;
+ $liste = array_unique($GLOBALS['cs_introduire']);
+ foreach($liste as $f)
+ if (function_exists($f)) $texte = $f($texte);
+ return $texte;
+}
+
+// Fonction propre() sans paragraphage
+function cs_propre($texte) {
+ include_spip('inc/texte');
+ return trim(PtoBR(propre($texte)));
+}
+
+// Filtre creant un lien <a> sur un texte
+// Exemple d'utilisation : [(#EMAIL*|cs_lien{#NOM})]
+function cs_lien($lien, $texte='') {
+ if(!$lien) return $texte;
+ return cs_propre("[{$texte}->{$lien}]");
+}
+
+// filtre pour ajouter un <span> autour d'un texte
+function cs_span($texte, $attr='') { return "<span $attr>$texte</span>"; }
+
+// Controle (basique!) des 3 balises usuelles p|div|span eventuellement coupees
+// Attention : simple traitement pour des balises non imbriquees
+function cs_safebalises($texte) {
+ $texte = trim($texte);
+ // ouvre/supprime la premiere balise trouvee fermee (attention aux modeles SPIP)
+ if(preg_match(',^(.*)</([a-z]+)>,Ums', $texte, $m) && !preg_match(",<$m[2][ >],", $m[1]))
+ $texte = strlen($m[1])?"<$m[2]>$texte":trim(substr($texte, strlen($m[2])+3));
+ // referme/supprime la derniere balise laissee ouverte (attention aux modeles SPIP)
+ if(preg_match(',^(.*)[ >]([a-z]+)<,Ums', $rev = strrev($texte), $m) && !preg_match(",>$m[2]/<,", $m[1]))
+ $texte = strrev(strlen($m[1])?">$m[2]/<$rev":trim(substr($rev, strlen($m[2])+2)));
+ // balises <p|span|div> a traiter
+ foreach(array('span', 'div', 'p') as $b) {
+ // ouvrante manquante
+ if(($fin = strpos($texte, "</$b>")) !== false)
+ if(!preg_match(",<{$b}[ >],", substr($texte, 0, $fin)))
+ $texte = "<$b>$texte";
+ // fermante manquante
+ $texte = strrev($texte);
+ if(preg_match(',[ >]'.strrev("<{$b}").',', $texte, $reg)) {
+ $fin = strpos(substr($texte, 0, $deb = strpos($texte, $reg[0])), strrev("</$b>"));
+ if($fin===false || $fin>$deb) $texte = strrev("</$b>").$texte;
+ }
+ $texte = strrev($texte);
+ }
+ return $texte;
+}
+
+// fonction de suppression de notes. Utile pour #CS_SOMMAIRE ou #CS_DECOUPE
+function cs_supprime_notes($texte) {
+ return preg_replace(', *\[\[(.*?)\]\],msS', '', $texte);
+}
+
+// filtre appliquant les traitements SPIP d'un champ (et eventuellement d'un type d'objet) sur un texte
+// (voir la fonction champs_traitements($p) dans : public/references.php)
+// => permet d'utiliser les balises etoilees : #TEXTE*|mon_filtre|cs_traitements{TEXTE,articles}
+// ce mecanisme est a preferer au traditionnel #TEXTE*|mon_filtre|propre
+// cs_traitements() consulte simplement la globale $table_des_traitements et applique le traitement adequat
+// $exclusions est une chaine ou un tableau de filtres a exclure du traitement
+function cs_traitements($texte, $nom_champ='NULL', $type_objet='NULL', $exclusions=NULL) {
+ global $table_des_traitements;
+ if(!isset($table_des_traitements[$nom_champ])) return $texte;
+ $ps = $table_des_traitements[$nom_champ];
+ if(is_array($ps)) $ps = $ps[isset($ps[$type_objet]) ? $type_objet : 0];
+ if(!$ps) return $texte;
+ // retirer les filtres a exclure
+ if($exclusions!==NULL) $ps = str_replace($exclusions, 'cs_noop', $ps);
+ // remplacer le placeholder %s par le texte fourni
+ eval('$texte=' . str_replace('%s', '$texte', $ps) . ';');
+ return $texte;
+}
+function cs_noop($t='',$a=NULL,$b=NULL,$c=NULL) { return $t; }
+
+// liste des docs sur spip-contrib (outils actifs)
+function cs_liste_contribs($coupe = 999, $join = "</li><li>") {
+ global $metas_outils;
+ $contribs = array();
+ foreach($metas_outils as $o=>$v) if(isset($v['contrib']) && isset($v['actif']) && $v['actif'])
+ $contribs[] = '[' . couper(couteauprive_T($o.':nom'), $coupe) . '->' . (is_numeric($v['contrib']) ?_URL_CONTRIB.$v['contrib']:$v['contrib']) . ']';
+ sort($contribs);
+ return '[{{' . couteauprive_T('docgen') . '}}->' . _URL_CONTRIB . '2166]'
+ . $join . '[{{' . couteauprive_T('docwiki') . '}}->' . _URL_CONTRIB . '2793]'
+ . $join . join($join, $contribs);
+}
+
+// renvoie un champ d'un objet en base
+function cs_champ_sql($id, $champ='texte', $objet='article') {
+ // Utiliser la bonne requete en fonction de la version de SPIP
+ if(function_exists('sql_getfetsel')) {
+ // SPIP 2.0
+ // TODO : fonctions SPIP pour trouver la table et l'id_objet
+ if($r = sql_getfetsel($champ, 'spip_'.$objet.'s', 'id_'.$objet.'='.intval($id)))
+ return $r;
+ } else {
+ if($r = spip_query('SELECT '.$champ.' FROM spip_'.$objet.'s WHERE id_'.$objet.'='.intval($id)))
+ // s'il existe un champ, on le retourne
+ if($row = spip_fetch_array($r)) return $row[$champ];
+ }
+ // sinon rien !
+ return '';
+}
+
+?>
\ No newline at end of file