Generic sort mechanism. Sort supported by relevance, string, or string w/o lead.
[pazpar2-moved-to-github.git] / src / config.h
1 #ifndef CONFIG_H
2 #define CONFIG_H
3
4 #include <libxslt/xslt.h>
5 #include <libxslt/transform.h>
6 #include <libxslt/xsltutils.h>
7
8 enum conf_sortkey_type
9 {
10     Metadata_sortkey_relevance,
11     Metadata_sortkey_numeric,       // Standard numerical sorting
12     Metadata_sortkey_skiparticle,   // Skip leading article when sorting
13     Metadata_sortkey_string         // Flat string
14 };
15
16 // Describes known metadata elements and how they are to be manipulated
17 // An array of these structure provides a 'map' against which discovered metadata
18 // elements are matched. It also governs storage, to minimize number of cycles needed
19 // at various tages of processing
20 struct conf_metadata 
21 {
22     char *name;  // The name of this element. Output by normalization stylesheet
23     int brief;   // Is this element to be returned in the brief format?
24     int termlist;// Is this field to be treated as a termlist for browsing?
25     int rank;    // Rank factor. 0 means don't use this field for ranking, 1 is default
26                  // values >1  give additional significance to a field
27     int sortkey_offset; // -1 if it's not a sortkey, otherwise index
28                         // into service/record_cluster->sortkey array
29     enum
30     {
31         Metadata_type_generic,          // Generic text field
32         Metadata_type_number,           // A number
33         Metadata_type_year              // A number
34     } type;
35     enum
36     {
37         Metadata_merge_no,              // Don't merge
38         Metadata_merge_unique,          // Include unique elements in merged block
39         Metadata_merge_longest,         // Include the longest (strlen) value
40         Metadata_merge_range,           // Store value as a range of lowest-highest
41         Metadata_merge_all              // Just include all elements found
42     } merge;
43 };
44
45 // Controls sorting
46 struct conf_sortkey
47 {
48     char *name;
49     enum conf_sortkey_type type;
50 };
51
52 // It is conceivable that there will eventually be several 'services' offered
53 // from one server, with separate configuration -- possibly more than one services
54 // associated with the same port. For now, however, only a single service is possible.
55 struct conf_service
56 {
57     int num_metadata;
58     struct conf_metadata *metadata;
59     int num_sortkeys;
60     struct conf_sortkey *sortkeys;
61 };
62
63 struct conf_server
64 {
65     char *host;
66     int port;
67     char *proxy_host;
68     int proxy_port;
69     struct conf_service *service;
70     struct conf_server *next;
71 };
72
73 struct conf_queryprofile
74 {
75     int dummy;
76 };
77
78 struct conf_retrievalmap
79 {
80     enum {
81         Map_xslt
82     } type;
83     char *charset;
84     char *format;
85     xsltStylesheet *stylesheet;
86     struct conf_retrievalmap *next;
87 };
88
89 struct conf_retrievalprofile
90 {
91     char *requestsyntax;
92     enum {
93         Nativesyn_xml,
94         Nativesyn_iso2709
95     } native_syntax;
96     enum {
97         Nativeform_na,
98         Nativeform_marc21,
99     } native_format;
100     char *native_encoding;
101     enum {
102         Nativemapto_na,
103         Nativemapto_marcxml,
104         Nativemapto_marcxchange
105     } native_mapto;
106     yaz_marc_t yaz_marc;
107     struct conf_retrievalmap *maplist;
108     struct conf_retrievalprofile *next;
109 };
110
111 struct conf_config
112 {
113     struct conf_server *servers;
114     struct conf_queryprofile *queryprofiles;
115     struct conf_retrievalprofile *retrievalprofiles;
116 };
117
118 #ifndef CONFIG_NOEXTERNS
119
120 extern struct conf_config *config;
121
122 #endif
123
124 int read_config(const char *fname);
125
126 #endif
127
128 /*
129  * Local variables:
130  * c-basic-offset: 4
131  * indent-tabs-mode: nil
132  * End:
133  * vim: shiftwidth=4 tabstop=8 expandtab
134  */