[NTG-context] Generate Authorlist example fails, was Re: authors in the toc

Rik Kabel context at rik.users.panix.com
Fri Oct 3 21:09:00 CEST 2014


On 2014-10-02 15:22, Wolfgang Schuster wrote:
>
> Am 02.10.2014 um 19:42 schrieb Rik Kabel <context at rik.users.panix.com 
> <mailto:context at rik.users.panix.com>>:
>
>> On 2014-10-02 05:18, Wolfgang Schuster wrote:
>>> There is a example on the wiki. You have to set your own values with 
>>> the second argument of the \startchapter etc. command, to display 
>>> the entry in the roc you have to write your own layout where you 
>>> access it with the \structurelistuservariable command.
>>>
>>> http://wiki.contextgarden.net/Generate_Authorlist_from_Head_Content
>>>
>>> Wolfgang
>>>
>> This example fails for me using the current (2014-09-27) standalone 
>> beta and with TL14. The failure is that the list of authors is 
>> presented as a grid without contents.
>>
>> Changing any of the lines in the example that construct the table 
>> cells, such as
>>
>>     \bTD \structureuservariable{author} \eTD
>>
>> to
>>
>>     \bTD xx \structureuservariable{author} \eTD
>>
>> results in a table with the new text, but no user variable text, 
>> showing that the \structureuservariable commands are not returning 
>> any text in this example.
>>
>> Has something relevant changed since the example was prepared 
>> (2010-11 or earlier)?
>>
>> (A pointer to useful descriptions of \structureuservariable and 
>> \structurelistuservariable would also be welcome. In the wiki, the 
>> startsection command description describes the former, but I have 
>> come across no comprehensive description for either in the 
>> documentation.)
>
> First you have to make a distinction between the values which are set 
> with the first and second argument of \startchapter, \startsection 
> etc.  While the first argument takes only certain keys, e.g. title, 
> bookmark etc. you’re free to choose your own keys for the second 
> argument because they are considered userdata.  The point of this 
> userdata is to give users a way to specify information which are 
> printed in the table of content or in the header, to access these 
> values context provides two commands.  When you create a new layout 
> for the table of contents you can use the \structurelistuservariable 
> command which takes the name of the key with the information as 
> argument and when you create a new header layout you can use the 
> \structureuservariable command.
>
>
> \define[3]\ChapterListCommand
>   {\starttabulate
>    \NC Number \NC #1 \NC\NR
>    \NC Title  \NC #2 \NC\NR
>    \NC Page   \NC #3 \NC\NR
>    \TB[medium]
>    \NC File   \NC \structurelistuservariable{file} \NC\NR
>    \stoptabulate}
>
> \setuplist[chapter][alternative=command,command=\ChapterListCommand]
>
> \define[2]\ChapterHeadCommand
>   {\startframed[align=flushleft,strut=no]
>      \starttabulate[before=,after=]
>      \NC Number \NC #1 \NC\NR
>      \NC Title  \NC #2 \NC\NR
>      \TB[medium]
>      \NC File   \NC \structureuservariable{file} \NC\NR
>      \stoptabulate
>    \stopframed}
>
> \setuphead[chapter][command=\ChapterHeadCommand]
>
> \starttext
>
> \completecontent
>
> \startchapter[title=Knuth example][file=knuth.tex]
> \input knuth
> \stopchapter
>
> \startchapter[title=Zapf example][file=zapf.tex]
> \input zapf
> \stopchapter
>
> \stoptext
>
> Wolfgang
>
Thank you, Wolfgang, for that explanation.

Can you suggest what might be wrong with the example at 
http://wiki.contextgarden.net/Generate_Authorlist_from_Head_Content?

The list of authors is created, so the user variable 'author' is set at 
for \doifsomething. When the index for the author list is set to a 
constant, only one row is generated, but when it is the user variable 
'name' the right number of rows is created, so 'name' is also set when 
it is referenced as the key in the author list sorting macro. Each line 
of the table is empty, suggesting that within the scope of the table the 
user variables are reset to nil. The same problem exists when 
\starttabulate is used instead of \bTABLE.

-- 
Rik

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.ntg.nl/pipermail/ntg-context/attachments/20141003/e0a9b3b7/attachment-0001.html>


More information about the ntg-context mailing list