2 * Copyright (c) 1995, the EUROPAGATE consortium (see below).
4 * The EUROPAGATE consortium members are:
6 * University College Dublin
7 * Danmarks Teknologiske Videnscenter
8 * An Chomhairle Leabharlanna
9 * Consejo Superior de Investigaciones Cientificas
11 * Permission to use, copy, modify, distribute, and sell this software and
12 * its documentation, in whole or in part, for any purpose, is hereby granted,
15 * 1. This copyright and permission notice appear in all copies of the
16 * software and its documentation. Notices of copyright or attribution
17 * which appear at the beginning of any file must remain unchanged.
19 * 2. The names of EUROPAGATE or the project partners may not be used to
20 * endorse or promote products derived from this software without specific
21 * prior written permission.
23 * 3. Users of this software (implementors and gateway operators) agree to
24 * inform the EUROPAGATE consortium of their use of the software. This
25 * information will be used to evaluate the EUROPAGATE project and the
26 * software, and to plan further developments. The consortium may use
27 * the information in later publications.
29 * 4. Users of this software agree to make their best efforts, when
30 * documenting their use of the software, to acknowledge the EUROPAGATE
31 * consortium, and the role played by the software in their work.
33 * THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT WARRANTY OF ANY KIND,
34 * EXPRESS, IMPLIED, OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
35 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
36 * IN NO EVENT SHALL THE EUROPAGATE CONSORTIUM OR ITS MEMBERS BE LIABLE
37 * FOR ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF
38 * ANY KIND, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA
39 * OR PROFITS, WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND
40 * ON ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
41 * USE OR PERFORMANCE OF THIS SOFTWARE.
47 * $Id: cclqfile.c,v 1.5 2004-10-02 13:28:26 adam Exp $
51 * Revision 1.3 1995/05/16 09:39:26 adam
54 * Revision 1.2 1995/05/11 14:03:56 adam
55 * Changes in the reading of qualifier(s). New function: ccl_qual_fitem.
56 * New variable ccl_case_sensitive, which controls whether reserved
57 * words and field names are case sensitive or not.
59 * Revision 1.1 1995/04/17 09:31:45 adam
60 * Improved handling of qualifiers. Aliases or reserved words.
70 void ccl_qual_field (CCL_bibset bibset, const char *cp, const char *qual_name)
81 char *qual_value, *qual_type;
85 if (sscanf (cp, "%100s%n", qual_spec, &no_scan) < 1)
88 if (!(split = strchr (qual_spec, '=')))
90 /* alias specification .. */
93 ccl_qual_add_combi (bibset, qual_name, cp);
98 /* [set,]type=value ... */
103 setp = strchr (qual_spec, ',');
106 /* set,type=value ... */
113 qual_type = qual_spec;
115 while (pair_no < 128)
120 if ((split = strchr (qual_value, ',')))
124 switch (qual_type[0])
133 if (!ccl_stricmp (qual_value, "o"))
134 value = CCL_BIB1_REL_ORDER;
135 else if (!ccl_stricmp (qual_value, "r"))
136 value = CCL_BIB1_REL_PORDER;
145 if (!ccl_stricmp (qual_value, "pw"))
146 value = CCL_BIB1_STR_WP;
147 if (!ccl_stricmp (qual_value, "al"))
148 value = CCL_BIB1_STR_AND_LIST;
149 if (!ccl_stricmp (qual_value, "ol"))
150 value = CCL_BIB1_STR_OR_LIST;
155 if (!ccl_stricmp (qual_value, "l"))
156 value = CCL_BIB1_TRU_CAN_LEFT;
157 else if (!ccl_stricmp (qual_value, "r"))
158 value = CCL_BIB1_TRU_CAN_RIGHT;
159 else if (!ccl_stricmp (qual_value, "b"))
160 value = CCL_BIB1_TRU_CAN_BOTH;
161 else if (!ccl_stricmp (qual_value, "n"))
162 value = CCL_BIB1_TRU_CAN_NONE;
169 type = atoi (qual_type);
172 type_ar[pair_no] = type;
176 value_ar[pair_no] = value;
177 svalue_ar[pair_no] = 0;
179 else if (*qual_value >= '0' && *qual_value <= '9')
181 value_ar[pair_no] = atoi (qual_value);
182 svalue_ar[pair_no] = 0;
188 len = split - qual_value;
190 len = strlen(qual_value);
191 svalue_ar[pair_no] = (char *) xmalloc(len+1);
192 memcpy(svalue_ar[pair_no], qual_value, len);
193 svalue_ar[pair_no][len] = '\0';
197 attsets[pair_no] = (char*) xmalloc (strlen(qual_spec)+1);
198 strcpy (attsets[pair_no], qual_spec);
201 attsets[pair_no] = 0;
207 ccl_qual_add_set (bibset, qual_name, pair_no, type_ar, value_ar, svalue_ar,
211 void ccl_qual_fitem (CCL_bibset bibset, const char *cp, const char *qual_name)
213 if (*qual_name == '@')
214 ccl_qual_add_special(bibset, qual_name+1, cp);
216 ccl_qual_field(bibset, cp, qual_name);
219 void ccl_qual_buf(CCL_bibset bibset, const char *buf)
221 const char *cp1 = buf;
225 const char *cp2 = cp1;
227 while (*cp2 && !strchr("\r\n", *cp2))
232 if (len >= (sizeof(line)-1))
233 len = sizeof(line)-1;
234 memcpy(line, cp1, len);
236 ccl_qual_line(bibset, line);
244 void ccl_qual_line(CCL_bibset bibset, char *line)
248 char *cp1, *cp = line;
251 return; /* ignore lines starting with # */
252 if (sscanf (cp, "%100s%n", qual_name, &no_scan) < 1)
253 return; /* also ignore empty lines */
255 cp1 = strchr(cp, '#');
258 ccl_qual_fitem (bibset, cp, qual_name);
262 * ccl_qual_file: Read bibset definition from file.
266 * Each line format is:
267 * <name> <t>=<v> <t>=<v> ....
268 * Where <name> is name of qualifier;
269 * <t>=<v> is a attribute definition pair where <t> is one of:
270 * u(use), r(relation), p(position), t(truncation), c(completeness)
272 * <v> is an integer or special pseudo-value.
274 void ccl_qual_file (CCL_bibset bibset, FILE *inf)
278 while (fgets (line, 255, inf))
279 ccl_qual_line(bibset, line);
282 int ccl_qual_fname (CCL_bibset bibset, const char *fname)
285 inf = fopen (fname, "r");
288 ccl_qual_file (bibset, inf);