X-Git-Url: http://git.cyclocoop.org/?p=velocampus%2Fweb%2Fwww.git;a=blobdiff_plain;f=www%2Fplugins%2Fauto%2Fcouteau_suisse%2Fcouteau_suisse%2Fcout_pipelines.php;fp=www%2Fplugins%2Fauto%2Fcouteau_suisse%2Fcouteau_suisse%2Fcout_pipelines.php;h=78cd2f4a4b998f985eb3b8e1e49393b90cb65181;hp=0000000000000000000000000000000000000000;hb=80b4d3e85f78d402ed2e73f8f5d1bf4c19962eed;hpb=aaf970bf4cdaf76689ecc10609048e18d073820c diff --git a/www/plugins/auto/couteau_suisse/couteau_suisse/cout_pipelines.php b/www/plugins/auto/couteau_suisse/couteau_suisse/cout_pipelines.php new file mode 100644 index 0000000..78cd2f4 --- /dev/null +++ b/www/plugins/auto/couteau_suisse/couteau_suisse/cout_pipelines.php @@ -0,0 +1,302 @@ + etc.) pour les traitements (s'il y en a) venant apres propre() + // Note : SPIP echappe egalement les modeles + if($GLOBALS['cs_post_propre']) { + if(strpos($flux, ']+>,', _CS_HTMLA.'$0'._CS_HTMLB, $flux); + if(strpos($flux, '
]+>
,', _CS_HTMLA.'$0'._CS_HTMLB, $flux); + } + return $flux; +} + +function couteau_suisse_post_typo($flux){ + return eval_metas_pipelines($flux, 'post_typo'); +} + +/******** + * BASE * + *******/ + +function couteau_suisse_pre_edition($flux){ + return eval_metas_pipelines($flux, 'pre_edition'); +} +function couteau_suisse_post_edition($flux){ + return eval_metas_pipelines($flux, 'post_edition'); +} + +/********** + * DIVERS * + *********/ + +// pipeline SPIP<2.1 +function couteau_suisse_creer_chaine_url($flux){ + return eval_metas_pipelines($flux, 'creer_chaine_url'); +} +// pipelines SPIP>=2.1 +function couteau_suisse_arbo_creer_chaine_url($flux){ + return eval_metas_pipelines($flux, 'arbo_creer_chaine_url'); +} +function couteau_suisse_propres_creer_chaine_url($flux){ + return eval_metas_pipelines($flux, 'propres_creer_chaine_url'); +} + +// eux fonctions obsoletes, conservees pour SPIP<3.0 : +// le contenu du sous-menu est gere par les lames elles-memes +function couteau_suisse_bt_toolbox($params) { + global $cs_metas_pipelines; + if(!isset($cs_metas_pipelines['bt_toolbox'])) return $params; + $flux = ''; + eval($cs_metas_pipelines['bt_toolbox']); + $tableau_formulaire = ' + ' + . str_replace(array('@@champ@@','@@span@@'), array($params['champ'], 'span style="vertical-align:75%;"'), $flux) . ' +
'; + $params['flux'] .= produceWharf('couteau_suisse', '', $tableau_formulaire); + return $params; +} +// bouton principal du Couteau Suisse +function couteau_suisse_bt_gadgets($params) { + global $cs_metas_pipelines; + if(!isset($cs_metas_pipelines['bt_toolbox'])) return $params; + $params['flux'] .= bouton_barre_racc("swap_couche('".$GLOBALS['numero_block']['couteau_suisse']."','');", _DIR_PLUGIN_COUTEAU_SUISSE."/img/couteau-24.gif", _T('couteauprive:raccourcis_barre'), $params['help']); + return $params; +} + +function couteau_suisse_porte_plume_barre_pre_charger($flux){ + eval_metas_pipelines($flux, 'porte_plume_barre_pre_charger'); + $barres = pipeline('porte_plume_cs_pre_charger', array()); + $r = array( + "id" => 'couteau_suisse_drop', + "name" => _T('couteau:pp_couteau_suisse_drop'), + "className" => 'couteau_suisse_drop', + "replaceWith" => '', + "display" => true, + ); + foreach($barres as $barre=>$menu) { + $r["dropMenu"] = $menu; + $flux[$barre]->ajouterApres('grpCaracteres', $r); + } + return $flux; +} + +function couteau_suisse_porte_plume_lien_classe_vers_icone($flux){ + global $cs_metas_pipelines; + if (isset($cs_metas_pipelines['porte_plume_lien_classe_vers_icone'])) { + $flux['couteau_suisse_drop'] = 'couteau-19.png'; + // chemin des icones-typo de couleur + _chemin(sous_repertoire(_DIR_VAR, 'couteau-suisse')); + eval($cs_metas_pipelines['porte_plume_lien_classe_vers_icone']); + } + return $flux; +} + +// pipeline maison : bouton sous un drop Couteau Suisse +function couteau_suisse_porte_plume_cs_pre_charger($flux){ + return eval_metas_pipelines($flux, 'porte_plume_cs_pre_charger'); +} + + +// compatibilite avec le plugin Facteur +function couteau_suisse_facteur_pre_envoi($flux){ + return eval_metas_pipelines($flux, 'facteur_pre_envoi'); +} + +// pipeline maison : pre-affichage de la description d'un outil +// flux['outil'] est l'id de l'outil, $flux['actif'] est l'etat de l'outil, flux['texte'] est le texte de description +function couteau_suisse_pre_description_outil($flux) { + global $cs_metas_pipelines; + $id = &$flux['outil']; $texte = &$flux['texte']; + if(isset($cs_metas_pipelines['pre_description_outil'])) + eval($cs_metas_pipelines['pre_description_outil']); + return $flux; +} +// A l'issue du telechargement d'un fichier distant +function couteau_suisse_fichier_distant($flux) { + global $cs_metas_pipelines; + if(isset($cs_metas_pipelines['fichier_distant'])) + eval($cs_metas_pipelines['fichier_distant']); + return $flux; +} + +// callback pour la fonction cs_compile_pipe() +function cs_compile_header_callback($matches) { +if(defined('_LOG_CS')) cs_log(" -- compilation d'un header. Code CSS : ".couper($matches[1], 150)); + return cs_recuperer_code($matches[1]); +} + +// recherche et compilation par SPIP du contenu d'un fichier .html : contenu +// $type = 'css' ou 'js' +function cs_compile_header(&$flux, $type_, $suffixe='', $rem=true) { +//if(defined('_LOG_CS')) cs_log(" -- recherche de compilations necessaires du header."); + global $cs_metas_pipelines; + if(isset($cs_metas_pipelines[$type = 'header_'.$type_.$suffixe])) { + $header = &$cs_metas_pipelines[$type]; + if(strpos($header, '')!==false) { + $header = preg_replace_callback(',(.*),Ums', 'cs_compile_header_callback', $header); + // sauvegarde en metas + ecrire_meta('tweaks_pipelines', serialize($cs_metas_pipelines)); + ecrire_metas(); + ecrire_fichier(_DIR_CS_TMP.$type.'.html', "\n\n$header"); + } + $flux .= $header; + } + if($rem) + $flux = strlen(trim($flux))?"\n\n$flux\n\n\n":"\n\n\n"; +} + +// construction d'un hit +// (recherche et compilation par SPIP du contenu d'un fichier .html : contenu) +// $type = 'css' ou 'js' +function cs_header_hit(&$flux, $type, $suffixe='') { + $f = "header$suffixe.$type"; + $nom = sous_repertoire(_DIR_VAR,'couteau-suisse') . $f; + $tmp = _DIR_CS_TMP . $f; + if(!file_exists($tmp) || !file_exists($nom) || $GLOBALS['var_mode']=='recalcul') { + if (lire_fichier(_DIR_CS_TMP."header.$type.html", $t) && strlen($t)) { + if(strpos($t, '')!==false) + $t = preg_replace_callback(',(.*),Ums', 'cs_compile_header_callback', $t); + ecrire_fichier($nom, $t, true); + ecrire_fichier($tmp, $t, true); + } else { + if(defined('_LOG_CS')) cs_log(" -- fichier $fo illisible. hit non construit"); + return; + } + } + switch($type) { + case 'js': $flux .= ''; break; + case 'css': include_spip('inc/filtres'); + $flux .= ''; break; + } +} + +/** + * recupere le resultat du calcul d'une compilation de code de squelette (marcimat) + * $coucou = $this->recuperer_code('[(#AUTORISER{ok}|oui)coucou]'); + */ +function cs_recuperer_code(&$code) {//, $contexte=array(), $options = array(), $connect=''){ + $fond = _DIR_CS_TMP . md5($code); + $base = $fond . '.html'; + if(!file_exists($base) OR $GLOBALS['var_mode']=='recalcul') + ecrire_fichier($base, $code); + include_spip('public/assembler'); + $fond = str_replace('../', '', $fond); +// return recuperer_fond($fond, array('fond'=>$fond)); + $f = inclure_page($fond, array('fond'=>$fond)); + return $f['texte']; +} + + +/* +if(defined('_LOG_CS')) cs_log("INIT : cout_pipelines, lgr=" . strlen($cs_metas_pipelines['pipelines'])); +if(!$GLOBALS['cs_pipelines']) include_once(_DIR_CS_TMP.'pipelines.php'); +if(defined('_LOG_CS')) cs_log(' -- sortie de cout_pipelines... cs_pipelines = ' . intval($GLOBALS['cs_pipelines'])); +*/ +?> \ No newline at end of file