Skip to content
Extraits de code Groupes Projets
inc_texte.php3 31,5 ko
Newer Older
<?php
Yannick Patois's avatar
Yannick Patois a validé

//
// Ce fichier ne sera execute qu'une fois
if (defined("_ECRIRE_INC_TEXTE")) return;
define("_ECRIRE_INC_TEXTE", "1");

Fil's avatar
 
Fil a validé
include_ecrire("inc_filtres.php3");
Yannick Patois's avatar
Yannick Patois a validé

//
// Initialisation de quelques variables globales
// (on peut les modifier globalement dans mes_fonctions.php3,
//  OU individuellement pour chaque type de page dans article.php3,
//  rubrique.php3, etc. cf doc...)
// Par securite ne pas accepter les variables passees par l'utilisateur
Yannick Patois's avatar
Yannick Patois a validé
//
function tester_variable($nom_var, $val){
	global $INSECURE;
	if (!isset($GLOBALS[$nom_var]) || $INSECURE[$nom_var]) {
		return false;
	}
	return true;
tester_variable('debut_intertitre', "\n<h3 class=\"spip\">");
tester_variable('fin_intertitre', "</h3>\n");
Fil's avatar
Fil a validé
tester_variable('ligne_horizontale', "\n<hr class=\"spip\" />\n");
ARNO*'s avatar
ARNO* a validé
tester_variable('ouvre_ref', '&nbsp;[');
tester_variable('ferme_ref', ']');
tester_variable('ouvre_note', '[');
tester_variable('ferme_note', '] ');
tester_variable('les_notes', '');
tester_variable('compt_note', 0);
tester_variable('nombre_surligne', 4);
tester_variable('url_glossaire_externe', "http://@lang@.wikipedia.org/wiki/");
Antoine Pitrou's avatar
Antoine Pitrou a validé

// On ne prend la $puce_rtl par defaut que si $puce n'a pas ete redefinie
Yannick Patois's avatar
Yannick Patois a validé

Antoine Pitrou's avatar
Antoine Pitrou a validé
//if (!tester_variable('puce', "<li class='spip_puce' style='list-style-image: url(puce.gif)'>")) {
ARNO*'s avatar
ARNO* a validé
if (!tester_variable('puce', "<img class='spip_puce' src='puce.gif' alt='-' border='0'>&nbsp;")) {
	tester_variable('puce_rtl', "<img class='spip_puce' src='puce_rtl.gif' alt='-' border='0'>&nbsp;");
Yannick Patois's avatar
Yannick Patois a validé


//
// Trouver une locale qui marche
//
$lang2 = strtoupper($GLOBALS['spip_lang']);
setlocale(LC_CTYPE, $GLOBALS['spip_lang']) ||
setlocale(LC_CTYPE, $lang2.'_'.$GLOBALS['spip_lang']) ||
setlocale(LC_CTYPE, $GLOBALS['spip_lang'].'_'.$lang2);
Yannick Patois's avatar
Yannick Patois a validé


Yannick Patois's avatar
Yannick Patois a validé

// ereg_ ou preg_ ?
function ereg_remplace($cherche_tableau, $remplace_tableau, $texte) {
	global $flag_pcre;
Yannick Patois's avatar
Yannick Patois a validé

	if ($flag_pcre) return preg_replace($cherche_tableau, $remplace_tableau, $texte);
Yannick Patois's avatar
Yannick Patois a validé

Yannick Patois's avatar
Yannick Patois a validé

	for ($i = 0; $i < $n; $i++) {
		$texte = ereg_replace(substr($cherche_tableau[$i], 1, -1), $remplace_tableau[$i], $texte);
Yannick Patois's avatar
Yannick Patois a validé
	}
Yannick Patois's avatar
Yannick Patois a validé
}

// Ne pas afficher le chapo si article virtuel
function nettoyer_chapo($chapo){
	if (substr($chapo,0,1) == "="){
Antoine Pitrou's avatar
Antoine Pitrou a validé
		$chapo = "";
	}
	return $chapo;
}

// points d'entree de pre- et post-traitement pour propre() et typo()
function spip_avant_propre ($letexte) {
Fil's avatar
Fil a validé
	$letexte = extraire_multi($letexte);

	if (@function_exists('avant_propre'))
	return $letexte;
}

function spip_apres_propre ($letexte) {
	if (@function_exists('apres_propre'))

	return $letexte;
}

function spip_avant_typo ($letexte) {
Fil's avatar
Fil a validé
	$letexte = extraire_multi($letexte);

	if (@function_exists('avant_typo'))
function spip_apres_typo ($letexte) {
	// caracteres speciaux
	$letexte = corriger_caracteres($letexte);
	$letexte = str_replace("'", "&#8217;", $letexte);
Fil's avatar
Fil a validé
	// relecture des &nbsp;
	if ($GLOBALS['flag_ecrire'] AND $GLOBALS['revision_nbsp'])
		$letexte = ereg_replace('&nbsp;', '<span class="spip-nbsp">&nbsp;</span>', $letexte);
	if (@function_exists('apres_typo'))
		return apres_typo ($letexte);

// Mise de cote des echappements
Yannick Patois's avatar
Yannick Patois a validé

// Les regexp de echappe_html, dépendant de la fonction de comparaison

if ($GLOBALS['flag_pcre']) {
	$GLOBALS['fct_match'] = 'preg_match';
	$regexp_echap_html = "<html>((.*?))<\/html>";
	$regexp_echap_code = "<code>((.*?))<\/code>";
	$regexp_echap_cadre = "[\n\r]*<(cadre|frame)>((.*?))<\/(cadre|frame)>[\n\r]*";
	$regexp_echap_poesie = "[\n\r]*<(poesie|poetry)>((.*?))<\/(poesie|poetry)>[\n\r]*";
	$GLOBALS['regexp_echappe'] = "/($regexp_echap_html)|($regexp_echap_code)|($regexp_echap_cadre)|($regexp_echap_poesie)/si";
		//echo creer_echappe_sans_pcre("cadre");
	$GLOBALS['fct_match'] = 'eregi';
	$regexp_echap_html = "<html>(([^<]|<[^/]|</[^h]|</h[^t]|</ht[^m]|</htm[^l]|<\/html[^>])*)<\/html>";
	$regexp_echap_code = "<code>(([^<]|<[^/]|</[^c]|</c[^o]|</co[^d]|</cod[^e]|<\/code[^>])*)<\/code>";
	$regexp_echap_cadre = "(<[cf][ar][da][rm]e>(([^<]|<[^/]|</[^cf]|</[cf][^ar]|</[cf][ar][^da]|</[cf][ar][da][^rm]|</[cf][ar][da][rm][^e]|<\/[cf][ar][da][rm]e[^>])*)<\/[cf][ar][da][rm]e>)()"; // parentheses finales pour obtenir meme nombre de regs que pcre
	$regexp_echap_poesie = "(<poe[st][ir][ey]>(([^<]|<[^/]|</[^p]|</p[^o]|</po[^e]|</poe[^st]|</poe[st][^ir]|</poe[st][ir][^[ey]]|<\/poe[st][ir][ey][^>])*)<\/poe[st][ir][ey]>)()";
	$GLOBALS['regexp_echappe'] = "($regexp_echap_html)|($regexp_echap_code)|($regexp_echap_cadre)|($regexp_echap_poesie)";
 }
Yannick Patois's avatar
Yannick Patois a validé

function echappe_html($letexte, $source='SOURCEPROPRE', $no_transform=false) {
  global $flag_pcre, $fct_match, $regexp_echappe;

  $debut = '';
  $suite = $letexte;
  while ($fct_match($regexp_echappe, $suite, $regs)) {
Yannick Patois's avatar
Yannick Patois a validé

		if ($no_transform) {	// echappements bruts
			$les_echap[$num_echap] = $regs[0];
		}
		else
Fil's avatar
Fil a validé
		if ($regs[1]) {
			// Echapper les <html>...</ html>
			$les_echap[$num_echap] = $regs[2];
		}
		else
Fil's avatar
Fil a validé
		if ($regs[4]) {
			// Echapper les <code>...</ code>
			$lecode = entites_html($regs[5]);

Fil's avatar
Fil a validé
			// supprimer les sauts de ligne debut/fin (mais pas les espaces => ascii art).
			$lecode = ereg_replace("^\n+|\n+$", "", $lecode);

			// ne pas mettre le <div...> s'il n'y a qu'une ligne
			if (is_int(strpos($lecode,"\n")))
Fil's avatar
Fil a validé
				$lecode = nl2br("<div align='left' class='spip_code' dir='ltr'>".$lecode."</div>");
			else
				$lecode = "<span class='spip_code' dir='ltr'>".$lecode."</span>";

			$lecode = ereg_replace("\t", "&nbsp; &nbsp; &nbsp; &nbsp; ", $lecode);
			$lecode = ereg_replace("  ", " &nbsp;", $lecode);
			$les_echap[$num_echap] = "<tt>".$lecode."</tt>";
		}
		else
Fil's avatar
Fil a validé
		if ($regs[7]) {
			// Echapper les <cadre>...</cadre>
			$lecode = trim(entites_html($regs[9]));
			$total_lignes = count(explode("\n", $lecode));
			$les_echap[$num_echap] = "</p><form action=\"/\" method=\"get\"><textarea readonly='readonly' cols='40' rows='$total_lignes' class='spip_cadre' dir='ltr'>".$lecode."</textarea></form><p class=\"spip\">";
		else
		if ($regs[12]) {
			$lecode = $regs[14];
			$lecode = ereg_replace("\n[[:space:]]*\n", "\n&nbsp;\n",$lecode);
			$lecode = ereg_replace("\r", "\n", $lecode);
			$lecode = "<div class=\"spip_poesie\"><div>".ereg_replace("\n+", "</div>\n<div>", $lecode)."</div></div>";
ARNO*'s avatar
ARNO* a validé
			$les_echap[$num_echap] = propre($lecode);
ARNO*'s avatar
ARNO* a validé
		} 
Yannick Patois's avatar
Yannick Patois a validé

		$pos = strpos($suite, $regs[0]);
		$debut .= substr($suite,0,$pos)."@@SPIP_$source$num_echap@@";
		$suite = substr($suite, $pos+strlen($regs[0]));
		spip_log($suite);
Yannick Patois's avatar
Yannick Patois a validé
	}
	// Gestion du TeX
	if (!(strpos($letexte, "<math>") === false)) {
		include_ecrire("inc_math.php3");
Fil's avatar
Fil a validé
		$letexte = traiter_math($letexte, $les_echap, $num_echap, $source);
ARNO*'s avatar
ARNO* a validé
	}

	// Reperages d'images et de documents utilisateur 
	// (insertion dans echappe_retour pour faciliter les doublons)
	while (eregi("<(IMG|DOC|EMB)([0-9]+)(\|([^\>]*))?".">", $letexte, $match)) {
		$num_echap++;

		$letout = quotemeta($match[0]);
		$letout = ereg_replace("\|", "\|", $letout);
		$letexte = ereg_replace($letout, "@@SPIP_$source$num_echap@@", $letexte);
	// Echapper les tags html contenant des caracteres sensibles a la typo
	$regexp_echap = "<[a-zA-Z!][^<>!':;\?]*[!':;\?][^<>]*>";
Fil's avatar
Fil a validé
	if ($flag_pcre) {
		if (preg_match_all("/$regexp_echap/", $letexte, $regs, PREG_SET_ORDER))
			while (list(,$reg) = each($regs)) {
				$num_echap++;
				$les_echap[$num_echap] = $reg[0];
				//echo htmlspecialchars($reg[0])."<p>";
				$pos = strpos($letexte, $les_echap[$num_echap]);
				$letexte = substr($letexte,0,$pos)."@@SPIP_$source$num_echap@@"
					.substr($letexte,$pos+strlen($les_echap[$num_echap]));
			}
Fil's avatar
Fil a validé
	} else {
		while (ereg($regexp_echap, $letexte, $reg)) {
			$num_echap++;
			$les_echap[$num_echap] = $reg[0];
			$pos = strpos($letexte, $les_echap[$num_echap]);
			$letexte = substr($letexte,0,$pos)."@@SPIP_$source$num_echap@@"
				.substr($letexte,$pos+strlen($les_echap[$num_echap]));
		}
Fil's avatar
Fil a validé
	}
	return array($letexte, $les_echap);
Yannick Patois's avatar
Yannick Patois a validé
}

// Traitement final des echappements
function echappe_retour($letexte, $les_echap, $source='') {
  $cherche = "@@SPIP_$source";
  $n = strlen($cherche);
  $debut = '';
  while(($pos = strpos($letexte, $cherche)) !== false) {
    ereg("^([0-9]+)@@(.*)$",substr($letexte,$pos+$n),$regs);
    $rempl = $les_echap[$regs[1]];
# si $rempl est un tableau, c'est le résultat (cf echappe_html) de eregi sur :
# <(IMG|DOC|EMB)([0-9]+)(\|([^\>]*))?
    if (is_array($rempl))
	  {
		    include_ecrire("inc_documents.php3");
		    $type = strtoupper($rempl[1]);
		    if ($type == 'EMB')
		      $rempl = embed_document($rempl[2], $rempl[4]);
		    else
		      $rempl = integre_image($rempl[2], $rempl[4], $type);
	  }
    $debut .= substr($letexte,0,$pos) . $rempl;
    $letexte = $regs[2];
  }
  return $debut . $letexte;
}

# il y a 3 couples de fonctions homonymes au prefixe _doublons pres
# pour éviter à tous les appels de se trimbaler ce qui concerne les squelettes

function echappe_retour_doublon($letexte, $les_echap, $source, &$doublons)
{
  if (!$les_echap)
    return $letexte;
  foreach($les_echap as $rempl) {
    if (is_array($rempl)) # cf commentaires dans la fonction echappe_retour
      $doublons['documents'] .= "," . $rempl[2];
  }
  return echappe_retour($letexte, $les_echap, $source);
Yannick Patois's avatar
Yannick Patois a validé
}

function couper($texte, $taille=50) {
	$texte = substr($texte, 0, 400 + 2*$taille); /* eviter de travailler sur 10ko pour extraire 150 caracteres */

	// on utilise les \r pour passer entre les gouttes
	$texte = str_replace("\r", "\n", $texte);

	// sauts de ligne et paragraphes
	$texte = ereg_replace("\n\n+", "\r", $texte);
Fil's avatar
Fil a validé
	$texte = ereg_replace("<(p|br)( [^>]*)?".">", "\r", $texte);
	// supprimer les traits, lignes etc
	$texte = ereg_replace("(^|\r|\n)(-[-#\*]*|_ )", "\r", $texte);

	// supprimer les tags
	$texte = supprimer_tags($texte);
	$texte = trim(str_replace("\n"," ", $texte));
	$texte .= "\n";	// marquer la fin

	// travailler en accents charset
	$texte = filtrer_entites($texte);

	// supprimer les liens
	$texte = ereg_replace("\[->([^]]*)\]","\\1", $texte); // liens sans texte
	$texte = ereg_replace("\[([^\[]*)->([^]]*)\]","\\1", $texte);
Yannick Patois's avatar
Yannick Patois a validé

	// supprimer les notes
	$texte = ereg_replace("\[\[([^]]|\][^]])*\]\]", "", $texte);
Yannick Patois's avatar
Yannick Patois a validé

	$texte = ereg_replace("[{}]", "", $texte);
Yannick Patois's avatar
Yannick Patois a validé

Fil's avatar
Fil a validé
	$texte = ereg_replace("(^|\r)\|.*\|\r", "\r", $texte);

	// couper au mot precedent
	$long = substr($texte, 0, max($taille-4,1));
Fil's avatar
Fil a validé
	$court = ereg_replace("([^[:space:]][[:space:]]+)[^[:space:]]*\n?$", "\\1", $long);
	$points = '&nbsp;(...)';

	// trop court ? ne pas faire de (...)
	if (strlen($court) < max(0.75 * $taille,2)) {
		$points = '';
		$long = ereg_replace("&#?[a-z0-9]*;?$", "", substr($texte, 0, $taille));
		$texte = ereg_replace("([^[:space:]][[:space:]]+)[^[:space:]]*$", "\\1", $long);
		// encore trop court ? couper au caractere
		if (strlen($texte) < 0.75 * $taille)
			$texte = $long;
	} else
		$texte = $court;

Fil's avatar
Fil a validé
	if (strpos($texte, "\n"))	// la fin est encore la : c'est qu'on n'a pas de texte de suite
	// remettre les paragraphes
	$texte = ereg_replace("\r+", "\n\n", $texte);

Yannick Patois's avatar
Yannick Patois a validé
}

// prendre <intro>...</intro> sinon couper a la longueur demandee
Yannick Patois's avatar
Yannick Patois a validé
function couper_intro($texte, $long) {
	$texte = eregi_replace("(</?)intro>", "\\1intro>", $texte); // minuscules
	while ($fin = strpos($texte, "</intro>")) {
		$zone = substr($texte, 0, $fin);
		$texte = substr($texte, $fin + strlen("</intro>"));
		if ($deb = strpos($zone, "<intro>") OR substr($zone, 0, 7) == "<intro>")
			$zone = substr($zone, $deb + 7);
		$intro .= $zone;
	}

	if ($intro)
Yannick Patois's avatar
Yannick Patois a validé
	else
		$intro = couper($texte, $long);

	// supprimer un eventuel chapo redirecteur =http:/.....
	$intro = ereg_replace("^=[^[:space:]]+","",$intro);
Yannick Patois's avatar
Yannick Patois a validé

	return $intro;
}


Yannick Patois's avatar
Yannick Patois a validé

// Securite : empecher l'execution de code PHP
function interdire_scripts($source) {
	$source = eregi_replace("<(\%|\?|([[:space:]]*)script)", "&lt;\\1", $source);
	return $source;
Yannick Patois's avatar
Yannick Patois a validé
}

// Correction typographique francaise
Yannick Patois's avatar
Yannick Patois a validé
function typo_fr($letexte) {
Antoine Pitrou's avatar
Antoine Pitrou a validé
	global $flag_strtr2;
	static $trans;
Antoine Pitrou's avatar
Antoine Pitrou a validé

	// Nettoyer 160 = nbsp ; 187 = raquo ; 171 = laquo ; 176 = deg ; 147 = ldquo; 148 = rdquo
Antoine Pitrou's avatar
Antoine Pitrou a validé
	if (!$trans) {
		$trans = array(
			"&nbsp;" => "~",
			"&raquo;" => "&#187;",
			"&laquo;" => "&#171;",
			"&rdquo;" => "&#148;",
			"&ldquo;" => "&#147;",
Antoine Pitrou's avatar
Antoine Pitrou a validé
			"&deg;" => "&#176;"
		);
		$chars = array(160 => '~', 187 => '&#187;', 171 => '&#171;', 148 => '&#148;', 147 => '&#147;', 176 => '&#176;');
Antoine Pitrou's avatar
Antoine Pitrou a validé
		$charset = lire_meta('charset');
		include_ecrire('inc_charsets.php3');
Fil's avatar
 
Fil a validé

Antoine Pitrou's avatar
Antoine Pitrou a validé
		while (list($c, $r) = each($chars)) {
			$c = unicode2charset(charset2unicode(chr($c), 'iso-8859-1', 'forcer'));
			$trans[$c] = $r;
		}
Yannick Patois's avatar
Yannick Patois a validé
	}

Antoine Pitrou's avatar
Antoine Pitrou a validé
	if ($flag_strtr2)
		$letexte = strtr($letexte, $trans);
	else {
		reset($trans);
		while (list($c, $r) = each($trans))
			$letexte = str_replace($c, $r, $letexte);
	}
Fil's avatar
 
Fil a validé

Yannick Patois's avatar
Yannick Patois a validé
	$cherche1 = array(
Yannick Patois's avatar
Yannick Patois a validé
		/* 2 */ 	'/((^|[^\#0-9a-zA-Z\&])[\#0-9a-zA-Z]*)\;/',
		/* 3 */		'/&#187;| --?,|:([^0-9]|$)/',
		/* 4 */		'/([^<!?])([!?])/',
		/* 5 */		'/&#171;|(M(M?\.|mes?|r\.?)|[MnN]&#176;) /'
Yannick Patois's avatar
Yannick Patois a validé
	);
	$remplace1 = array(
		/* 1		'<i class="spip">\1</i>', */
Yannick Patois's avatar
Yannick Patois a validé
		/* 2 */		'\1~;',
Yannick Patois's avatar
Yannick Patois a validé
	);
	$letexte = ereg_remplace($cherche1, $remplace1, $letexte);
	$letexte = ereg_replace(" *~+ *", "~", $letexte);

	$cherche2 = array(
Yannick Patois's avatar
Yannick Patois a validé
		'/~/'
	);
	$remplace2 = array(
		'\1:',
		'&nbsp;'
	);
Yannick Patois's avatar
Yannick Patois a validé
	$letexte = ereg_remplace($cherche2, $remplace2, $letexte);

Antoine Pitrou's avatar
Antoine Pitrou a validé
	return $letexte;
Yannick Patois's avatar
Yannick Patois a validé
}

// rien sauf les "~" et "-,"
function typo_en($letexte) {
Fil's avatar
Fil a validé
	$cherche1 = array(
Fil's avatar
Fil a validé
	);
	$remplace1 = array(
Fil's avatar
Fil a validé
	);
	$letexte = ereg_remplace($cherche1, $remplace1, $letexte);
Antoine Pitrou's avatar
Antoine Pitrou a validé
	$letexte = str_replace("&nbsp;", "~", $letexte);
	$letexte = ereg_replace(" *~+ *", "~", $letexte);

	$cherche2 = array(
Fil's avatar
Fil a validé

	$letexte = ereg_remplace($cherche2, $remplace2, $letexte);

	return $letexte;
// Typographie generale : francaise si la langue est 'cpf', 'fr' ou 'eo',
// sinon anglaise (minimaliste)
	global $spip_lang, $lang_typo;
Yannick Patois's avatar
Yannick Patois a validé

	// Appeler la fonction de pre-traitement
	$letexte = spip_avant_typo ($letexte);
Antoine Pitrou's avatar
Antoine Pitrou a validé
	if (!$lang = $lang_typo) {
		include_ecrire('inc_lang.php3');
Antoine Pitrou's avatar
Antoine Pitrou a validé
		$lang = lang_typo($spip_lang);
Antoine Pitrou's avatar
Antoine Pitrou a validé
	if ($lang == 'fr')
Yannick Patois's avatar
Yannick Patois a validé
		$letexte = typo_fr($letexte);
	else
		$letexte = typo_en($letexte);
Antoine Pitrou's avatar
Antoine Pitrou a validé

	// Appeler la fonction de post-traitement
function typo($letexte) {
	// echapper les codes <html>...</html> etc.
	list($letexte, $les_echap) = echappe_html($letexte, "SOURCETYPO");
	
	$letexte = typo_generale($letexte);
	// reintegrer les echappements
	return echappe_retour($letexte, $les_echap, "SOURCETYPO");
Yannick Patois's avatar
Yannick Patois a validé
}

function typo_doublon(&$doublons, $letexte)
{
	// echapper les codes <html>...</html> etc.
	list($letexte, $les_echap) = echappe_html($letexte, "SOURCETYPO");
	
	$letexte = typo_generale($letexte);
	// reintegrer les echappements
	return echappe_retour_doublon($letexte, $les_echap, "SOURCETYPO", $doublons);
}
Fil's avatar
 
Fil a validé
// cette fonction est tordue : on lui passe un tableau correspondant au match
// de la regexp ci-dessous, et elle retourne le texte a inserer a la place
// et le lien "brut" a usage eventuel de redirection...
function extraire_lien ($regs) {
Fil's avatar
Fil a validé
	$lien_texte = $regs[1];
	$lien_url = entites_html(trim($regs[3]));
Fil's avatar
 
Fil a validé
	$compt_liens++;
	$lien_interne = false;
Fil's avatar
Fil a validé
	if (ereg('^[[:space:]]*(art(icle)?|rub(rique)?|br(.ve)?|aut(eur)?|mot|site|doc(ument)?|im(age|g))?[[:space:]]*([[:digit:]]+)(#.*)?[[:space:]]*$', $lien_url, $match)) {
Fil's avatar
 
Fil a validé
		// Traitement des liens internes
Fil's avatar
Fil a validé
		if ($flag_ecrire)
			include_ecrire('inc_urls.php3');
		else if (@file_exists('inc-urls.php3'))
Antoine Pitrou's avatar
Antoine Pitrou a validé
			include_local('inc-urls.php3');
Fil's avatar
Fil a validé
		else if (@file_exists('inc-urls-dist.php3'))
Antoine Pitrou's avatar
Antoine Pitrou a validé
			include_local('inc-urls-dist.php3');

		$ancre = $match[9];
		$type_lien = substr($match[1], 0, 2);
Fil's avatar
 
Fil a validé
		$lien_interne=true;
		$class_lien = "in";
		switch ($type_lien) {
Fil's avatar
 
Fil a validé
			case 'ru':
				$lien_url = generer_url_rubrique($id_lien);
				if (!$lien_texte) {
					$req = "select titre from spip_rubriques where id_rubrique=$id_lien";
					$row = @spip_fetch_array(@spip_query($req));
Fil's avatar
 
Fil a validé
					$lien_texte = $row['titre'];
				}
				break;
			case 'br':
				$lien_url = generer_url_breve($id_lien);
				if (!$lien_texte) {
					$req = "select titre from spip_breves where id_breve=$id_lien";
					$row = @spip_fetch_array(@spip_query($req));
Fil's avatar
 
Fil a validé
					$lien_texte = $row['titre'];
				}
				break;
			case 'au':
				$lien_url = generer_url_auteur($id_lien);
				if (!$lien_texte) {
					$req = "select nom from spip_auteurs where id_auteur = $id_lien";
					$row = @spip_fetch_array(@spip_query($req));
Fil's avatar
 
Fil a validé
					$lien_texte = $row['nom'];
				}
				break;
			case 'mo':
				$lien_url = generer_url_mot($id_lien);
				if (!$lien_texte) {
					$req = "select titre from spip_mots where id_mot=$id_lien";
					$row = @spip_fetch_array(@spip_query($req));
Fil's avatar
 
Fil a validé
					$lien_texte = $row['titre'];
				}
				break;
			case 'im':
			case 'do':
				$lien_url = generer_url_document($id_lien);
				if (!$lien_texte) {
					$req = "select titre,fichier from spip_documents where id_document=$id_lien";
					$row = @spip_fetch_array(@spip_query($req));
					$lien_texte = $row['titre'];
					if (!$lien_texte)
						$lien_texte = ereg_replace("^.*/","",$row['fichier']);
				}
Fil's avatar
Fil a validé
				break;
Fil's avatar
 
Fil a validé
			case 'si':
				$row = @spip_fetch_array(@spip_query("SELECT nom_site,url_site FROM spip_syndic WHERE id_syndic=$id_lien"));
Fil's avatar
 
Fil a validé
				if ($row) {
					$lien_url = $row['url_site'];
					if (!$lien_texte)
						$lien_texte = typo($row['nom_site']);
				}
				break;
			default:
				$lien_url = generer_url_article($id_lien);
				if (!$lien_texte) {
					$req = "select titre from spip_articles where id_article=$id_lien";
					$row = @spip_fetch_array(@spip_query($req));
Fil's avatar
 
Fil a validé
					$lien_texte = $row['titre'];
Fil's avatar
 
Fil a validé
				}
				break;
		}
		$lien_url .= $ancre;

		// supprimer les numeros des titres
		include_ecrire("inc_filtres.php3");
		$lien_texte = supprimer_numero($lien_texte);
Antoine Pitrou's avatar
Antoine Pitrou a validé
	}
	else if (ereg('^\?(.*)$', $lien_url, $regs)) {
		// Liens glossaire
		$lien_url = substr($lien_url, 1);
		$class_lien = "glossaire";
	}
	else {
		// Liens non automatiques
Fil's avatar
 
Fil a validé
		$class_lien = "out";
		// texte vide ?
		if ((!$lien_texte) and (!$lien_interne)) {
			$lien_texte = ereg_replace('"', '', $lien_url);
			if (strlen($lien_texte)>40)
				$lien_texte = substr($lien_texte,0,35).'...';
			$class_lien = "url";
			$lien_texte = "<html>$lien_texte</html>";
Fil's avatar
 
Fil a validé
		}
		// petites corrections d'URL
		if (ereg("^www\.[^@]+$",$lien_url))
			$lien_url = "http://".$lien_url;
Antoine Pitrou's avatar
Antoine Pitrou a validé
		else if (strpos($lien_url, "@") && email_valide($lien_url))
			$lien_url = "mailto:".$lien_url;
Fil's avatar
 
Fil a validé
	}

	$insert = "<a href=\"$lien_url\" class=\"spip_$class_lien\""
Fil's avatar
Fil a validé
		.">".typo($lien_texte)."</a>";
Fil's avatar
 
Fil a validé

	return array($insert, $lien_url);
}
// Traitement des listes (merci a Michael Parienti)
//
function traiter_listes ($texte) {
	$parags = split ("\n[[:space:]]*\n", $texte);
	unset($texte);

	// chaque paragraphe est traite a part
	while (list(,$para) = each($parags)) {
		$niveau = 0;
		$lignes = explode("\n-", "\n" . $para);

		// ne pas toucher a la premiere ligne
		list(,$debut) = each($lignes);
		$texte .= $debut;

		// chaque item a sa profondeur = nb d'etoiles
		unset ($type);
		while (list(,$item) = each($lignes)) {
Fil's avatar
Fil a validé
			ereg("^([*]*|[#]*)([^*#].*)", $item, $regs);
			$profond = strlen($regs[1]);

			if ($profond > 0) {
				unset ($ajout);

				// changement de type de liste au meme niveau : il faut
				// descendre un niveau plus bas, fermer ce niveau, et
				// remonter
				$nouv_type = (substr($item,0,1) == '*') ? 'ul' : 'ol';
				$change_type = ($type AND ($type <> $nouv_type) AND ($profond == $niveau)) ? 1 : 0;
				// d'abord traiter les descentes
				while ($niveau > $profond - $change_type) {
					$ajout .= $pile_li[$niveau];
					$ajout .= $pile_type[$niveau];
Fil's avatar
Fil a validé
					if (!$change_type)
						unset ($pile_li[$niveau]);
				// puis les identites (y compris en fin de descente)
				if ($niveau == $profond && !$change_type) {
Fil's avatar
Fil a validé
					$ajout .= $pile_li[$niveau];
				}

				// puis les montees (y compris apres une descente un cran trop bas)
				while ($niveau < $profond) {
					$niveau ++;
					$ajout .= "<$type class=\"spip\">";
					$pile_type[$niveau] = "</$type>";
				}
				$ajout .= "<li class=\"spip\">";
				$pile_li[$profond] = "</li>";
Antoine Pitrou's avatar
Antoine Pitrou a validé
			else {
			$texte .= $ajout . $regs[2];
		unset ($ajout);
		while ($niveau > 0) {
			$ajout .= $pile_li[$niveau];
			$ajout .= $pile_type[$niveau];
			$niveau --;
		}
		$texte .= $ajout;

		// paragraphe
		$texte .= "\n\n";
	}

	// sucrer les deux derniers \n
	return substr($texte, 0, -2);
}

Yannick Patois's avatar
Yannick Patois a validé
// Nettoie un texte, traite les raccourcis spip, la typo, etc.
function traiter_raccourcis_generale($letexte) {
Antoine Pitrou's avatar
Antoine Pitrou a validé
	global $debut_intertitre, $fin_intertitre, $ligne_horizontale, $url_glossaire_externe;
Yannick Patois's avatar
Yannick Patois a validé
	global $compt_note;
Yannick Patois's avatar
Yannick Patois a validé
	global $ouvre_ref;
	global $ferme_ref;
	global $ouvre_note;
	global $ferme_note;
Antoine Pitrou's avatar
Antoine Pitrou a validé
	global $flag_pcre;
Fil's avatar
Fil a validé
	global $lang_dir;
Yannick Patois's avatar
Yannick Patois a validé

	// Appeler la fonction de pre_traitement
	$letexte = spip_avant_propre ($letexte);
	if (!$lang_dir) {
		include_ecrire('inc_lang.php3');
Fil's avatar
Fil a validé
		$lang_dir = lang_dir($GLOBALS['spip_lang']);
	if ($lang_dir == 'rtl' AND $GLOBALS['puce_rtl'])
		$puce = $GLOBALS['puce_rtl'];
	else
		$puce = $GLOBALS['puce'];
Yannick Patois's avatar
Yannick Patois a validé
	// Harmoniser les retours chariot
	$letexte = ereg_replace ("\r\n?", "\n",$letexte);

	// Corriger HTML
	$letexte = eregi_replace("</?p>","\n\n\n",$letexte);

	//
	// Notes de bas de page
	//
	$regexp = ',\[\[(.*?)\]\],ms';
	if (preg_match_all($regexp, $letexte, $matches, PREG_SET_ORDER))
	foreach ($matches as $regs) {
		$note_source = $regs[0];
Yannick Patois's avatar
Yannick Patois a validé
		$note_texte = $regs[1];
		$num_note = false;
Fil's avatar
Fil a validé

		// note auto ou pas ?
		if (ereg("^ *<([^>]*)>", $note_texte, $regs)){
			$num_note = $regs[1];
			$note_texte = ereg_replace ("^ *<([^>]*)>", "", $note_texte);
Fil's avatar
Fil a validé
		} else {
Yannick Patois's avatar
Yannick Patois a validé
			$compt_note++;
			$num_note = $compt_note;
Yannick Patois's avatar
Yannick Patois a validé
		}
Fil's avatar
Fil a validé

		// preparer la note
			if ($marqueur_notes) // ??????
			$ancre = $mn.urlencode($num_note);
ARNO*'s avatar
ARNO* a validé
			$insert = "$ouvre_ref<a href=\"#nb$ancre\" name=\"nh$ancre\" class=\"spip_note\">$num_note</a>$ferme_ref";
			$appel = "<html>$ouvre_note<a href=\"#nh$ancre\" name=\"nb$ancre\" class=\"spip_note\">$num_note</a>$ferme_note</html>";
Yannick Patois's avatar
Yannick Patois a validé
		} else {
			$insert = '';
Fil's avatar
Fil a validé
			$appel = '';
Yannick Patois's avatar
Yannick Patois a validé
		}
Fil's avatar
Fil a validé

		// l'ajouter "brut" dans les notes
		if ($note_texte) {
			if ($mes_notes)
				$mes_notes .= "\n\n";
Fil's avatar
Fil a validé
			$mes_notes .= $appel . $note_texte;
		}

		// dans le texte, mettre l'appel de note a la place de la note
		$pos = strpos($letexte, $note_source);
		$letexte = substr($letexte, 0, $pos) . $insert
			. substr($letexte, $pos + strlen($note_source));
Yannick Patois's avatar
Yannick Patois a validé
	}

Antoine Pitrou's avatar
Antoine Pitrou a validé
	//
	// Raccourcis automatiques [?SPIP] vers un glossaire
Antoine Pitrou's avatar
Antoine Pitrou a validé
	// (on traite ce raccourci en deux temps afin de ne pas appliquer
	//  la typo sur les URLs, voir raccourcis liens ci-dessous)
	//
	if ($url_glossaire_externe) {
		$regexp = "|\[\?+([^][<>]+)\]|";
		if (preg_match_all($regexp, $letexte, $matches, PREG_SET_ORDER))
		foreach ($matches as $regs) {
Antoine Pitrou's avatar
Antoine Pitrou a validé
			$terme = trim($regs[1]);
Fil's avatar
Fil a validé
			$terme_underscore = urlencode(ereg_replace('[[:space:]]+', '_', $terme));
			if (strstr($url_glossaire_externe,"%s"))
				$url = str_replace("%s", $terme_underscore, $url_glossaire_externe);
Fil's avatar
Fil a validé
			else
				$url = $url_glossaire_externe.$terme_underscore;
			$url = str_replace("@lang@", $GLOBALS['spip_lang'], $url);
Antoine Pitrou's avatar
Antoine Pitrou a validé
			$code = "[$terme->?$url]";
			$letexte = str_replace($regs[0], $code, $letexte);
		}
	}

Yannick Patois's avatar
Yannick Patois a validé
	//
	// Raccourcis ancre [#ancre<-]
	//
	$regexp = "|\[#?([^][]*)<-\]|";
	if (preg_match_all($regexp, $letexte, $matches, PREG_SET_ORDER))
Fil's avatar
Fil a validé
	foreach ($matches as $regs)
		$letexte = str_replace($regs[0],
		'<a name="'.entites_html($regs[1]).'"></a>', $letexte);


	//
	// Raccourcis liens [xxx->url] (cf. fonction extraire_lien ci-dessus)
	// Note : complique car c'est ici qu'on applique la typo() !
Yannick Patois's avatar
Yannick Patois a validé
	//
Fil's avatar
Fil a validé
	$regexp = "|\[([^][]*)->(>?)([^]]*)\]|ms";
Yannick Patois's avatar
Yannick Patois a validé
	$texte_vu = '';
Fil's avatar
Fil a validé
	if (preg_match_all($regexp, $letexte, $matches, PREG_SET_ORDER))
	foreach ($matches as $regs) {
Fil's avatar
 
Fil a validé
		list($insert, $lien) = extraire_lien($regs);
Fil's avatar
Fil a validé
		$pos = strpos($letexte, $regs[0]);
		$texte_vu .= typo(substr($letexte, 0, $pos)) . $insert;
		$letexte = substr($letexte, $pos + strlen($regs[0]));
Yannick Patois's avatar
Yannick Patois a validé
	}
Fil's avatar
Fil a validé
	$letexte = $texte_vu.typo($letexte); // typo de la queue du texte
Yannick Patois's avatar
Yannick Patois a validé

Yannick Patois's avatar
Yannick Patois a validé
	//
	// Tableaux
	//
	$letexte = ereg_replace("^\n?\|", "\n\n|", $letexte);
	$letexte = ereg_replace("\|\n?$", "|\n\n", $letexte);
Antoine Pitrou's avatar
Antoine Pitrou a validé

Yannick Patois's avatar
Yannick Patois a validé
	$tableBeginPos = strpos($letexte, "\n\n|");
	$tableEndPos = strpos($letexte, "|\n\n");
	while (is_integer($tableBeginPos) && is_integer($tableEndPos) && $tableBeginPos < $tableEndPos + 3) {
		$textBegin = substr($letexte, 0, $tableBeginPos);
		$textTable = substr($letexte, $tableBeginPos + 2, $tableEndPos - $tableBeginPos);
		$textEnd = substr($letexte, $tableEndPos + 3);
Antoine Pitrou's avatar
Antoine Pitrou a validé

		$newTextTable = "\n\n<table class=\"spip\">";
Yannick Patois's avatar
Yannick Patois a validé
		$rowId = 0;
		$lineEnd = strpos($textTable, "|\n");
		while (is_integer($lineEnd)) {
			$rowId++;
			$row = substr($textTable, 0, $lineEnd);
			$textTable = substr($textTable, $lineEnd + 2);
			if ($rowId == 1 && ereg("^(\\|[[:space:]]*\\{\\{[^}]+\\}\\}[[:space:]]*)+$", $row)) {
				$newTextTable .= '<tr class="row_first">';
			} else {
				$newTextTable .= '<tr class="row_'.($rowId % 2 ? 'odd' : 'even').'">';
			}
			$newTextTable .= ereg_replace("\|([^\|]+)", "<td>\\1</td>", $row);
			$newTextTable .= '</tr>';
			$lineEnd = strpos($textTable, "|\n");
		}
		$newTextTable .= "</table>\n\n";
Yannick Patois's avatar
Yannick Patois a validé
		$letexte = $textBegin . $newTextTable . $textEnd;

		$tableBeginPos = strpos($letexte, "\n\n|");
		$tableEndPos = strpos($letexte, "|\n\n");
	}
Yannick Patois's avatar
Yannick Patois a validé
	//
	// Ensemble de remplacements implementant le systeme de mise
	// en forme (paragraphes, raccourcis...)
	//
	// ATTENTION : si vous modifiez cette partie, modifiez les DEUX
Antoine Pitrou's avatar
Antoine Pitrou a validé
	// branches de l'alternative (if (!flag_pcre).../else).
Yannick Patois's avatar
Yannick Patois a validé
	//

	$letexte = "\n".trim($letexte);
	if (ereg("\n-[*#]", $letexte))
		$letexte = traiter_listes($letexte);
Antoine Pitrou's avatar
Antoine Pitrou a validé
	if (!$flag_pcre) {
		/* note : on pourrait se passer de cette branche, car ereg_remplace() fonctionne
		   sans pcre ; toutefois les elements ci-dessous sont un peu optimises (str_replace
		   est plus rapide que ereg_replace), donc laissons les deux branches cohabiter, ca
		   permet de gagner un peu de temps chez les hergeurs nazes */
		$letexte = ereg_replace("\n(-{4,}|_{4,})", "@@SPIP_ligne_horizontale@@", $letexte);
		$letexte = ereg_replace("\n-- *", "\n<br />&mdash;&nbsp;",$letexte);
		$letexte = ereg_replace("\n- *", "\n<br />$puce&nbsp;",$letexte);
		$letexte = ereg_replace("\n_ +", "\n<br />",$letexte);
		$letexte = ereg_replace("(( *)\n){2,}(<br[[:space:]]*\/?".">)?", "<p>", $letexte);
		$letexte = str_replace("{{{", "@@SPIP_debut_intertitre@@", $letexte);
		$letexte = str_replace("}}}", "@@SPIP_fin_intertitre@@", $letexte);
Yannick Patois's avatar
Yannick Patois a validé
		$letexte = str_replace("{{", "<b class=\"spip\">", $letexte);
		$letexte = str_replace("}}", "</b>", $letexte);
		$letexte = str_replace("{", "<i class=\"spip\">", $letexte);
		$letexte = str_replace("}", "</i>", $letexte);
		$letexte = eregi_replace("(<br[[:space:]]*/?".">)+(<p>|<br[[:space:]]*/?".">)", "<p class=\"spip\">", $letexte);
Yannick Patois's avatar
Yannick Patois a validé
		$letexte = str_replace("<p>", "<p class=\"spip\">", $letexte);
		$letexte = str_replace("\n", " ", $letexte);
		$letexte = str_replace("<quote>", "<div class=\"spip_quote\">", $letexte);
		$letexte = str_replace("<\/quote>", "</div>", $letexte);
		$letexte = ereg_replace("^ <br />", "", $letexte);
Yannick Patois's avatar
Yannick Patois a validé
	}
	else {
		$cherche1 = array(
			/* 0 */ 	"/\n(----+|____+)/",
			/* 1 */ 	"/\n-- */",
			/* 2 */ 	"/\n- */",
			/* 4 */ 	"/(( *)\n){2,}(<br[[:space:]]*\/?".">)?/",
Yannick Patois's avatar
Yannick Patois a validé
			/* 5 */ 	"/\{\{\{/",
			/* 6 */ 	"/\}\}\}/",
			/* 7 */ 	"/\{\{/",
			/* 8 */ 	"/\}\}/",
			/* 9 */ 	"/\{/",
			/* 10 */	"/\}/",
			/* 11 */	"/(<br[[:space:]]*\/?".">){2,}/",
			/* 12 */	"/<p>([\n]*)(<br[[:space:]]*\/?".">)+/",
Fil's avatar
Fil a validé
			/* 14 		"/\n/", */
			/* 15 */	"/<quote>/",
			/* 16 */	"/<\/quote>/"
Yannick Patois's avatar
Yannick Patois a validé
		);
		$remplace1 = array(
			/* 0 */ 	"@@SPIP_ligne_horizontale@@",
			/* 1 */ 	"\n<br />&mdash;&nbsp;",
			/* 2 */ 	"\n<br />$puce&nbsp;",
			/* 3 */ 	"\n<br />",
			/* 5 */ 	"@@SPIP_debut_intertitre@@",
			/* 6 */ 	"@@SPIP_fin_intertitre@@",
Yannick Patois's avatar
Yannick Patois a validé
			/* 7 */ 	"<b class=\"spip\">",
			/* 8 */ 	"</b>",
			/* 9 */ 	"<i class=\"spip\">",
			/* 10 */	"</i>",
			/* 11 */	"<p class=\"spip\">",
			/* 12 */	"<p class=\"spip\">",
Fil's avatar
Fil a validé
			/* 14 		" ", */
			/* 15 */	"\n\n<blockquote class=\"spip\"><p class=\"spip\">",
			/* 16 */	"</p></blockquote>\n\n"
Yannick Patois's avatar
Yannick Patois a validé
		);
		$letexte = ereg_remplace($cherche1, $remplace1, $letexte);
		$letexte = preg_replace("@^ <br />@", "", $letexte);
Yannick Patois's avatar
Yannick Patois a validé
	}

	// paragrapher
Antoine Pitrou's avatar
Antoine Pitrou a validé
	if (strpos(' '.$letexte, '<p class="spip">'))
		$letexte = '<p class="spip">'.str_replace('<p class="spip">', "</p>\n".'<p class="spip">', $letexte).'</p>';
	// intertitres / hr / blockquote / table / ul compliants
	$letexte = ereg_replace('(<p class="spip">)?[[:space:]]*@@SPIP_debut_intertitre@@', $debut_intertitre, $letexte);
	$letexte = ereg_replace('@@SPIP_fin_intertitre@@[[:space:]]*(</p>)?', $fin_intertitre, $letexte);
	$letexte = ereg_replace('(<p class="spip">)?[[:space:]]*@@SPIP_ligne_horizontale@@[[:space:]]*(</p>)?', $ligne_horizontale, $letexte);
	$letexte = ereg_replace('(<p class="spip">)?[[:space:]]*<blockquote class=\"spip\"></p>', "<blockquote class=\"spip\">", $letexte);
	$letexte = ereg_replace('</blockquote>[[:space:]]*(</p>)?', '</blockquote>', $letexte);
	$letexte = ereg_replace('(<p class="spip">)?[[:space:]]*<table', "<table", $letexte);
	$letexte = ereg_replace('</table>[[:space:]]*(</p>)?', '</table>', $letexte);
	$letexte = ereg_replace('(<p class="spip">)?[[:space:]]*<ul', "<ul", $letexte);
	$letexte = ereg_replace('</ul>[[:space:]]*(</p>)?', '</ul>', $letexte);
Yannick Patois's avatar
Yannick Patois a validé

	// Appeler la fonction de post-traitement
	$letexte = spip_apres_propre ($letexte);
function traiter_les_notes($mes_notes, $les_echap) {
	list($mes_notes,) = traiter_raccourcis_generale($mes_notes);
	if (ereg('<p class="spip">',$mes_notes))
		$mes_notes = ereg_replace('<p class="spip">', '<p class="spip_note">', $mes_notes);
	else
		$mes_notes = '<p class="spip_note">'.$mes_notes."</p>\n";
	$mes_notes = echappe_retour($mes_notes, $les_echap, "SOURCEPROPRE");
	$GLOBALS['les_notes'] .= interdire_scripts($mes_notes);
function traiter_raccourcis($letexte) {
	// echapper les <a href>, <html>...< /html>, <code>...< /code>
	list($letexte, $les_echap) = echappe_html($letexte, "SOURCEPROPRE");
	list($letexte, $mes_notes) = traiter_raccourcis_generale($letexte);
	if ($mes_notes) traiter_les_notes($mes_notes, $les_echap);
	// Reinserer les echappements
	return trim(echappe_retour($letexte, $les_echap, "SOURCEPROPRE"));
Yannick Patois's avatar
Yannick Patois a validé

function traiter_raccourcis_doublon(&$doublons, $letexte) {
	// echapper les <a href>, <html>...< /html>, <code>...< /code>