Bonjour,
Le jeudi 03 février 2005 à 17:16 +0100, alexandre a écrit :
> Toutes mes excuses pour le message précédent, je l'ai envoyé au format
> html et c'est assez illisible.
Oui, le gestionnaire de liste n'aime pas beaucoup cela!
> Ah, au moins on peut mettre un prédicat, chouette :)
> Néanmoins, je n'ai pas réussi à adapter votre suggestion à mes besoins.
> Je crois que je ne me suis pas encore adapté au mode de pensée xsl.
> Si j'applique votre méthode sur l'original suivant :
> <!-- ---------------------------------------------------- -->
> <parent>
> <sibling-précédent>un sibling</sibling-précédent>
> <detail>detail 1</detail>
> <detail>detail 2</detail>
> </parent>
> <!-- ---------------------------------------------------- -->
>
> j'obtiens :
> <!-- ---------------------------------------------------- -->
> <parent>
> <sibling-précédent>un sibling</sibling-précédent>
> <details>
> <detail>detail 1</detail>
> </details>
> <details>
> <detail>detail 2</detail>
> </details>
> </parent>
> <!-- ---------------------------------------------------- -->
>
> mais j'aimerais obtenir ceci :
> <!-- ---------------------------------------------------- -->
> <parent>
> <sibling-précédent>un sibling</sibling-précédent>
> <details>
> <detail>detail 1</detail>
> <detail>detail 2</detail>
> </details>
> </parent>
> <!-- ---------------------------------------------------- -->
>
> Autrement dit, j'aimerais créer un nouvel élément (<details>) qui aurait
> pour enfants un groupe de noeuds existants (<detail>).
> Ou encore, tous les frères cadets de <sibling-précédent> deviendraient
> ses neveux et son nouveau et unique frêre cadet serait <details> ;)
Revenons à la définition de votre template... en écrivant :
<xsl:template match="*::[preceding-sibling::sibling-précédent]">
<details>
<xsl:copy>
<xsl:apply-templates select="@* | * | text()"/>
</xsl:copy>
</details>
</xsl:template>
vous définissez une règle qui va être exécutée pour chaque noeud
vérifiant la clause match et il est donc normal de générer un élément
details par noeud.
Pour corriger cela, il faut donc générer l'élément "details" avant
d'appeler les règles par xsl:apply-templates ou faire en sorte que seul
le premier "detail" le fasse et appelle les suivants.
Il y a beaucoup de variantes possibles, mais si on suit cette deuxième
stratégie, on pourra écrire :
<xsl:template match="*::[preceding-sibling::sibling-précédent]"/>
<xsl:template match="*::[preceding-sibling::sibling-précédent][1]" priority="1">
<details>
<xsl:apply-templates select=".|following-sibling::*" mode="details"/>
</details>
</xsl:template>
<xsl:template match="*" mode="details">
<xsl:copy>
<xsl:apply-templates select="@* | * | text()"/>
</xsl:copy>
</xsl:template>
Cordialement,
Eric van der Vlist
--
Don't you think all these XML schema languages should work together?
http://dsdl.org
------------------------------------------------------------------------
Eric van der Vlist http://xmlfr.org http://dyomedea.com
(ISO) RELAX NG ISBN:0-596-00421-4 http://oreilly.com/catalog/relax
(W3C) XML Schema ISBN:0-596-00252-1 http://oreilly.com/catalog/xmlschema
------------------------------------------------------------------------
--
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 Thu Feb 3 17:47:01 2005