1doctools::idx::import::docidx(nD)ocumentation toodlosctools::idx::import::docidx(n)
2
3
4
5______________________________________________________________________________
6

NAME

8       doctools::idx::import::docidx - docidx import plugin
9

SYNOPSIS

11       package require Tcl  8.5
12
13       package require doctools::idx::import::docidx  ?0.2.1?
14
15       package require doctools::idx::parse
16
17       package require doctools::idx::structure
18
19       package require doctools::msgcat
20
21       package require doctools::tcl::parse
22
23       package require fileutil
24
25       package require logger
26
27       package require snit
28
29       package require struct::list
30
31       package require struct::set
32
33       package require struct::stack
34
35       package require struct::tree
36
37       package require treeql
38
39       import string configuration
40
41______________________________________________________________________________
42

DESCRIPTION

44       This  package  implements  the doctools keyword index import plugin for
45       the parsing of docidx markup.
46
47       This is an internal package of doctools, for use by  the  higher  level
48       management   packages   handling   keyword   indices,  especially  doc‐
49       tools::idx::import, the import manager.
50
51       Using it from a regular interpreter is possible, however only with con‐
52       tortions, and is not recommended.  The proper way to use this function‐
53       ality is through the package doctools::idx::import and the import  man‐
54       ager objects it provides.
55

API

57       The API provided by this package satisfies the specification of the do‐
58       cidx import plugin API version 2.
59
60       import string configuration
61              This command takes the string and parses it as docidx markup en‐
62              coding a keyword index, in the context of the specified configu‐
63              ration (a dictionary). The result of the command is the  canoni‐
64              cal  serialization  of that keyword index, in the form specified
65              in section Keyword index serialization format.
66

[DOCIDX] NOTATION OF KEYWORD INDICES

68       The docidx format for keyword indices, also called  the  docidx  markup
69       language, is too large to be covered in single section.  The interested
70       reader should start with the document
71
72       [1]    docidx language introduction
73
74       and then proceed from there to the formal specifications, i.e. the doc‐
75       uments
76
77       [1]    docidx language syntax and
78
79       [2]    docidx language command reference.
80
81       to get a thorough understanding of the language.
82

KEYWORD INDEX SERIALIZATION FORMAT

84       Here  we specify the format used by the doctools v2 packages to serial‐
85       ize keyword indices as immutable values for transport, comparison, etc.
86
87       We distinguish between regular and canonical  serializations.  While  a
88       keyword index may have more than one regular serialization only exactly
89       one of them will be canonical.
90
91       regular serialization
92
93              [1]    An index serialization is a nested Tcl dictionary.
94
95              [2]    This dictionary holds a single  key,  doctools::idx,  and
96                     its value. This value holds the contents of the index.
97
98              [3]    The  contents  of  the index are a Tcl dictionary holding
99                     the title of the index, a label,  and  the  keywords  and
100                     references. The relevant keys and their values are
101
102                     title  The  value is a string containing the title of the
103                            index.
104
105                     label  The value is a string containing a label  for  the
106                            index.
107
108                     keywords
109                            The  value is a Tcl dictionary, using the keywords
110                            known to the index as keys. The associated  values
111                            are lists containing the identifiers of the refer‐
112                            ences associated with that particular keyword.
113
114                            Any reference identifier used in these  lists  has
115                            to  exist  as  a key in the references dictionary,
116                            see the next item for its definition.
117
118                     references
119                            The value is a Tcl dictionary, using  the  identi‐
120                            fiers  for  the  references  known to the index as
121                            keys. The associated values  are  2-element  lists
122                            containing the type and label of the reference, in
123                            this order.
124
125                            Any key here has to be associated  with  at  least
126                            one  keyword,  i.e.  occur  in at least one of the
127                            reference lists which are the values in  the  key‐
128                            words  dictionary, see previous item for its defi‐
129                            nition.
130
131              [4]    The type of a reference can be one of two values,
132
133                     manpage
134                            The identifier of the reference is interpreted  as
135                            symbolic  file name, referring to one of the docu‐
136                            ments the index was made for.
137
138                     url    The identifier of the reference is interpreted  as
139                            an  url, referring to some external location, like
140                            a website, etc.
141
142       canonical serialization
143              The canonical serialization of a keyword index has the format as
144              specified  in the previous item, and then additionally satisfies
145              the constraints below, which make it unique among all the possi‐
146              ble serializations of the keyword index.
147
148              [1]    The  keys  found  in  all the nested Tcl dictionaries are
149                     sorted in ascending dictionary  order,  as  generated  by
150                     Tcl's builtin command lsort -increasing -dict.
151
152              [2]    The  references  listed for each keyword of the index, if
153                     any, are listed in ascending dictionary  order  of  their
154                     labels,  as generated by Tcl's builtin command lsort -in‐
155                     creasing -dict.
156

BUGS, IDEAS, FEEDBACK

158       This document, and the package it describes, will  undoubtedly  contain
159       bugs  and  other problems.  Please report such in the category doctools
160       of the Tcllib Trackers [http://core.tcl.tk/tcllib/reportlist].   Please
161       also  report any ideas for enhancements you may have for either package
162       and/or documentation.
163
164       When proposing code changes, please provide unified diffs, i.e the out‐
165       put of diff -u.
166
167       Note  further  that  attachments  are  strongly  preferred over inlined
168       patches. Attachments can be made by going  to  the  Edit  form  of  the
169       ticket  immediately  after  its  creation, and then using the left-most
170       button in the secondary navigation bar.
171

KEYWORDS

173       deserialization, docidx, doctools, import, index
174

CATEGORY

176       Text formatter plugin
177
179       Copyright (c) 2009-2019 Andreas Kupries <andreas_kupries@users.sourceforge.net>
180
181
182
183
184tcllib                               0.2.1    doctools::idx::import::docidx(n)
Impressum