[SPIP] +2.1.12
[velocampus/web/www.git] / www / plugins / auto / couteau_suisse / couteau_suisse / outils / cout_fonctions.php
diff --git a/www/plugins/auto/couteau_suisse/couteau_suisse/outils/cout_fonctions.php b/www/plugins/auto/couteau_suisse/couteau_suisse/outils/cout_fonctions.php
new file mode 100644 (file)
index 0000000..8f598d8
--- /dev/null
@@ -0,0 +1,126 @@
+<?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