Cliquez ici.
Accueil
 chercher             Plan du site             Info (English version) 
L'histoire de XML s'écrit en ce moment même. XMLfr vous aide à la suivre et à en dégager les tendances.Les listes de discussions XMLfr sont à votre disposition pour réagir sur nos articles ou simplement poser une question.Si vous ètes passionnée(e) par XML, pourquoi ne pas en faire votre métier ?XMLfr n'est heureusement pas le seul site où l'on parle de XML. Découvrez les autres grâce à XMLfr et à l'ODP.Les partenaires grâce auxquels XMLfr peut se développer.Pour tout savoir sur XMLfr.XMLfr sans fil, c'est possible !Pour ceux qui veulent vraiment en savoir plus sur XML.L'index du site.
 Commentaires et questions non techniques.Commentaires et questions techniques.

 
Cliquez ici.

xml tech : Technologies XML

[xml-tech] Re: XSL généré par un autre XSL

[xml-tech] Re: XSL généré par un autre XSL

Auteur: Sylvain Wallez <sylvain.wallez@anyware-tech.com>
Date: 15/12/2004 - 14:45

Damien Raude-Morvan wrote:

>Bonjour à tous,
>
>Afin de faciliter le paramétrage et de décharger le serveur du parsing
>inutile, j'aimerais pouvoir générer de façon statique (= sur action de
>l'admin) des fichiers XSL à partir de gros fichiers XSL sources.
>
>Je dispose d'un premier fichier XSL, classique :
>----------
><xsl:stylesheet version="1.0"
>xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
>
><xsl:template match="/">
> <xsl:apply-templates />
></xsl:template>
>
><xsl:template match="formpart1">
> <h1>Show form part1</h1>
></xsl:template>
>
><xsl:template match="formpart2">
> <h1>Show form part2</h1>
></xsl:template>
>
></xsl:stylesheet>
>----------
>
>J'ai ensuite un second filtre XSL, avec un namespace différent, qui
>permet de parser le premier et d'en resortir uniquement les choses
>voulues (suivant la valeur de xsl:param) :
>----------
><superxsl:stylesheet version="1.0"
>xmlns:superxsl="http://www.w3.org/1999/XSL/Transform"
>xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
>
><superxsl:output method="xml" encoding="ISO-8859-15" indent="yes"/>
>
><superxsl:param name="showpart1">1</superxsl:param>
><superxsl:param name="showpart2">0</superxsl:param>
>
><superxsl:template match="/">
><xsl:text disable-output-escaping="yes"><![CDATA[<xsl:stylesheet
>version="1.0"
>xmlns:xsl="http://www.w3.org/1999/XSL/Transform">]]></xsl:text>
> <superxsl:apply-templates />
><xsl:text
>disable-output-escaping="yes"><![CDATA[</xsl:stylesheet>]]></xsl:text>
></superxsl:template>
>
><superxsl:template match="xsl:template">
>
> <superxsl:if test="@match='/'">
> <superxsl:copy-of select="." />
> </superxsl:if>
>
> <superxsl:if test="$showpart1='1' and @match='formpart1'">
> <superxsl:copy-of select="." />
> </superxsl:if>
>
> <superxsl:if test="$showpart2='1' and @match='formpart2'">
> <superxsl:copy-of select="." />
> </superxsl:if>
>
></superxsl:template>
>
></superxsl:stylesheet>
>----------
>
>Est-ce que ca vous parrait être un bon système ? Est-ce que certains
>d'entre vous on d'autres méthodes pour ce genre de traitement ?
>
>Vos avis m'intéressent :)
>
>

Oh oui, qu'on utilise ça ! Je me serts de ce système pour de décrire des
règles de transformation dans un XML métier (de la doc avion) qui est
ensuite "compilé" en une XSL avec une XSL (que j'appelle "meta-XSL").
L'intérêt est que le langage métier reste compréhensible par le commun
des mortels alors que la XSL correspondante peut être assez compliquée :-)

Un autre cas d'utilisation est "TAL" (template attribute language), issu
de Zope, qui est en grande discussion en ce moment sur les listes Cocoon
: ça permet d'annoter un fichier HTML (ou autre) avec des attributs
décrivant le contenu qui doit venir s'y placer. Cet HTML annoté est
ensuite compilé en XSL avec une XSL. L'intérêt de cette approche est
qu'on garde un fichier HTML "compatible Dreamweaver" qui se compile en XSL.

Plus d'infos sur http://wiki.bitflux.org/Templates_TAL_Example

Par ailleurs, j'appuie les remarques d'Eric : pas besoin de
disable-output-escaping ni de CDATA. On peut rester dans du beau XML
bien propre, xsl:namespace-alias est fait exactement pour ce type
d'utilisation.

Sylvain

-- 
Sylvain Wallez                                  Anyware Technologies
http://www.apache.org/~sylvain           http://www.anyware-tech.com
{ XML, Java, Cocoon, OpenSource }*{ Training, Consulting, Projects }
--
Devenez redacteur <XML>fr et contribuez au developpement du
xml francophone (http://xmlfr.org/infos/redacteurs/) !
Liste de diffusion "xml-tech@xmlfr.org" (http://xmlfr.org).
Cette liste est a votre disposition pour discuter en francais de 
tout sujet technique lie a XML.
Pour resilier votre abonnement, envoyez un message contenant 
la commande "unsubscribe" a xml-tech-request@xmlfr.org
(mailto:xml-tech-request@xmlfr.org?Subject=unsubscribe)
Received on Wed Dec 15 15:45:38 2004

Archive générée par hypermail 2.1.8 le 31/12/2004 - 11:12 UTC

webmaster@xmlfr.org

 

xml tech

Discussions techniques au sujet de XML.

Cette liste est à votre disposition pour discuter en français de tout sujet technique lié à XML.



Devenez rédacteur <XML>fr et contribuez au développement du xml francophone !
Les documents publiés sur ce site le sont sous licence "Open Content"
Conception graphique
  l.henriot@online.fr  

Conception, réalisation et hébergement