Hi Denis,

Ok, after a bit of more testing I can now come up with another example.

The version using startstop works, but with the normal command, I'm always 
getting back the content of the first element. I thought it might be an 
expansion issue, but \expanded and also expansion=yes or expansion=xml on 
\definedescription have no effect. Perhaps most interestingly, adding using the 
startstop variant together with the command variant gives correct results for 
the command as well (xml:index-entry-term-3).

I have now found a way to proceed with my project (I'll just use the startstop 
variant), but I'd still be interested in understanding what is happening here. 
Does anyone know? Or is there anything I'm doing wrong here?

This is kind of tricky but here is a variant test

\startxmlsetups xml:index-entry-term-1 % does not work
    \indexentry{1: \xmlflush{#1}}
%     test \par
    \indexentry{2: \xmlflush{#1}}
    3: \xmlflush{#1}
    \par
\stopxmlsetups

it has to do with the fact that when you don't use a start / stop the next paragraph is sees as description content so then you grab the same entry (sort of) nested

you can uncomment the "test \par" to see the side effects (twice one versus 1/2)

it's kind of hard to debug this, i admit,

Hans


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\startxmlsetups xml:test
               \xmlsetsetup{#1}{*}{-}
               \xmlsetsetup{#1}{index}{xml:*}
               \xmlsetsetup{#1}{index-entry}{xml:index-entry}
               %\xmlsetsetup{#1}{term}{xml:index-entry-term}
               \xmlsetsetup{#1}{term}{xml:index-entry-term-2}
               \xmlsetsetup{#1}{term}{xml:index-entry-term-3}
\stopxmlsetups

\xmlregisterdocumentsetup{test}{xml:test}

% Index

\startxmlsetups xml:book-back
               \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index
               \xmlflush{#1}
\stopxmlsetups

\definedescription[indexentry][]
%\definedescription[indexentry][expansion=yes] % has no effect
%\definedescription[indexentry][expansion=xml] % has no effect


\startxmlsetups xml:index-entry
               \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index-entry-term % does not work
               \expanded{\indexentry{\xmlflush{#1}}}
               \indexentry{\xmlflush{#1}}
   \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index-entry-term-2 % works
\startindexentry{\xmlflush{#1}}
\xmlflush{#1}
\stopindexentry
\stopxmlsetups

\startxmlsetups xml:index-entry-term-3 % works
\expanded{\indexentry{\xmlflush{#1}}}
\indexentry{\xmlflush{#1}}
\startindexentry{\xmlflush{#1}}
\xmlflush{#1}
\stopindexentry
\stopxmlsetups


\startbuffer[test]
<?xml version="1.0" encoding="UTF-8"?>
<index>
<index-entry>
<term>One</term>
</index-entry>
<index-entry>
<term>Two</term>
</index-entry>
<index-entry>
<term>Three</term>
</index-entry>
</index>
\stopbuffer

\starttext

\xmlprocessbuffer{test}{test}{}

\stoptext
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

Von: denis.ma...@unibe.ch <denis.ma...@unibe.ch>
Gesendet: Montag, 24. Juli 2023 15:57
An: ntg-context@ntg.nl
Betreff: [NTG-context] Re: xml: matches always child of other element

Interestingly, we should be in the right subtree as this modified example is 
supposed to demonstrate (we're getting the correct numbers under each 
index-entry-term, just the terms are incorrect in all but the first case):

\startxmlsetups xml:test
                 \xmlsetsetup{#1}{*}{-}
                 \xmlsetsetup{#1}{index}{xml:*}
                 \xmlsetsetup{#1}{index-entry}{xml:index-entry}
                 %\xmlsetsetup{#1}{index-entry}{xml:index-entry-2}
                 \xmlsetsetup{#1}{term}{xml:index-entry-term}
                 \xmlsetsetup{#1}{nav-pointer-group}{xml:*}
                 \xmlsetsetup{#1}{nav-pointer}{xml:nav-pointer}
                 \xmlsetsetup{#1}{nav-pointer/ext-link}{xml:nav-pointer-link}
\stopxmlsetups

\xmlregisterdocumentsetup{test}{xml:test}

% Index

\startxmlsetups xml:book-back
                 \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index
   
\startsectionlevel[title={\xmlfilter{#1}{/index-title-group/title/command(xml:index-title)}},]
                 \xmlflush{#1}
   \stopsectionlevel
\stopxmlsetups

\startxmlsetups xml:index-title
                 \xmlflush{#1}
\stopxmlsetups

\definedescription[indexentry]
                 [alternative=top,
                 headstyle=normal,
     headcommand=\hskip-1cm,
                 margin=1cm,
                 inbetween=,
                 ]

\startxmlsetups xml:index-entry
                 \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index-entry-2
     \xmlfilter{#1}{/term/command(xml:index-entry-term)}%
     \xmlverbatim{#1}
\stopxmlsetups

\startxmlsetups xml:index-entry-term
                 \indexentry{\xmlflush{#1}}
\stopxmlsetups

\startxmlsetups xml:nav-pointer-group
                 \xmlconcat{#1}{/nav-pointer}{, }
\stopxmlsetups

\startxmlsetups xml:nav-pointer
                 \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:nav-pointer-link
                 \xmlflush{#1}
\stopxmlsetups

\startbuffer[test]
<?xml version="1.0" encoding="UTF-8"?>
<index>
       <index-title-group>
         <title>Index</title>
       </index-title-group>
       <index-entry>
         <term>First</term>
         <nav-pointer-group>
           <nav-pointer>
             <ext-link>1</ext-link>
           </nav-pointer>
           <nav-pointer>
             <ext-link>2</ext-link>
           </nav-pointer>
           <nav-pointer>
             <ext-link>3</ext-link>
           </nav-pointer>
         </nav-pointer-group>
       </index-entry>
       <index-entry>
         <term>Second</term>
         <nav-pointer-group>
           <nav-pointer>
             <ext-link>4</ext-link>
           </nav-pointer>
         </nav-pointer-group>
       </index-entry>
       <index-entry>
         <term>Third</term>
         <nav-pointer-group>
           <nav-pointer>
             <ext-link>5</ext-link>
           </nav-pointer>
           <nav-pointer>
             <ext-link>6</ext-link>
           </nav-pointer>
           <nav-pointer>
             <ext-link>7</ext-link>
           </nav-pointer>
         </nav-pointer-group>
       </index-entry>
</index>
\stopbuffer


\starttext

\xmlprocessbuffer{test}{test}{}

\stoptext

Von: denis.ma...@unibe.ch<mailto:denis.ma...@unibe.ch> 
<denis.ma...@unibe.ch<mailto:denis.ma...@unibe.ch>>
Gesendet: Montag, 24. Juli 2023 13:38
An: ntg-context@ntg.nl<mailto:ntg-context@ntg.nl>
Betreff: [NTG-context] xml: matches always child of other element

Hi,

I must be missing something obvious, but in this example the pattern for <term> 
always matches the first element, not the one under the current <index-entry>.
Interestingly, using xml:index-entry-2 instead of the normal version matches 
correctly... Any hints what is going off the rails here?

Best,
Denis

\startxmlsetups xml:test
                 \xmlsetsetup{#1}{*}{-}
                 \xmlsetsetup{#1}{index}{xml:*}
                 \xmlsetsetup{#1}{index-entry}{xml:index-entry}
                 %\xmlsetsetup{#1}{index-entry}{xml:index-entry-2}
                 \xmlsetsetup{#1}{term}{xml:index-entry-term}
                 \xmlsetsetup{#1}{nav-pointer-group}{xml:*}
                 \xmlsetsetup{#1}{nav-pointer}{xml:nav-pointer}
                 \xmlsetsetup{#1}{nav-pointer/ext-link}{xml:nav-pointer-link}
\stopxmlsetups

\xmlregisterdocumentsetup{test}{xml:test}

% Index

\startxmlsetups xml:book-back
                 \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index
   
\startsectionlevel[title={\xmlfilter{#1}{/index-title-group/title/command(xml:index-title)}},]
                 \xmlflush{#1}
   \stopsectionlevel
\stopxmlsetups

\startxmlsetups xml:index-title
                 \xmlflush{#1}
\stopxmlsetups

\definedescription[indexentry]
                 [alternative=top,
                 headstyle=normal,
     headcommand=\hskip-1cm,
                 margin=1cm,
                 inbetween=,
                 ]

\startxmlsetups xml:index-entry
                 \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:index-entry-2
     \xmlfilter{#1}{/term/command(xml:index-entry-term)}%
     \xmlverbatim{#1}
\stopxmlsetups

\startxmlsetups xml:index-entry-term
                 \indexentry{\xmlflush{#1}}
\stopxmlsetups

\startxmlsetups xml:nav-pointer-group
                 \xmlconcat{#1}{/nav-pointer}{, }
\stopxmlsetups

\startxmlsetups xml:nav-pointer
                 \xmlflush{#1}
\stopxmlsetups

\startxmlsetups xml:nav-pointer-link
                 \xmlflush{#1}
\stopxmlsetups

\startbuffer[test]
<?xml version="1.0" encoding="UTF-8"?>
<index>
       <index-title-group>
         <title>Index</title>
       </index-title-group>
       <index-entry>
         <term>First</term>
         <nav-pointer-group>
           <nav-pointer>
             <ext-link>1</ext-link>
           </nav-pointer>
           <nav-pointer>
             <ext-link>2</ext-link>
           </nav-pointer>
           <nav-pointer>
             <ext-link>3</ext-link>
           </nav-pointer>
         </nav-pointer-group>
       </index-entry>
       <index-entry>
         <term>Second</term>
         <nav-pointer-group>
           <nav-pointer>
             <ext-link>1</ext-link>
           </nav-pointer>
         </nav-pointer-group>
       </index-entry>
       <index-entry>
         <term>Third</term>
         <nav-pointer-group>
           <nav-pointer>
             <ext-link>1</ext-link>
           </nav-pointer>
         </nav-pointer-group>
       </index-entry>
</index>
\stopbuffer

\starttext

\xmlprocessbuffer{test}{test}{}

\stoptext


___________________________________________________________________________________
If your question is of interest to others as well, please add an entry to the 
Wiki!

maillist : ntg-context@ntg.nl / https://www.ntg.nl/mailman/listinfo/ntg-context
webpage  : https://www.pragma-ade.nl / http://context.aanhet.net
archive  : https://bitbucket.org/phg/context-mirror/commits/
wiki     : https://contextgarden.net
___________________________________________________________________________________

--

-----------------------------------------------------------------
                                          Hans Hagen | PRAGMA ADE
              Ridderstraat 27 | 8061 GH Hasselt | The Netherlands
       tel: 038 477 53 69 | www.pragma-ade.nl | www.pragma-pod.nl
-----------------------------------------------------------------

___________________________________________________________________________________
If your question is of interest to others as well, please add an entry to the 
Wiki!

maillist : ntg-context@ntg.nl / https://www.ntg.nl/mailman/listinfo/ntg-context
webpage  : https://www.pragma-ade.nl / http://context.aanhet.net
archive  : https://bitbucket.org/phg/context-mirror/commits/
wiki     : https://contextgarden.net
___________________________________________________________________________________

Reply via email to