efd69da250ac5932a740e3f59e2759272422cf9c
[idzebra-moved-to-github.git] / doc / recordmodel.xml
1  <chapter id="record-model">
2   <!-- $Id: recordmodel.xml,v 1.16 2002-12-30 10:25:24 adam Exp $ -->
3   <title>The Record Model</title>
4   
5   <para>
6    The Zebra system is designed to support a wide range of data management
7    applications. The system can be configured to handle virtually any
8    kind of structured data. Each record in the system is associated with
9    a <emphasis>record schema</emphasis> which lends context to the data
10    elements of the record.
11    Any number of record schemas can coexist in the system.
12    Although it may be wise to use only a single schema within
13    one database, the system poses no such restrictions.
14   </para>
15
16   <para>
17    The record model described in this chapter applies to the fundamental,
18    structured
19    record type <literal>grs</literal>, introduced in
20    <xref linkend="record-types"/>.
21    <!--
22    FIXME - Need to describe the simple string-tag model, or at least 
23    refer to it here. -H
24    -->
25   </para>
26
27   <para>
28    Records pass through three different states during processing in the
29    system.
30   </para>
31
32   <para>
33
34    <itemizedlist>
35     <listitem>
36      
37      <para>
38       When records are accessed by the system, they are represented
39       in their local, or native format. This might be SGML or HTML files,
40       News or Mail archives, MARC records. If the system doesn't already
41       know how to read the type of data you need to store, you can set up an
42       input filter by preparing conversion rules based on regular
43       expressions and possibly augmented by a flexible scripting language
44       (Tcl).
45       The input filter produces as output an internal representation,
46       a tree structure.
47
48      </para>
49     </listitem>
50     <listitem>
51
52      <para>
53       When records are processed by the system, they are represented
54       in a tree-structure, constructed by tagged data elements hanging off a
55       root node. The tagged elements may contain data or yet more tagged
56       elements in a recursive structure. The system performs various
57       actions on this tree structure (indexing, element selection, schema
58       mapping, etc.),
59
60      </para>
61     </listitem>
62     <listitem>
63
64      <para>
65       Before transmitting records to the client, they are first
66       converted from the internal structure to a form suitable for exchange
67       over the network - according to the Z39.50 standard.
68      </para>
69     </listitem>
70
71    </itemizedlist>
72
73   </para>
74
75   <sect1 id="local-representation">
76    <title>Local Representation</title>
77
78    <para>
79     As mentioned earlier, Zebra places few restrictions on the type of
80     data that you can index and manage. Generally, whatever the form of
81     the data, it is parsed by an input filter specific to that format, and
82     turned into an internal structure that Zebra knows how to handle. This
83     process takes place whenever the record is accessed - for indexing and
84     retrieval.
85    </para>
86
87    <para>
88     The RecordType parameter in the <literal>zebra.cfg</literal> file, or
89     the <literal>-t</literal> option to the indexer tells Zebra how to
90     process input records.
91     Two basic types of processing are available - raw text and structured
92     data. Raw text is just that, and it is selected by providing the
93     argument <emphasis>text</emphasis> to Zebra. Structured records are
94     all handled internally using the basic mechanisms described in the
95     subsequent sections.
96     Zebra can read structured records in many different formats.
97     How this is done is governed by additional parameters after the
98     "grs" keyword, separated by "." characters.
99    </para>
100
101    <para>
102     Four basic subtypes to the <emphasis>grs</emphasis> type are
103     currently available:
104    </para>
105
106    <para>
107     <variablelist>
108      <varlistentry>
109       <term>grs.sgml</term>
110       <listitem>
111        <para>
112         This is the canonical input format &mdash;
113         described below. It is a simple SGML-like syntax.
114        </para>
115       </listitem>
116      </varlistentry>
117      <varlistentry>
118       <term>grs.regx.<emphasis>filter</emphasis></term>
119       <listitem>
120        <para>
121         This enables a user-supplied input
122         filter. The mechanisms of these filters are described below.
123        </para>
124       </listitem>
125      </varlistentry>
126      <varlistentry>
127       <term>grs.tcl.<emphasis>filter</emphasis></term>
128       <listitem>
129        <para>
130         Similar to grs.regx but using Tcl for rules.
131        </para>
132       </listitem>
133      </varlistentry>
134      <varlistentry>
135       <term>grs.marc.<emphasis>abstract syntax</emphasis></term>
136       <listitem>
137        <para>
138         This allows Zebra to read
139         records in the ISO2709 (MARC) encoding standard. In this case, the
140         last parameter <emphasis>abstract syntax</emphasis> names the
141         <literal>.abs</literal> file (see below)
142         which describes the specific MARC structure of the input record as
143         well as the indexing rules.
144        </para>
145       </listitem>
146      </varlistentry>
147      <varlistentry>
148       <term>grs.xml</term>
149       <listitem>
150        <para>
151         This filter reads XML records. Only one record per file
152         is supported. The filter is only available if Zebra/YAZ
153         is compiled with EXPAT support.
154        </para>
155       </listitem>
156      </varlistentry>
157
158     </variablelist>
159    </para>
160
161    <sect2>
162     <title>Canonical Input Format</title>
163
164     <para>
165      Although input data can take any form, it is sometimes useful to
166      describe the record processing capabilities of the system in terms of
167      a single, canonical input format that gives access to the full
168      spectrum of structure and flexibility in the system. In Zebra, this
169      canonical format is an "SGML-like" syntax.
170     </para>
171
172     <para>
173      To use the canonical format specify <literal>grs.sgml</literal> as
174      the record type.
175     </para>
176
177     <para>
178      Consider a record describing an information resource (such a record is
179      sometimes known as a <emphasis>locator record</emphasis>).
180      It might contain a field describing the distributor of the
181      information resource, which might in turn be partitioned into
182      various fields providing details about the distributor, like this:
183     </para>
184
185     <para>
186
187      <screen>
188       &#60;Distributor&#62;
189         &#60;Name&#62; USGS/WRD &#60;/Name&#62;
190         &#60;Organization&#62; USGS/WRD &#60;/Organization&#62;
191         &#60;Street-Address&#62;
192           U.S. GEOLOGICAL SURVEY, 505 MARQUETTE, NW
193         &#60;/Street-Address&#62;
194         &#60;City&#62; ALBUQUERQUE &#60;/City&#62;
195         &#60;State&#62; NM &#60;/State&#62;
196         &#60;Zip-Code&#62; 87102 &#60;/Zip-Code&#62;
197         &#60;Country&#62; USA &#60;/Country&#62;
198         &#60;Telephone&#62; (505) 766-5560 &#60;/Telephone&#62;
199       &#60;/Distributor&#62;
200      </screen>
201
202     </para>
203
204     <!-- There is no indentation in the example above!  -H
205     -note-
206      -para-
207       The indentation used above is used to illustrate how Zebra
208       interprets the mark-up. The indentation, in itself, has no
209       significance to the parser for the canonical input format, which
210       discards superfluous whitespace.
211      -/para-
212     -/note-
213     -->
214
215     <para>
216      The keywords surrounded by &lt;...&gt; are
217      <emphasis>tags</emphasis>, while the sections of text
218      in between are the <emphasis>data elements</emphasis>.
219      A data element is characterized by its location in the tree
220      that is made up by the nested elements.
221      Each element is terminated by a closing tag - beginning
222      with <literal>&#60;</literal>/, and containing the same symbolic
223      tag-name as the corresponding opening tag.
224      The general closing tag - <literal>&lt;/&gt;</literal> -
225      terminates the element started by the last opening tag. The
226      structuring of elements is significant.
227      The element <emphasis>Telephone</emphasis>,
228      for instance, may be indexed and presented to the client differently,
229      depending on whether it appears inside the
230      <emphasis>Distributor</emphasis> element, or some other,
231      structured data element such a <emphasis>Supplier</emphasis> element.
232     </para>
233
234     <sect3>
235      <title>Record Root</title>
236
237      <para>
238       The first tag in a record describes the root node of the tree that
239       makes up the total record. In the canonical input format, the root tag
240       should contain the name of the schema that lends context to the
241       elements of the record
242       (see <xref linkend="internal-representation"/>).
243       The following is a GILS record that
244       contains only a single element (strictly speaking, that makes it an
245       illegal GILS record, since the GILS profile includes several mandatory
246       elements - Zebra does not validate the contents of a record against
247       the Z39.50 profile, however - it merely attempts to match up elements
248       of a local representation with the given schema):
249      </para>
250
251      <para>
252
253       <screen>
254        &#60;gils&#62;
255           &#60;title&#62;Zen and the Art of Motorcycle Maintenance&#60;/title&#62;
256        &#60;/gils&#62;
257       </screen>
258
259      </para>
260
261     </sect3>
262
263     <sect3><!-- ### we shouldn't make such a big deal about this -->
264      <title>Variants</title>
265
266      <para>
267       Zebra allows you to provide individual data elements in a number of
268       <emphasis>variant forms</emphasis>. Examples of variant forms are
269       textual data elements which might appear in different languages, and
270       images which may appear in different formats or layouts.
271       The variant system in Zebra is essentially a representation of
272       the variant mechanism of Z39.50-1995.
273      </para>
274
275      <para>
276       The following is an example of a title element which occurs in two
277       different languages.
278      </para>
279
280      <para>
281
282       <screen>
283        &#60;title&#62;
284        &#60;var lang lang "eng"&#62;
285        Zen and the Art of Motorcycle Maintenance&#60;/&#62;
286        &#60;var lang lang "dan"&#62;
287        Zen og Kunsten at Vedligeholde en Motorcykel&#60;/&#62;
288        &#60;/title&#62;
289       </screen>
290
291      </para>
292
293      <para>
294       The syntax of the <emphasis>variant element</emphasis> is
295       <literal>&lt;var class type value&gt;</literal>.
296       The available values for the <emphasis>class</emphasis> and
297       <emphasis>type</emphasis> fields are given by the variant set
298       that is associated with the current schema
299       (see <xref linkend="variant-set"/>).
300      </para>
301
302      <para>
303       Variant elements are terminated by the general end-tag &#60;/&#62;, by
304       the variant end-tag &#60;/var&#62;, by the appearance of another variant
305       tag with the same <emphasis>class</emphasis> and
306       <emphasis>value</emphasis> settings, or by the
307       appearance of another, normal tag. In other words, the end-tags for
308       the variants used in the example above could have been omitted.
309      </para>
310
311      <para>
312       Variant elements can be nested. The element
313      </para>
314
315      <para>
316
317       <screen>
318        &#60;title&#62;
319        &#60;var lang lang "eng"&#62;&#60;var body iana "text/plain"&#62;
320        Zen and the Art of Motorcycle Maintenance
321        &#60;/title&#62;
322       </screen>
323
324      </para>
325
326      <para>
327       Associates two variant components to the variant list for the title
328       element.
329      </para>
330
331      <para>
332       Given the nesting rules described above, we could write
333      </para>
334
335      <para>
336
337       <screen>
338        &#60;title&#62;
339        &#60;var body iana "text/plain&#62;
340        &#60;var lang lang "eng"&#62;
341        Zen and the Art of Motorcycle Maintenance
342        &#60;var lang lang "dan"&#62;
343        Zen og Kunsten at Vedligeholde en Motorcykel
344        &#60;/title&#62;
345       </screen>
346
347      </para>
348
349      <para>
350       The title element above comes in two variants. Both have the IANA body
351       type "text/plain", but one is in English, and the other in
352       Danish. The client, using the element selection mechanism of Z39.50,
353       can retrieve information about the available variant forms of data
354       elements, or it can select specific variants based on the requirements
355       of the end-user.
356      </para>
357
358     </sect3>
359
360    </sect2>
361
362    <sect2>
363     <title>Input Filters</title>
364
365     <para>
366      In order to handle general input formats, Zebra allows the
367      operator to define filters which read individual records in their
368      native format and produce an internal representation that the system
369      can work with.
370     </para>
371
372     <para>
373      Input filters are ASCII files, generally with the suffix
374      <literal>.flt</literal>.
375      The system looks for the files in the directories given in the
376      <emphasis>profilePath</emphasis> setting in the
377      <literal>zebra.cfg</literal> files.
378      The record type for the filter is
379      <literal>grs.regx.</literal><emphasis>filter-filename</emphasis>
380      (fundamental type <literal>grs</literal>, file read
381      type <literal>regx</literal>, argument
382      <emphasis>filter-filename</emphasis>).
383     </para>
384     
385     <para>
386      Generally, an input filter consists of a sequence of rules, where each
387      rule consists of a sequence of expressions, followed by an action. The
388      expressions are evaluated against the contents of the input record,
389      and the actions normally contribute to the generation of an internal
390      representation of the record.
391     </para>
392     
393     <para>
394      An expression can be either of the following:
395     </para>
396
397     <para>
398      <variablelist>
399
400       <varlistentry>
401        <term>INIT</term>
402        <listitem>
403         <para>
404          The action associated with this expression is evaluated
405          exactly once in the lifetime of the application, before any records
406          are read. It can be used in conjunction with an action that
407          initializes tables or other resources that are used in the processing
408          of input records.
409         </para>
410        </listitem>
411       </varlistentry>
412       <varlistentry>
413        <term>BEGIN</term>
414        <listitem>
415         <para>
416          Matches the beginning of the record. It can be used to
417          initialize variables, etc. Typically, the
418          <emphasis>BEGIN</emphasis> rule is also used
419          to establish the root node of the record.
420         </para>
421        </listitem>
422       </varlistentry>
423       <varlistentry>
424        <term>END</term>
425        <listitem>
426         <para>
427          Matches the end of the record - when all of the contents
428          of the record has been processed.
429         </para>
430        </listitem>
431       </varlistentry>
432       <varlistentry>
433        <term>/pattern/</term>
434        <listitem>
435         <para>
436          Matches a string of characters from the input record.
437         </para>
438        </listitem>
439       </varlistentry>
440       <varlistentry>
441        <term>BODY</term>
442        <listitem>
443         <para>
444          This keyword may only be used between two patterns.
445          It matches everything between (not including) those patterns.
446         </para>
447        </listitem>
448       </varlistentry>
449       <varlistentry>
450        <term>FINISH</term>
451        <listitem>
452         <para>
453          The expression associated with this pattern is evaluated
454          once, before the application terminates. It can be used to release
455          system resources - typically ones allocated in the
456          <emphasis>INIT</emphasis> step.
457         </para>
458        </listitem>
459       </varlistentry>
460      </variablelist>
461     </para>
462
463     <para>
464      An action is surrounded by curly braces ({...}), and
465      consists of a sequence of statements. Statements may be separated
466      by newlines or semicolons (;).
467      Within actions, the strings that matched the expressions
468      immediately preceding the action can be referred to as
469      $0, $1, $2, etc.
470     </para>
471
472     <para>
473      The available statements are:
474     </para>
475
476     <para>
477      <variablelist>
478
479       <varlistentry>
480        <term>begin <emphasis>type [parameter ... ]</emphasis></term>
481        <listitem>
482         <para>
483          Begin a new
484          data element. The type is one of the following:
485          <variablelist>
486           
487           <varlistentry>
488            <term>record</term>
489            <listitem>
490             <para>
491              Begin a new record. The following parameter should be the
492              name of the schema that describes the structure of the record, eg.
493              <literal>gils</literal> or <literal>wais</literal> (see below).
494              The <literal>begin record</literal> call should precede
495              any other use of the <emphasis>begin</emphasis> statement.
496             </para>
497            </listitem>
498           </varlistentry>
499           <varlistentry>
500            <term>element</term>
501            <listitem>
502             <para>
503              Begin a new tagged element. The parameter is the
504              name of the tag. If the tag is not matched anywhere in the tagsets
505              referenced by the current schema, it is treated as a local string
506              tag.
507             </para>
508            </listitem>
509           </varlistentry>
510           <varlistentry>
511            <term>variant</term>
512            <listitem>
513             <para>
514              Begin a new node in a variant tree. The parameters are
515              <emphasis>class type value</emphasis>.
516             </para>
517            </listitem>
518           </varlistentry>
519          </variablelist>
520         </para>
521        </listitem>
522       </varlistentry>
523       <varlistentry>
524        <term>data</term>
525        <listitem>
526         <para>
527          Create a data element. The concatenated arguments make
528          up the value of the data element.
529          The option <literal>-text</literal> signals that
530          the layout (whitespace) of the data should be retained for
531          transmission.
532          The option <literal>-element</literal>
533          <emphasis>tag</emphasis> wraps the data up in
534          the <emphasis>tag</emphasis>.
535          The use of the <literal>-element</literal> option is equivalent to
536          preceding the command with a <emphasis>begin
537           element</emphasis> command, and following
538          it with the <emphasis>end</emphasis> command.
539         </para>
540        </listitem>
541       </varlistentry>
542       <varlistentry>
543        <term>end <emphasis>[type]</emphasis></term>
544        <listitem>
545         <para>
546          Close a tagged element. If no parameter is given,
547          the last element on the stack is terminated.
548          The first parameter, if any, is a type name, similar
549          to the <emphasis>begin</emphasis> statement.
550          For the <emphasis>element</emphasis> type, a tag
551          name can be provided to terminate a specific tag.
552         </para>
553        </listitem>
554       </varlistentry>
555      </variablelist>
556     </para>
557
558     <para>
559      The following input filter reads a Usenet news file, producing a
560      record in the WAIS schema. Note that the body of a news posting is
561      separated from the list of headers by a blank line (or rather a
562      sequence of two newline characters.
563     </para>
564
565     <para>
566
567      <screen>
568       BEGIN                { begin record wais }
569
570       /^From:/ BODY /$/    { data -element name $1 }
571       /^Subject:/ BODY /$/ { data -element title $1 }
572       /^Date:/ BODY /$/    { data -element lastModified $1 }
573       /\n\n/ BODY END      {
574       begin element bodyOfDisplay
575       begin variant body iana "text/plain"
576       data -text $1
577       end record
578       }
579      </screen>
580
581     </para>
582
583     <para>
584      If Zebra is compiled with support for Tcl (Tool Command Language)
585      enabled, the statements described above are supplemented with a complete
586      scripting environment, including control structures (conditional
587      expressions and loop constructs), and powerful string manipulation
588      mechanisms for modifying the elements of a record. Tcl is a popular
589      scripting environment, with several tutorials available both online
590      and in hardcopy.
591     </para>
592
593    </sect2>
594
595   </sect1>
596
597   <sect1 id="internal-representation">
598    <title>Internal Representation</title>
599
600    <para>
601     When records are manipulated by the system, they're represented in a
602     tree-structure, with data elements at the leaf nodes, and tags or
603     variant components at the non-leaf nodes. The root-node identifies the
604     schema that lends context to the tagging and structuring of the
605     record. Imagine a simple record, consisting of a 'title' element and
606     an 'author' element:
607    </para>
608
609    <para>
610
611     <screen>
612      ROOT 
613         TITLE     "Zen and the Art of Motorcycle Maintenance"
614         AUTHOR    "Robert Pirsig"
615     </screen>
616
617    </para>
618
619    <para>
620     A slightly more complex record would have the author element consist
621     of two elements, a surname and a first name:
622    </para>
623
624    <para>
625
626     <screen>
627      ROOT  
628         TITLE  "Zen and the Art of Motorcycle Maintenance"
629         AUTHOR
630            FIRST-NAME "Robert"
631            SURNAME    "Pirsig"
632     </screen>
633
634    </para>
635
636    <para>
637     The root of the record will refer to the record schema that describes
638     the structuring of this particular record. The schema defines the
639     element tags (TITLE, FIRST-NAME, etc.) that may occur in the record, as
640     well as the structuring (SURNAME should appear below AUTHOR, etc.). In
641     addition, the schema establishes element set names that are used by
642     the client to request a subset of the elements of a given record. The
643     schema may also establish rules for converting the record to a
644     different schema, by stating, for each element, a mapping to a
645     different tag path.
646    </para>
647
648    <sect2>
649     <title>Tagged Elements</title>
650
651     <para>
652      A data element is characterized by its tag, and its position in the
653      structure of the record. For instance, while the tag "telephone
654      number" may be used different places in a record, we may need to
655      distinguish between these occurrences, both for searching and
656      presentation purposes. For instance, while the phone numbers for the
657      "customer" and the "service provider" are both
658      representatives for the same type of resource (a telephone number), it
659      is essential that they be kept separate. The record schema provides
660      the structure of the record, and names each data element (defined by
661      the sequence of tags - the tag path - by which the element can be
662      reached from the root of the record).
663     </para>
664
665    </sect2>
666
667    <sect2>
668     <title>Variants</title>
669
670     <para>
671      The children of a tag node may be either more tag nodes, a data node
672      (possibly accompanied by tag nodes),
673      or a tree of variant nodes. The children of  variant nodes are either
674      more variant nodes or a data node (possibly accompanied by more
675      variant nodes). Each leaf node, which is normally a
676      data node, corresponds to a <emphasis>variant form</emphasis> of the
677      tagged element identified by the tag which parents the variant tree.
678      The following title element occurs in two different languages:
679     </para>
680
681     <para>
682
683      <screen>
684       VARIANT LANG=ENG  "War and Peace"
685       TITLE
686       VARIANT LANG=DAN  "Krig og Fred"
687      </screen>
688
689     </para>
690
691     <para>
692      Which of the two elements are transmitted to the client by the server
693      depends on the specifications provided by the client, if any.
694     </para>
695     
696     <para>
697      In practice, each variant node is associated with a triple of class,
698      type, value, corresponding to the variant mechanism of Z39.50.
699     </para>
700     
701    </sect2>
702    
703    <sect2>
704     <title>Data Elements</title>
705     
706     <para>
707      Data nodes have no children (they are always leaf nodes in the record
708      tree).
709     </para>
710     
711     <!--
712     FIXME! Documentation needs extension here about types of nodes - numerical,
713     textual, etc., plus the various types of inclusion notes.
714    </para>
715     -->
716     
717    </sect2>
718    
719   </sect1>
720   
721   <sect1 id="data-model">
722    <title>Configuring Your Data Model</title>
723    
724    <para>
725     The following sections describe the configuration files that govern
726     the internal management of data records. The system searches for the files
727     in the directories specified by the <emphasis>profilePath</emphasis>
728     setting in the <literal>zebra.cfg</literal> file.
729    </para>
730
731    <sect2>
732     <title>The Abstract Syntax</title>
733
734     <para>
735      The abstract syntax definition (also known as an Abstract Record
736      Structure, or ARS) is the focal point of the
737      record schema description. For a given schema, the ABS file may state any
738      or all of the following:
739     </para>
740
741     <!--
742      FIXME - Need a diagram here, or a simple explanation how it all hangs together -H
743     -->
744
745     <para>
746
747      <itemizedlist>
748       <listitem>
749
750        <para>
751         The object identifier of the Z39.50 schema associated
752         with the ARS, so that it can be referred to by the client.
753        </para>
754       </listitem>
755
756       <listitem>
757        <para>
758         The attribute set (which can possibly be a compound of multiple
759         sets) which applies in the profile. This is used when indexing and
760         searching the records belonging to the given profile.
761        </para>
762       </listitem>
763
764       <listitem>
765        <para>
766         The tag set (again, this can consist of several different sets).
767         This is used when reading the records from a file, to recognize the
768         different tags, and when transmitting the record to the client -
769         mapping the tags to their numerical representation, if they are
770         known.
771        </para>
772       </listitem>
773       
774       <listitem>
775        <para>
776         The variant set which is used in the profile. This provides a
777         vocabulary for specifying the <emphasis>forms</emphasis> of
778         data that appear inside the records.
779        </para>
780       </listitem>
781
782       <listitem>
783        <para>
784         Element set names, which are a shorthand way for the client to
785         ask for a subset of the data elements contained in a record. Element
786         set names, in the retrieval module, are mapped to <emphasis>element
787          specifications</emphasis>, which contain information equivalent to the
788         <emphasis>Espec-1</emphasis> syntax of Z39.50.
789        </para>
790       </listitem>
791
792       <listitem>
793        <para>
794         Map tables, which may specify mappings to
795         <emphasis>other</emphasis> database profiles, if desired.
796        </para>
797       </listitem>
798
799       <listitem>
800        <para>
801         Possibly, a set of rules describing the mapping of elements to a
802         MARC representation.
803
804        </para>
805       </listitem>
806
807       <listitem>      
808        <para>
809         A list of element descriptions (this is the actual ARS of the
810         schema, in Z39.50 terms), which lists the ways in which the various
811         tags can be used and organized hierarchically.
812        </para>
813       </listitem>
814
815      </itemizedlist>
816
817     </para>
818
819     <para>
820      Several of the entries above simply refer to other files, which
821      describe the given objects.
822     </para>
823
824    </sect2>
825
826    <sect2>
827     <title>The Configuration Files</title>
828
829     <para>
830      This section describes the syntax and use of the various tables which
831      are used by the retrieval module.
832     </para>
833
834     <para>
835      The number of different file types may appear daunting at first, but
836      each type corresponds fairly clearly to a single aspect of the Z39.50
837      retrieval facilities. Further, the average database administrator,
838      who is simply reusing an existing profile for which tables already
839      exist, shouldn't have to worry too much about the contents of these tables.
840     </para>
841
842     <para>
843      Generally, the files are simple ASCII files, which can be maintained
844      using any text editor. Blank lines, and lines beginning with a (#) are
845      ignored. Any characters on a line followed by a (#) are also ignored.
846      All other lines contain <emphasis>directives</emphasis>, which provide
847      some setting or value to the system.
848      Generally, settings are characterized by a single
849      keyword, identifying the setting, followed by a number of parameters.
850      Some settings are repeatable (r), while others may occur only once in a
851      file. Some settings are optional (o), while others again are
852      mandatory (m).
853     </para>
854     
855    </sect2>
856    
857    <sect2 id="abs-file">
858     <title>The Abstract Syntax (.abs) Files</title>
859     
860     <para>
861      The name of this file type is slightly misleading in Z39.50 terms,
862      since, apart from the actual abstract syntax of the profile, it also
863      includes most of the other definitions that go into a database
864      profile.
865     </para>
866     
867     <para>
868      When a record in the canonical, SGML-like format is read from a file
869      or from the database, the first tag of the file should reference the
870      profile that governs the layout of the record. If the first tag of the
871      record is, say, <literal>&lt;gils&gt;</literal>, the system will look
872      for the profile definition in the file <literal>gils.abs</literal>.
873      Profile definitions are cached, so they only have to be read once
874      during the lifespan of the current process. 
875     </para>
876
877     <para>
878      When writing your own input filters, the
879      <emphasis>record-begin</emphasis> command
880      introduces the profile, and should always be called first thing when
881      introducing a new record.
882     </para>
883     
884     <para>
885      The file may contain the following directives:
886     </para>
887     
888     <para>
889      <variablelist>
890       
891       <varlistentry>
892        <term>name <replaceable>symbolic-name</replaceable></term>
893        <listitem>
894         <para>
895          (m) This provides a shorthand name or
896          description for the profile. Mostly useful for diagnostic purposes.
897         </para>
898        </listitem>
899       </varlistentry>
900       <varlistentry>
901        <term>reference <replaceable>OID-name</replaceable></term>
902        <listitem>
903         <para>
904          (m) The reference name of the OID for the profile.
905          The reference names can be found in the <emphasis>util</emphasis>
906          module of YAZ.
907         </para>
908        </listitem>
909       </varlistentry>
910       <varlistentry>
911        <term>attset <replaceable>filename</replaceable></term>
912        <listitem>
913         <para>
914          (m) The attribute set that is used for
915          indexing and searching records belonging to this profile.
916         </para>
917        </listitem>
918       </varlistentry>
919       <varlistentry>
920        <term>tagset <replaceable>filename</replaceable></term>
921        <listitem>
922         <para>
923          (o) The tag set (if any) that describe
924          that fields of the records.
925         </para>
926        </listitem>
927       </varlistentry>
928       <varlistentry>
929        <term>varset <replaceable>filename</replaceable></term>
930        <listitem>
931         <para>
932          (o) The variant set used in the profile.
933         </para>
934        </listitem>
935       </varlistentry>
936       <varlistentry>
937        <term>maptab <replaceable>filename</replaceable></term>
938        <listitem>
939         <para>
940          (o,r) This points to a
941          conversion table that might be used if the client asks for the record
942          in a different schema from the native one.
943         </para>
944        </listitem>
945       </varlistentry>
946       <varlistentry>
947        <term>marc <replaceable>filename</replaceable></term>
948        <listitem>
949         <para>
950          (o) Points to a file containing parameters
951          for representing the record contents in the ISO2709 syntax.
952          Read the description of the MARC representation facility below.
953         </para>
954        </listitem>
955       </varlistentry>
956       <varlistentry>
957        <term>esetname <replaceable>name filename</replaceable></term>
958        <listitem>
959         <para>
960          (o,r) Associates the
961          given element set name with an element selection file. If an (@) is
962          given in place of the filename, this corresponds to a null mapping for
963          the given element set name.
964         </para>
965        </listitem>
966       </varlistentry>
967       <varlistentry>
968        <term>any <replaceable>tags</replaceable></term>
969        <listitem>
970         <para>
971          (o) This directive specifies a list of attributes
972          which should be appended to the attribute list given for each
973          element. The effect is to make every single element in the abstract
974          syntax searchable by way of the given attributes. This directive
975          provides an efficient way of supporting free-text searching across all
976          elements. However, it does increase the size of the index
977          significantly. The attributes can be qualified with a structure, as in
978          the <replaceable>elm</replaceable> directive below.
979         </para>
980        </listitem>
981       </varlistentry>
982       <varlistentry>
983        <term>elm <replaceable>path name attributes</replaceable></term>
984        <listitem>
985         <para>
986          (o,r) Adds an element to the abstract record syntax of the schema.
987          The <replaceable>path</replaceable> follows the
988          syntax which is suggested by the Z39.50 document - that is, a sequence
989          of tags separated by slashes (&#x2f;). Each tag is given as a
990          comma-separated pair of tag type and -value surrounded by parenthesis.
991          The <replaceable>name</replaceable> is the name of the element, and
992          the <replaceable>attributes</replaceable>
993          specifies which attributes to use when indexing the element in a
994          comma-separated list.
995          A ! in place of the attribute name is equivalent to
996          specifying an attribute name identical to the element name.
997          A - in place of the attribute name
998          specifies that no indexing is to take place for the given element.
999          The attributes can be qualified with <replaceable>field
1000           types</replaceable> to specify which
1001          character set should govern the indexing procedure for that field.
1002          The same data element may be indexed into several different
1003          fields, using different character set definitions.
1004          See the <xref linkend="field-structure-and-character-sets"/>.
1005          The default field type is <literal>w</literal> for
1006          <emphasis>word</emphasis>.
1007         </para>
1008        </listitem>
1009       </varlistentry>
1010       
1011       <varlistentry>
1012        <term>xelm <replaceable>xpath attributes</replaceable></term>
1013        <listitem>
1014         <para>
1015          Specifies indexing for record nodes given by
1016          <replaceable>xpath</replaceable>. Unlike directive
1017          elm, this directive allows you to index attribute
1018          contents. The <replaceable>xpath</replaceable> uses
1019          a syntax similar to XPath. The <replaceable>attributes</replaceable>
1020          have same syntax and meaning as directive elm, except that operator
1021          ! refers to the nodes selected by <replaceable>xpath</replaceable>.
1022          <!--
1023          xelm   /         !:w                 default index
1024          xelm   //        !:w                 additional index
1025          xelm   /gils/title/@att    myatt:w   index attribute @att in myatt
1026          xelm   title/@att          myatt:w   same meaning.
1027          -->
1028         </para>
1029        </listitem>
1030       </varlistentry>
1031       
1032       <varlistentry>
1033        <term>encoding <replaceable>encodingname</replaceable></term>
1034        <listitem>
1035         <para>
1036          This directive specifies character encoding for external records.
1037          For records such as XML that specifies encoding within the
1038          file via a header this directive is ignored.
1039          If neither this directive is given, nor an encoding is set
1040          within external records, ISO-8859-1 encoding is assumed.
1041          </para>
1042        </listitem>
1043       </varlistentry>
1044       <varlistentry>
1045        <term>xpath <literal>enable</literal>/<literal>disable</literal></term>
1046        <listitem>
1047         <para>
1048          If this directive is followed by <literal>enable</literal>,
1049          then extra indexing is performed to allow for XPath-like queries.
1050          If this directive is not specified - equivalent to 
1051          <literal>disable</literal> - no extra XPath-indexing is performed.
1052         </para>
1053        </listitem>
1054       </varlistentry>
1055
1056       <!-- Adam's version 
1057       <varlistentry>
1058        <term>systag <replaceable>systemtag</replaceable> <replaceable>element</replaceable></term>
1059        <listitem>
1060         <para>
1061          This directive maps system information to an element during
1062          retrieval. This information is dynamically created. The
1063          following system tags are defined
1064          <variablelist>
1065           <varlistentry>
1066            <term>size</term>
1067            <listitem>
1068             <para>
1069              Size of record in bytes. By default this
1070              is mapped to element <literal>size</literal>.
1071             </para>
1072            </listitem>
1073           </varlistentry>
1074
1075           <varlistentry>
1076            <term>rank</term>
1077            <listitem>
1078             <para>
1079              Score/rank of record. By default this
1080              is mapped to element <literal>rank</literal>.
1081              If no score was calculated for the record (non-ranked
1082              searched) search this directive is ignored.
1083             </para>
1084            </listitem>
1085           </varlistentry>
1086           
1087           <varlistentry>
1088            <term>sysno</term>
1089            <listitem> 
1090             <para>
1091              Zebra's system number (record ID) for the
1092              record. By default this is mapped to element
1093              <literal>localControlNumber</literal>.
1094             </para>
1095            </listitem>
1096           </varlistentry>
1097          </variablelist>
1098          If you do not want a particular system tag to be applied,
1099          then set the resulting element to something undefined in the
1100          abs file (such as <literal>none</literal>).
1101         </para>
1102        </listitem>
1103       </varlistentry>
1104       -->
1105
1106       <!-- Mike's version -->
1107       <varlistentry>
1108        <term>
1109         systag
1110         <replaceable>systemTag</replaceable>
1111         <replaceable>actualTag</replaceable>
1112        </term>
1113        <listitem>
1114         <para>
1115          Specifies what information, if any, Zebra should
1116          automatically include in retrieval records for the 
1117          ``system fields'' that it supports.
1118          <replaceable>systemTag</replaceable> may
1119          be any of the following:
1120          <variablelist>
1121           <varlistentry>
1122            <term><literal>rank</literal></term>
1123            <listitem><para>
1124             An integer indicating the relevance-ranking score
1125             assigned to the record.
1126            </para></listitem>
1127           </varlistentry>
1128           <varlistentry>
1129            <term><literal>sysno</literal></term>
1130            <listitem><para>
1131             An automatically generated identifier for the record,
1132             unique within this database.  It is represented by the
1133             <literal>&lt;localControlNumber&gt;</literal> element in
1134             XML and the <literal>(1,14)</literal> tag in GRS-1.
1135            </para></listitem>
1136           </varlistentry>
1137           <varlistentry>
1138            <term><literal>size</literal></term>
1139            <listitem><para>
1140             The size, in bytes, of the retrieved record.
1141            </para></listitem>
1142           </varlistentry>
1143          </variablelist>
1144         </para>
1145         <para>
1146          The <replaceable>actualTag</replaceable> parameter may be
1147          <literal>none</literal> to indicate that the named element
1148          should be omitted from retrieval records.
1149         </para>
1150        </listitem>
1151       </varlistentry>
1152      </variablelist>
1153     </para>
1154     
1155     <note>
1156      <para>
1157       The mechanism for controlling indexing is not adequate for
1158       complex databases, and will probably be moved into a separate
1159       configuration table eventually.
1160      </para>
1161     </note>
1162     
1163     <para>
1164      The following is an excerpt from the abstract syntax file for the GILS
1165      profile.
1166     </para>
1167
1168     <para>
1169
1170      <screen>
1171       name gils
1172       reference GILS-schema
1173       attset gils.att
1174       tagset gils.tag
1175       varset var1.var
1176
1177       maptab gils-usmarc.map
1178
1179       # Element set names
1180
1181       esetname VARIANT gils-variant.est  # for WAIS-compliance
1182       esetname B gils-b.est
1183       esetname G gils-g.est
1184       esetname F @
1185
1186       elm (1,10)              rank                        -
1187       elm (1,12)              url                         -
1188       elm (1,14)              localControlNumber     Local-number
1189       elm (1,16)              dateOfLastModification Date/time-last-modified
1190       elm (2,1)               title                       w:!,p:!
1191       elm (4,1)               controlIdentifier      Identifier-standard
1192       elm (2,6)               abstract               Abstract
1193       elm (4,51)              purpose                     !
1194       elm (4,52)              originator                  - 
1195       elm (4,53)              accessConstraints           !
1196       elm (4,54)              useConstraints              !
1197       elm (4,70)              availability                -
1198       elm (4,70)/(4,90)       distributor                 -
1199       elm (4,70)/(4,90)/(2,7) distributorName             !
1200       elm (4,70)/(4,90)/(2,10 distributorOrganization     !
1201       elm (4,70)/(4,90)/(4,2) distributorStreetAddress    !
1202       elm (4,70)/(4,90)/(4,3) distributorCity             !
1203      </screen>
1204
1205     </para>
1206
1207    </sect2>
1208
1209    <sect2 id="attset-files">
1210     <title>The Attribute Set (.att) Files</title>
1211
1212     <para>
1213      This file type describes the <replaceable>Use</replaceable> elements of
1214      an attribute set. 
1215      It contains the following directives. 
1216     </para>
1217     
1218     <para>
1219      <variablelist>
1220       <varlistentry>
1221        <term>name <replaceable>symbolic-name</replaceable></term>
1222        <listitem>
1223         <para>
1224          (m) This provides a shorthand name or
1225          description for the attribute set.
1226          Mostly useful for diagnostic purposes.
1227         </para>
1228        </listitem></varlistentry>
1229       <varlistentry>
1230        <term>reference <replaceable>OID-name</replaceable></term>
1231        <listitem>
1232         <para>
1233          (m) The reference name of the OID for
1234          the attribute set.
1235          The reference names can be found in the <replaceable>util</replaceable>
1236          module of <replaceable>YAZ</replaceable>.
1237         </para>
1238        </listitem></varlistentry>
1239       <varlistentry>
1240        <term>include <replaceable>filename</replaceable></term>
1241        <listitem>
1242         <para>
1243          (o,r) This directive is used to
1244          include another attribute set as a part of the current one. This is
1245          used when a new attribute set is defined as an extension to another
1246          set. For instance, many new attribute sets are defined as extensions
1247          to the <replaceable>bib-1</replaceable> set.
1248          This is an important feature of the retrieval
1249          system of Z39.50, as it ensures the highest possible level of
1250          interoperability, as those access points of your database which are
1251          derived from the external set (say, bib-1) can be used even by clients
1252          who are unaware of the new set.
1253         </para>
1254        </listitem></varlistentry>
1255       <varlistentry>
1256        <term>att
1257         <replaceable>att-value att-name [local-value]</replaceable></term>
1258        <listitem>
1259         <para>
1260          (o,r) This
1261          repeatable directive introduces a new attribute to the set. The
1262          attribute value is stored in the index (unless a
1263          <replaceable>local-value</replaceable> is
1264          given, in which case this is stored). The name is used to refer to the
1265          attribute from the <replaceable>abstract syntax</replaceable>. 
1266         </para>
1267        </listitem></varlistentry>
1268      </variablelist>
1269     </para>
1270
1271     <para>
1272      This is an excerpt from the GILS attribute set definition.
1273      Notice how the file describing the <emphasis>bib-1</emphasis>
1274      attribute set is referenced.
1275     </para>
1276
1277     <para>
1278
1279      <screen>
1280       name gils
1281       reference GILS-attset
1282       include bib1.att
1283
1284       att 2001          distributorName
1285       att 2002          indextermsControlled
1286       att 2003          purpose
1287       att 2004          accessConstraints
1288       att 2005          useConstraints
1289      </screen>
1290
1291     </para>
1292
1293    </sect2>
1294
1295    <sect2>
1296     <title>The Tag Set (.tag) Files</title>
1297
1298     <para>
1299      This file type defines the tagset of the profile, possibly by
1300      referencing other tag sets (most tag sets, for instance, will include
1301      tagsetG and tagsetM from the Z39.50 specification. The file may
1302      contain the following directives.
1303     </para>
1304
1305     <para>
1306      <variablelist>
1307
1308       <varlistentry>
1309        <term>name <emphasis>symbolic-name</emphasis></term>
1310        <listitem>
1311         <para>
1312          (m) This provides a shorthand name or
1313          description for the tag set. Mostly useful for diagnostic purposes.
1314         </para>
1315        </listitem></varlistentry>
1316       <varlistentry>
1317        <term>reference <emphasis>OID-name</emphasis></term>
1318        <listitem>
1319         <para>
1320          (o) The reference name of the OID for the tag set.
1321          The reference names can be found in the <emphasis>util</emphasis>
1322          module of <emphasis>YAZ</emphasis>.
1323          The directive is optional, since not all tag sets
1324          are registered outside of their schema.
1325         </para>
1326        </listitem></varlistentry>
1327       <varlistentry>
1328        <term>type <emphasis>integer</emphasis></term>
1329        <listitem>
1330         <para>
1331          (m) The type number of the tagset within the schema
1332          profile (note: this specification really should belong to the .abs
1333          file. This will be fixed in a future release).
1334         </para>
1335        </listitem></varlistentry>
1336       <varlistentry>
1337        <term>include <emphasis>filename</emphasis></term>
1338        <listitem>
1339         <para>
1340          (o,r) This directive is used
1341          to include the definitions of other tag sets into the current one.
1342         </para>
1343        </listitem></varlistentry>
1344       <varlistentry>
1345        <term>tag <emphasis>number names type</emphasis></term>
1346        <listitem>
1347         <para>
1348          (o,r) Introduces a new tag to the set.
1349          The <emphasis>number</emphasis> is the tag number as used
1350          in the protocol (there is currently no mechanism for
1351          specifying string tags at this point, but this would be quick
1352          work to add).
1353          The <emphasis>names</emphasis> parameter is a list of names
1354          by which the tag should be recognized in the input file format.
1355          The names should be separated by slashes (/).
1356          The <emphasis>type</emphasis> is the recommended data type of
1357          the tag.
1358          It should be one of the following:
1359
1360          <itemizedlist>
1361           <listitem>
1362            <para>
1363             structured
1364            </para>
1365           </listitem>
1366
1367           <listitem>
1368            <para>
1369             string
1370            </para>
1371           </listitem>
1372
1373           <listitem>
1374            <para>
1375             numeric
1376            </para>
1377           </listitem>
1378
1379           <listitem>
1380            <para>
1381             bool
1382            </para>
1383           </listitem>
1384
1385           <listitem>
1386            <para>
1387             oid
1388            </para>
1389           </listitem>
1390
1391           <listitem>
1392            <para>
1393             generalizedtime
1394            </para>
1395           </listitem>
1396
1397           <listitem>
1398            <para>
1399             intunit
1400            </para>
1401           </listitem>
1402
1403           <listitem>
1404            <para>
1405             int
1406            </para>
1407           </listitem>
1408
1409           <listitem>
1410            <para>
1411             octetstring
1412            </para>
1413           </listitem>
1414
1415           <listitem>
1416            <para>
1417             null
1418            </para>
1419           </listitem>
1420
1421          </itemizedlist>
1422
1423         </para>
1424        </listitem></varlistentry>
1425      </variablelist>
1426     </para>
1427
1428     <para>
1429      The following is an excerpt from the TagsetG definition file.
1430     </para>
1431
1432     <para>
1433      <screen>
1434       name tagsetg
1435       reference TagsetG
1436       type 2
1437
1438       tag       1       title           string
1439       tag       2       author          string
1440       tag       3       publicationPlace string
1441       tag       4       publicationDate string
1442       tag       5       documentId      string
1443       tag       6       abstract        string
1444       tag       7       name            string
1445       tag       8       date            generalizedtime
1446       tag       9       bodyOfDisplay   string
1447       tag       10      organization    string
1448      </screen>
1449     </para>
1450
1451    </sect2>
1452
1453    <sect2 id="variant-set">
1454     <title>The Variant Set (.var) Files</title>
1455
1456     <para>
1457      The variant set file is a straightforward representation of the
1458      variant set definitions associated with the protocol. At present, only
1459      the <emphasis>Variant-1</emphasis> set is known.
1460     </para>
1461
1462     <para>
1463      These are the directives allowed in the file.
1464     </para>
1465
1466     <para>
1467      <variablelist>
1468
1469       <varlistentry>
1470        <term>name <emphasis>symbolic-name</emphasis></term>
1471        <listitem>
1472         <para>
1473          (m) This provides a shorthand name or
1474          description for the variant set. Mostly useful for diagnostic purposes.
1475         </para>
1476        </listitem></varlistentry>
1477       <varlistentry>
1478        <term>reference <emphasis>OID-name</emphasis></term>
1479        <listitem>
1480         <para>
1481          (o) The reference name of the OID for
1482          the variant set, if one is required. The reference names can be found
1483          in the <emphasis>util</emphasis> module of <emphasis>YAZ</emphasis>.
1484         </para>
1485        </listitem></varlistentry>
1486       <varlistentry>
1487        <term>class <emphasis>integer class-name</emphasis></term>
1488        <listitem>
1489         <para>
1490          (m,r) Introduces a new
1491          class to the variant set.
1492         </para>
1493        </listitem></varlistentry>
1494       <varlistentry>
1495        <term>type <emphasis>integer type-name datatype</emphasis></term>
1496        <listitem>
1497         <para>
1498          (m,r) Addes a
1499          new type to the current class (the one introduced by the most recent
1500          <emphasis>class</emphasis> directive).
1501          The type names belong to the same name space as the one used
1502          in the tag set definition file.
1503         </para>
1504        </listitem></varlistentry>
1505      </variablelist>
1506     </para>
1507
1508     <para>
1509      The following is an excerpt from the file describing the variant set
1510      <emphasis>Variant-1</emphasis>.
1511     </para>
1512
1513     <para>
1514
1515      <screen>
1516       name variant-1
1517       reference Variant-1
1518
1519       class 1 variantId
1520
1521       type      1       variantId               octetstring
1522
1523       class 2 body
1524
1525       type      1       iana                    string
1526       type      2       z39.50                  string
1527       type      3       other                   string
1528      </screen>
1529
1530     </para>
1531
1532    </sect2>
1533
1534    <sect2>
1535     <title>The Element Set (.est) Files</title>
1536
1537     <para>
1538      The element set specification files describe a selection of a subset
1539      of the elements of a database record. The element selection mechanism
1540      is equivalent to the one supplied by the <emphasis>Espec-1</emphasis>
1541      syntax of the Z39.50 specification.
1542      In fact, the internal representation of an element set
1543      specification is identical to the <emphasis>Espec-1</emphasis> structure,
1544      and we'll refer you to the description of that structure for most of
1545      the detailed semantics of the directives below.
1546     </para>
1547
1548     <note>
1549      <para>
1550       Not all of the Espec-1 functionality has been implemented yet.
1551       The fields that are mentioned below all work as expected, unless
1552       otherwise is noted.
1553      </para>
1554     </note>
1555     
1556     <para>
1557      The directives available in the element set file are as follows:
1558     </para>
1559
1560     <para>
1561      <variablelist>
1562       <varlistentry>
1563        <term>defaultVariantSetId <emphasis>OID-name</emphasis></term>
1564        <listitem>
1565         <para>
1566          (o) If variants are used in
1567          the following, this should provide the name of the variantset used
1568          (it's not currently possible to specify a different set in the
1569          individual variant request). In almost all cases (certainly all
1570          profiles known to us), the name
1571          <literal>Variant-1</literal> should be given here.
1572         </para>
1573        </listitem></varlistentry>
1574       <varlistentry>
1575        <term>defaultVariantRequest <emphasis>variant-request</emphasis></term>
1576        <listitem>
1577         <para>
1578          (o) This directive
1579          provides a default variant request for
1580          use when the individual element requests (see below) do not contain a
1581          variant request. Variant requests consist of a blank-separated list of
1582          variant components. A variant compont is a comma-separated,
1583          parenthesized triple of variant class, type, and value (the two former
1584          values being represented as integers). The value can currently only be
1585          entered as a string (this will change to depend on the definition of
1586          the variant in question). The special value (@) is interpreted as a
1587          null value, however.
1588         </para>
1589        </listitem></varlistentry>
1590       <varlistentry>
1591        <term>simpleElement
1592         <emphasis>path ['variant' variant-request]</emphasis></term>
1593        <listitem>
1594         <para>
1595          (o,r) This corresponds to a simple element request
1596          in <emphasis>Espec-1</emphasis>.
1597          The path consists of a sequence of tag-selectors, where each of
1598          these can consist of either:
1599         </para>
1600
1601         <para>
1602          <itemizedlist>
1603           <listitem>
1604            <para>
1605             A simple tag, consisting of a comma-separated type-value pair in
1606             parenthesis, possibly followed by a colon (:) followed by an
1607             occurrences-specification (see below). The tag-value can be a number
1608             or a string. If the first character is an apostrophe ('), this
1609             forces the value to be interpreted as a string, even if it
1610             appears to be numerical.
1611            </para>
1612           </listitem>
1613
1614           <listitem>
1615            <para>
1616             A WildThing, represented as a question mark (?), possibly
1617             followed by a colon (:) followed by an occurrences
1618             specification (see below).
1619            </para>
1620           </listitem>
1621
1622           <listitem>
1623            <para>
1624             A WildPath, represented as an asterisk (*). Note that the last
1625             element of the path should not be a wildPath (wildpaths don't
1626             work in this version).
1627            </para>
1628           </listitem>
1629
1630          </itemizedlist>
1631
1632         </para>
1633
1634         <para>
1635          The occurrences-specification can be either the string
1636          <literal>all</literal>, the string <literal>last</literal>, or
1637          an explicit value-range. The value-range is represented as
1638          an integer (the starting point), possibly followed by a
1639          plus (+) and a second integer (the number of elements, default
1640          being one).
1641         </para>
1642
1643         <para>
1644          The variant-request has the same syntax as the defaultVariantRequest
1645          above. Note that it may sometimes be useful to give an empty variant
1646          request, simply to disable the default for a specific set of fields
1647          (we aren't certain if this is proper <emphasis>Espec-1</emphasis>,
1648          but it works in this implementation).
1649         </para>
1650        </listitem></varlistentry>
1651      </variablelist>
1652     </para>
1653
1654     <para>
1655      The following is an example of an element specification belonging to
1656      the GILS profile.
1657     </para>
1658
1659     <para>
1660
1661      <screen>
1662       simpleelement (1,10)
1663       simpleelement (1,12)
1664       simpleelement (2,1)
1665       simpleelement (1,14)
1666       simpleelement (4,1)
1667       simpleelement (4,52)
1668      </screen>
1669
1670     </para>
1671
1672    </sect2>
1673
1674    <sect2 id="schema-mapping">
1675     <title>The Schema Mapping (.map) Files</title>
1676
1677     <para>
1678      Sometimes, the client might want to receive a database record in
1679      a schema that differs from the native schema of the record. For
1680      instance, a client might only know how to process WAIS records, while
1681      the database record is represented in a more specific schema, such as
1682      GILS. In this module, a mapping of data to one of the MARC formats is
1683      also thought of as a schema mapping (mapping the elements of the
1684      record into fields consistent with the given MARC specification, prior
1685      to actually converting the data to the ISO2709). This use of the
1686      object identifier for USMARC as a schema identifier represents an
1687      overloading of the OID which might not be entirely proper. However,
1688      it represents the dual role of schema and record syntax which
1689      is assumed by the MARC family in Z39.50.
1690     </para>
1691
1692     <!--
1693      <emphasis>NOTE: FIXME! The schema-mapping functions are so far limited to a
1694       straightforward mapping of elements. This should be extended with
1695       mechanisms for conversions of the element contents, and conditional
1696       mappings of elements based on the record contents.</emphasis>
1697     -->
1698
1699     <para>
1700      These are the directives of the schema mapping file format:
1701     </para>
1702
1703     <para>
1704      <variablelist>
1705
1706       <varlistentry>
1707        <term>targetName <emphasis>name</emphasis></term>
1708        <listitem>
1709         <para>
1710          (m) A symbolic name for the target schema
1711          of the table. Useful mostly for diagnostic purposes.
1712         </para>
1713        </listitem></varlistentry>
1714       <varlistentry>
1715        <term>targetRef <emphasis>OID-name</emphasis></term>
1716        <listitem>
1717         <para>
1718          (m) An OID name for the target schema.
1719          This is used, for instance, by a server receiving a request to present
1720          a record in a different schema from the native one.
1721          The name, again, is found in the <emphasis>oid</emphasis>
1722          module of <emphasis>YAZ</emphasis>.
1723         </para>
1724        </listitem></varlistentry>
1725       <varlistentry>
1726        <term>map <emphasis>element-name target-path</emphasis></term>
1727        <listitem>
1728         <para>
1729          (o,r) Adds
1730          an element mapping rule to the table.
1731         </para>
1732        </listitem></varlistentry>
1733      </variablelist>
1734     </para>
1735
1736    </sect2>
1737
1738    <sect2>
1739     <title>The MARC (ISO2709) Representation (.mar) Files</title>
1740
1741     <para>
1742      This file provides rules for representing a record in the ISO2709
1743      format. The rules pertain mostly to the values of the constant-length
1744      header of the record.
1745     </para>
1746
1747     <!--
1748      NOTE: FIXME! This will be described better. We're in the process of
1749       re-evaluating and most likely changing the way that MARC records are
1750       handled by the system.</emphasis>
1751     -->
1752
1753    </sect2>
1754
1755    <sect2 id="field-structure-and-character-sets">
1756     <title>Field Structure and Character Sets
1757     </title>
1758
1759     <para>
1760      In order to provide a flexible approach to national character set
1761      handling, Zebra allows the administrator to configure the set up the
1762      system to handle any 8-bit character set &mdash; including sets that
1763      require multi-octet diacritics or other multi-octet characters. The
1764      definition of a character set includes a specification of the
1765      permissible values, their sort order (this affects the display in the
1766      SCAN function), and relationships between upper- and lowercase
1767      characters. Finally, the definition includes the specification of
1768      space characters for the set.
1769     </para>
1770
1771     <para>
1772      The operator can define different character sets for different fields,
1773      typical examples being standard text fields, numerical fields, and
1774      special-purpose fields such as WWW-style linkages (URx).
1775     </para>
1776
1777     <para>
1778      The field types, and hence character sets, are associated with data
1779      elements by the .abs files (see above).
1780      The file <literal>default.idx</literal>
1781      provides the association between field type codes (as used in the .abs
1782      files) and the character map files (with the .chr suffix). The format
1783      of the .idx file is as follows
1784     </para>
1785
1786     <para>
1787      <variablelist>
1788
1789       <varlistentry>
1790        <term>index <emphasis>field type code</emphasis></term>
1791        <listitem>
1792         <para>
1793          This directive introduces a new search index code.
1794          The argument is a one-character code to be used in the
1795          .abs files to select this particular index type. An index, roughly,
1796          corresponds to a particular structure attribute during search. Refer
1797          to <xref linkend="search"/>.
1798         </para>
1799        </listitem></varlistentry>
1800       <varlistentry>
1801        <term>sort <emphasis>field code type</emphasis></term>
1802        <listitem>
1803         <para>
1804          This directive introduces a 
1805          sort index. The argument is a one-character code to be used in the
1806          .abs fie to select this particular index type. The corresponding
1807          use attribute must be used in the sort request to refer to this
1808          particular sort index. The corresponding character map (see below)
1809          is used in the sort process.
1810         </para>
1811        </listitem></varlistentry>
1812       <varlistentry>
1813        <term>completeness <emphasis>boolean</emphasis></term>
1814        <listitem>
1815         <para>
1816          This directive enables or disables complete field indexing.
1817          The value of the <emphasis>boolean</emphasis> should be 0
1818          (disable) or 1. If completeness is enabled, the index entry will
1819          contain the complete contents of the field (up to a limit), with words
1820          (non-space characters) separated by single space characters
1821          (normalized to " " on display). When completeness is
1822          disabled, each word is indexed as a separate entry. Complete subfield
1823          indexing is most useful for fields which are typically browsed (eg.
1824          titles, authors, or subjects), or instances where a match on a
1825          complete subfield is essential (eg. exact title searching). For fields
1826          where completeness is disabled, the search engine will interpret a
1827          search containing space characters as a word proximity search.
1828         </para>
1829        </listitem></varlistentry>
1830       <varlistentry>
1831        <term>charmap <emphasis>filename</emphasis></term>
1832        <listitem>
1833         <para>
1834          This is the filename of the character
1835          map to be used for this index for field type.
1836         </para>
1837        </listitem></varlistentry>
1838      </variablelist>
1839     </para>
1840
1841     <para>
1842      The contents of the character map files are structured as follows:
1843     </para>
1844
1845     <para>
1846      <variablelist>
1847
1848       <varlistentry>
1849        <term>lowercase <emphasis>value-set</emphasis></term>
1850        <listitem>
1851         <para>
1852          This directive introduces the basic value set of the field type.
1853          The format is an ordered list (without spaces) of the
1854          characters which may occur in "words" of the given type.
1855          The order of the entries in the list determines the
1856          sort order of the index. In addition to single characters, the
1857          following combinations are legal:
1858         </para>
1859
1860         <para>
1861
1862          <itemizedlist>
1863           <listitem>
1864            <para>
1865             Backslashes may be used to introduce three-digit octal, or
1866             two-digit hex representations of single characters
1867             (preceded by <literal>x</literal>).
1868             In addition, the combinations
1869             \\, \\r, \\n, \\t, \\s (space &mdash; remember that real
1870             space-characters may not occur in the value definition), and
1871             \\ are recognized, with their usual interpretation.
1872            </para>
1873           </listitem>
1874
1875           <listitem>
1876            <para>
1877             Curly braces {} may be used to enclose ranges of single
1878             characters (possibly using the escape convention described in the
1879             preceding point), eg. {a-z} to introduce the
1880             standard range of ASCII characters.
1881             Note that the interpretation of such a range depends on
1882             the concrete representation in your local, physical character set.
1883            </para>
1884           </listitem>
1885
1886           <listitem>
1887            <para>
1888             paranthesises () may be used to enclose multi-byte characters -
1889             eg. diacritics or special national combinations (eg. Spanish
1890             "ll"). When found in the input stream (or a search term),
1891             these characters are viewed and sorted as a single character, with a
1892             sorting value depending on the position of the group in the value
1893             statement.
1894            </para>
1895           </listitem>
1896
1897          </itemizedlist>
1898
1899         </para>
1900        </listitem></varlistentry>
1901       <varlistentry>
1902        <term>uppercase <emphasis>value-set</emphasis></term>
1903        <listitem>
1904         <para>
1905          This directive introduces the
1906          upper-case equivalencis to the value set (if any). The number and
1907          order of the entries in the list should be the same as in the
1908          <literal>lowercase</literal> directive.
1909         </para>
1910        </listitem></varlistentry>
1911       <varlistentry>
1912        <term>space <emphasis>value-set</emphasis></term>
1913        <listitem>
1914         <para>
1915          This directive introduces the character
1916          which separate words in the input stream. Depending on the
1917          completeness mode of the field in question, these characters either
1918          terminate an index entry, or delimit individual "words" in
1919          the input stream. The order of the elements is not significant &mdash;
1920          otherwise the representation is the same as for the
1921          <literal>uppercase</literal> and <literal>lowercase</literal>
1922          directives.
1923         </para>
1924        </listitem></varlistentry>
1925       <varlistentry>
1926        <term>map <emphasis>value-set</emphasis>
1927         <emphasis>target</emphasis></term>
1928        <listitem>
1929         <para>
1930          This directive introduces a
1931          mapping between each of the members of the value-set on the left to
1932          the character on the right. The character on the right must occur in
1933          the value set (the <literal>lowercase</literal> directive) of
1934          the character set, but
1935          it may be a paranthesis-enclosed multi-octet character. This directive
1936          may be used to map diacritics to their base characters, or to map
1937          HTML-style character-representations to their natural form, etc.
1938         </para>
1939        </listitem></varlistentry>
1940      </variablelist>
1941     </para>
1942
1943    </sect2>
1944
1945   </sect1>
1946
1947   <sect1 id="formats">
1948    <title>Exchange Formats</title>
1949
1950    <para>
1951     Converting records from the internal structure to en exchange format
1952     is largely an automatic process. Currently, the following exchange
1953     formats are supported:
1954    </para>
1955
1956    <para>
1957     <itemizedlist>
1958      <listitem>
1959       <para>
1960        GRS-1. The internal representation is based on GRS-1/XML, so the
1961        conversion here is straightforward. The system will create
1962        applied variant and supported variant lists as required, if a record
1963        contains variant information.
1964       </para>
1965      </listitem>
1966
1967      <listitem>
1968       <para>
1969        XML. The internal representation is based on GRS-1/XML so
1970        the mapping is trivial. Note that XML schemas, preprocessing
1971        instructions and comments are not part of the internal representation
1972        and therefore will never be part of a generated XML record.
1973        Future versions of the Zebra will support that.
1974       </para>
1975      </listitem>
1976
1977      <listitem>
1978       <para>
1979        SUTRS. Again, the mapping is fairly straightforward. Indentation
1980        is used to show the hierarchical structure of the record. All
1981        "GRS" type records support both the GRS-1 and SUTRS
1982        representations.
1983        <!-- FIXME - What is SUTRS - should be expanded here -->
1984       </para>
1985      </listitem>
1986
1987      <listitem>
1988       <para>
1989        ISO2709-based formats (USMARC, etc.). Only records with a
1990        two-level structure (corresponding to fields and subfields) can be
1991        directly mapped to ISO2709. For records with a different structuring
1992        (eg., GILS), the representation in a structure like USMARC involves a
1993        schema-mapping (see <xref linkend="schema-mapping"/>), to an
1994        "implied" USMARC schema (implied,
1995        because there is no formal schema which specifies the use of the
1996        USMARC fields outside of ISO2709). The resultant, two-level record is
1997        then mapped directly from the internal representation to ISO2709. See
1998        the GILS schema definition files for a detailed example of this
1999        approach.
2000       </para>
2001      </listitem>
2002
2003      <listitem>
2004       <para>
2005        Explain. This representation is only available for records
2006        belonging to the Explain schema.
2007       </para>
2008      </listitem>
2009
2010      <listitem>
2011       <para>
2012        Summary. This ASN-1 based structure is only available for records
2013        belonging to the Summary schema - or schema which provide a mapping
2014        to this schema (see the description of the schema mapping facility
2015        above).
2016       </para>
2017      </listitem>
2018
2019      <listitem>
2020       <para>
2021        SOIF. Support for this syntax is experimental, and is currently
2022        keyed to a private Index Data OID (1.2.840.10003.5.1000.81.2). All
2023        abstract syntaxes can be mapped to the SOIF format, although nested
2024        elements are represented by concatenation of the tag names at each
2025        level.
2026        <!-- FIXME - Is this used anywhere ? -H -->
2027       </para>
2028      </listitem>
2029
2030     </itemizedlist>
2031    </para>
2032   </sect1>
2033
2034  </chapter>
2035  <!-- Keep this comment at the end of the file
2036  Local variables:
2037  mode: sgml
2038  sgml-omittag:t
2039  sgml-shorttag:t
2040  sgml-minimize-attributes:nil
2041  sgml-always-quote-attributes:t
2042  sgml-indent-step:1
2043  sgml-indent-data:t
2044  sgml-parent-document: "zebra.xml"
2045  sgml-local-catalogs: nil
2046  sgml-namecase-general:t
2047  End:
2048  -->