Hits per term. Returned in SearchResult-1
[idzebra-moved-to-github.git] / include / rset.h
1 /*
2  * Copyright (C) 1994-1999, Index Data
3  * All rights reserved.
4  * Sebastian Hammer, Adam Dickmeiss
5  *
6  * $Log: rset.h,v $
7  * Revision 1.17  2002-03-20 20:24:29  adam
8  * Hits per term. Returned in SearchResult-1
9  *
10  * Revision 1.16  1999/02/02 14:50:38  adam
11  * Updated WIN32 code specific sections. Changed header.
12  *
13  * Revision 1.15  1998/03/05 08:37:44  adam
14  * New result set model.
15  *
16  * Revision 1.14  1998/02/10 11:56:46  adam
17  * Implemented rset_dup.
18  *
19  * Revision 1.13  1997/12/18 10:54:24  adam
20  * New method result set method rs_hits that returns the number of
21  * hits in result-set (if known). The ranked result set returns real
22  * number of hits but only when not combined with other operands.
23  *
24  * Revision 1.12  1997/09/05 15:30:03  adam
25  * Changed prototype for chr_map_input - added const.
26  * Added support for C++, headers uses extern "C" for public definitions.
27  *
28  * Revision 1.11  1995/12/11 09:07:53  adam
29  * New rset member 'flag', that holds various flags about a result set -
30  * currently 'volatile' (set is register dependent) and 'ranked' (set is
31  * ranked).
32  * New set types sand/sor/snot. They handle and/or/not for ranked and
33  * semi-ranked result sets.
34  *
35  * Revision 1.10  1995/10/12  12:40:36  adam
36  * Private info (buf) moved from struct rset_control to struct rset.
37  * Member control in rset is statically set in rset_create.
38  *
39  * Revision 1.9  1995/10/10  14:00:01  adam
40  * Function rset_open changed its wflag parameter to general flags.
41  *
42  * Revision 1.8  1995/10/06  14:37:53  adam
43  * New result set method: r_score.
44  * Local no (sysno) and score is transferred to retrieveCtrl.
45  *
46  * Revision 1.7  1995/09/07  13:58:08  adam
47  * New parameter: result-set file descriptor (RSFD) to support multiple
48  * positions within the same result-set.
49  * Boolean operators: and, or, not implemented.
50  *
51  * Revision 1.6  1995/09/06  16:10:58  adam
52  * More work on boolean sets.
53  *
54  * Revision 1.5  1995/09/04  15:20:13  adam
55  * More work on temp sets. is_open member removed.
56  *
57  * Revision 1.4  1995/09/04  09:09:52  adam
58  * String arg in dict lookup is const.
59  * Minor changes.
60  *
61  * Revision 1.3  1994/11/22  13:15:27  quinn
62  * Simple
63  *
64  * Revision 1.2  1994/11/04  13:21:21  quinn
65  * Working.
66  *
67  * Revision 1.1  1994/11/03  14:13:22  quinn
68  * Result set manipulation
69  *
70  */
71
72 #ifndef RSET_H
73 #define RSET_H
74
75 #include <stdlib.h>
76
77 #ifdef __cplusplus
78 extern "C" {
79 #endif
80 typedef void *RSFD;
81
82 typedef struct rset *RSET;
83 typedef struct rset_term *RSET_TERM;
84
85 struct rset_control
86 {
87     char *desc; /* text description of set type (for debugging) */
88     void *(*f_create)(RSET ct, const struct rset_control *sel, void *parms);
89     RSFD (*f_open)(RSET ct, int wflag);
90     void (*f_close)(RSFD rfd);
91     void (*f_delete)(RSET ct);
92     void (*f_rewind)(RSFD rfd);
93     int (*f_count)(RSET ct);
94     int (*f_read)(RSFD rfd, void *buf, int *term_index);
95     int (*f_write)(RSFD rfd, const void *buf);
96 };
97
98 struct rset_term {
99     char *name;
100     int  nn;
101     char *flags;
102     int  count;
103 };
104
105 typedef struct rset
106 {
107     const struct rset_control *control;
108     int  flags;
109     int  count;
110     void *buf;
111     RSET_TERM *rset_terms;
112     int no_rset_terms;
113 } rset;
114
115 RSET_TERM rset_term_create (const char *name, int length, const char *flags);
116 void rset_term_destroy (RSET_TERM t);
117 RSET_TERM rset_term_dup (RSET_TERM t);
118
119 #define RSETF_READ       0
120 #define RSETF_WRITE      1
121
122 RSET rset_create(const struct rset_control *sel, void *parms); 
123 /* parameters? */
124
125 /* int rset_open(RSET rs, int wflag); */
126 #define rset_open(rs, wflag) (*(rs)->control->f_open)((rs), (wflag))
127
128 /* void rset_close(RSET rs); */
129 #define rset_close(rs, rfd) (*(rs)->control->f_close)(rfd)
130
131 void rset_delete(RSET rs);
132
133 RSET rset_dup (RSET rs);
134
135 /* void rset_rewind(RSET rs); */
136 #define rset_rewind(rs, rfd) (*(rs)->control->f_rewind)((rfd))
137
138 /* int rset_count(RSET rs); */
139 #define rset_count(rs) (*(rs)->control->f_count)(rs)
140
141 /* int rset_read(RSET rs, void *buf); */
142 #define rset_read(rs, fd, buf, indx) (*(rs)->control->f_read)((fd), (buf), indx)
143
144 /* int rset_write(RSET rs, const void *buf); */
145 #define rset_write(rs, fd, buf) (*(rs)->control->f_write)((fd), (buf))
146
147 /* int rset_type (RSET) */
148 #define rset_type(rs) ((rs)->control->desc)
149
150 #define RSET_FLAG_VOLATILE 1
151
152 #define rset_is_volatile(rs) ((rs)->flags & RSET_FLAG_VOLATILE)
153
154 #ifdef __cplusplus
155 }
156 #endif
157
158 #endif