1 /* This file is part of the YAZ toolkit.
2 * Copyright (C) Index Data
3 * See the file LICENSE for details.
10 #include <yaz/ccl_xml.h>
15 static int tst_ccl_query(CCL_bibset bibset,
19 CCL_parser parser = ccl_parser_create(bibset);
24 struct ccl_rpn_node *rpn;
26 rpn = ccl_parser_find_str(parser, query);
29 /* parse ok. check that result is there and match */
30 WRBUF wrbuf = wrbuf_alloc();
31 ccl_pquery(wrbuf, rpn);
33 /* check expect a result and that it matches */
34 if (result && !strcmp(wrbuf_cstr(wrbuf), result))
38 yaz_log(YLOG_WARN, "%s: result does not match", query);
39 yaz_log(YLOG_WARN, " expected %s", result);
40 yaz_log(YLOG_WARN, " got %s", wrbuf_cstr(wrbuf));
50 yaz_log(YLOG_WARN, "%s: parse failed", query);
57 ccl_parser_destroy (parser);
63 CCL_bibset bibset = ccl_qual_mk();
72 CCL_bibset nbibset = ccl_qual_dup(bibset);
80 ccl_qual_fitem(bibset, "term dc.title", "comb");
81 ccl_qual_fitem(bibset, "u=4 s=pw t=l,r", "ti");
82 ccl_qual_fitem(bibset, "1=1016 s=al,pw t=r", "term");
83 ccl_qual_fitem(bibset, "t=x", "reg");
84 ccl_qual_fitem(bibset, "t=z", "z");
85 ccl_qual_fitem(bibset, "1=/my/title", "dc.title");
86 ccl_qual_fitem(bibset, "r=r,omiteq", "date");
87 ccl_qual_fitem(bibset, "r=o", "x");
88 ccl_qual_fitem(bibset, "dc.title", "title");
89 ccl_qual_fitem(bibset, "s=ag", "ag");
92 strcpy(tstline, "ti u=4 s=pw t=l,r");
93 ccl_qual_line(bibset, tstline);
95 strcpy(tstline, "term 1=1016 s=al,pw t=r # default term");
96 ccl_qual_line(bibset, tstline);
98 strcpy(tstline, "reg t=x");
99 ccl_qual_line(bibset, tstline);
101 strcpy(tstline, "z t=z");
102 ccl_qual_line(bibset, tstline);
104 strcpy(tstline, "dc.title 1=/my/title");
105 ccl_qual_line(bibset, tstline);
107 strcpy(tstline, "date r=r,omiteq # ordered relation");
108 ccl_qual_line(bibset, tstline);
110 strcpy(tstline, "x r=o # ordered relation");
111 ccl_qual_line(bibset, tstline);
113 strcpy(tstline, "title dc.title # alias");
114 ccl_qual_line(bibset, tstline);
116 strcpy(tstline, "comb term dc.title # combination");
117 ccl_qual_line(bibset, tstline);
119 strcpy(tstline, "ag s=ag");
120 ccl_qual_line(bibset, tstline);
123 ccl_qual_buf(bibset, "ti u=4 s=pw t=l,r\n"
124 "term 1=1016 s=al,pw t=r\r\n"
128 "dc.title 1=/my/title\n"
132 "comb term dc.title\n"
142 const char *addinfo = 0;
143 const char *xml_str =
145 " <qual name=\"ti\">\n"
146 " <attr type=\"u\" value=\"4\"/>\n"
147 " <attr type=\"s\" value=\"pw\"/>\n"
148 " <attr type=\"t\" value=\"l,r\"/>\n"
150 " <qual name=\"term\">\n"
151 " <attr type=\"1\" value=\"1016\"/>\n"
152 " <attr type=\"s\" value=\"al,pw\"/>\n"
153 " <attr type=\"t\" value=\"r\"/>\n"
155 " <qual name=\"reg\">\n"
156 " <attr type=\"t\" value=\"x\"/>\n"
158 " <qual name=\"z\">\n"
159 " <attr type=\"t\" value=\"z\"/>\n"
161 " <qual name=\"dc.title\">\n"
162 " <attr type=\"1\" value=\"/my/title\"/>\n"
164 " <qual name=\"date\">\n"
165 " <attr type=\"r\" value=\"r,omiteq\"/>\n"
167 " <qual name=\"x\">\n"
168 " <attr type=\"r\" value=\"o\"/>\n"
170 " <qual name=\"title\">\n"
171 " <qual name=\"dc.title\"/>\n"
173 " <qual name=\"comb\">\n"
174 " <qual name=\"term\"/>\n"
175 " <qual name=\"dc.title\"/>\n"
177 " <qual name=\"ag\">\n"
178 " <attr type=\"s\" value=\"ag\"/>\n"
182 doc = xmlParseMemory(xml_str, strlen(xml_str));
185 r = ccl_xml_config(bibset, xmlDocGetRootElement(doc), &addinfo);
199 YAZ_CHECK(tst_ccl_query(bibset, "x1", "@attr 4=2 @attr 1=1016 x1 "));
201 YAZ_CHECK(tst_ccl_query(bibset, "k\xc3\xb8" "benhavn", "@attr 4=2 @attr 1=1016 k\xc3\xb8" "benhavn "));
203 YAZ_CHECK(tst_ccl_query(bibset, "k\xf8" "benhavn", "@attr 4=2 @attr 1=1016 ""k\xf8" "benhavn "));
205 YAZ_CHECK(tst_ccl_query(bibset, "(((((x1)))))", "@attr 4=2 @attr 1=1016 x1 "));
206 YAZ_CHECK(tst_ccl_query(bibset, "x1 and x2",
208 "@attr 4=2 @attr 1=1016 x1 "
209 "@attr 4=2 @attr 1=1016 x2 "));
210 YAZ_CHECK(tst_ccl_query(bibset, "ti=x3", "@attr 4=2 @attr 1=4 x3 "));
211 YAZ_CHECK(tst_ccl_query(bibset, "dc.title=x4", "@attr 1=/my/title x4 "));
212 YAZ_CHECK(tst_ccl_query(bibset, "dc.title=(x4)", "@attr 1=/my/title x4 "));
213 YAZ_CHECK(tst_ccl_query(bibset, "x1 and", 0));
214 YAZ_CHECK(tst_ccl_query(bibset, "tix=x5", 0));
216 YAZ_CHECK(tst_ccl_query(bibset, "a%b",
218 "@attr 4=2 @attr 1=1016 a "
219 "@attr 4=2 @attr 1=1016 b "));
220 YAZ_CHECK(tst_ccl_query(bibset, "a%(b)",
222 "@attr 4=2 @attr 1=1016 a "
223 "@attr 4=2 @attr 1=1016 b "));
224 YAZ_CHECK(tst_ccl_query(bibset, "(a)%(b)",
226 "@attr 4=2 @attr 1=1016 a "
227 "@attr 4=2 @attr 1=1016 b "));
228 YAZ_CHECK(tst_ccl_query(bibset, "a%1b",
230 "@attr 4=2 @attr 1=1016 a "
231 "@attr 4=2 @attr 1=1016 b "));
233 YAZ_CHECK(tst_ccl_query(bibset, "a%2b",
235 "@attr 4=2 @attr 1=1016 a "
236 "@attr 4=2 @attr 1=1016 b "));
238 YAZ_CHECK(tst_ccl_query(bibset, "(a)%2(b)",
240 "@attr 4=2 @attr 1=1016 a "
241 "@attr 4=2 @attr 1=1016 b "));
243 YAZ_CHECK(tst_ccl_query(bibset, "a%19b",
244 "@prox 0 19 0 2 k 2 "
245 "@attr 4=2 @attr 1=1016 a "
246 "@attr 4=2 @attr 1=1016 b "));
248 YAZ_CHECK(tst_ccl_query(bibset, "spid%æserne",
250 "@attr 4=2 @attr 1=1016 spid "
251 "@attr 4=2 @attr 1=1016 æserne "));
253 YAZ_CHECK(tst_ccl_query(bibset, "a!b",
255 "@attr 4=2 @attr 1=1016 a "
256 "@attr 4=2 @attr 1=1016 b "));
257 YAZ_CHECK(tst_ccl_query(bibset, "a!2b",
259 "@attr 4=2 @attr 1=1016 a "
260 "@attr 4=2 @attr 1=1016 b "));
262 YAZ_CHECK(tst_ccl_query(bibset, "a% (b or dc.title=c)",
264 "@attr 4=2 @attr 1=1016 a "
265 "@or @attr 4=2 @attr 1=1016 b "
267 "@or @attr 4=2 @attr 1=/my/title c "
268 "@attr 4=2 @attr 1=1016 c "
270 "@attr 4=2 @attr 1=1016 @attr 1=/my/title c "
274 YAZ_CHECK(tst_ccl_query(bibset, "(a b) % (c)",
275 "@prox 0 1 0 2 k 2 @and "
276 "@attr 4=2 @attr 1=1016 a @attr 4=2 @attr 1=1016 b "
277 "@attr 4=2 @attr 1=1016 c " ));
279 YAZ_CHECK(tst_ccl_query(bibset, "date=1980",
281 YAZ_CHECK(tst_ccl_query(bibset, "(date=1980)",
283 YAZ_CHECK(tst_ccl_query(bibset, "date>1980",
285 YAZ_CHECK(tst_ccl_query(bibset, "date>=1980",
287 YAZ_CHECK(tst_ccl_query(bibset, "date<1980",
289 YAZ_CHECK(tst_ccl_query(bibset, "date<=1980",
291 YAZ_CHECK(tst_ccl_query(bibset, "date=234-1990",
292 "@and @attr 2=4 234 @attr 2=2 1990 "));
293 YAZ_CHECK(tst_ccl_query(bibset, "date=234- 1990",
294 "@and @attr 2=4 234 @attr 2=2 1990 "));
295 YAZ_CHECK(tst_ccl_query(bibset, "date=234 -1990",
296 "@and @attr 2=4 234 @attr 2=2 1990 "));
297 YAZ_CHECK(tst_ccl_query(bibset, "date=234 - 1990",
298 "@and @attr 2=4 234 @attr 2=2 1990 "));
299 YAZ_CHECK(tst_ccl_query(bibset, "date=-1980",
301 YAZ_CHECK(tst_ccl_query(bibset, "date=- 1980",
303 YAZ_CHECK(tst_ccl_query(bibset, "x=-1980",
304 "@attr 2=3 -1980 "));
305 YAZ_CHECK(tst_ccl_query(bibset, "x=- 1980",
307 YAZ_CHECK(tst_ccl_query(bibset, "x= -1980",
308 "@attr 2=3 -1980 "));
309 YAZ_CHECK(tst_ccl_query(bibset, "x=234-1990",
310 "@attr 2=3 234-1990 "));
311 YAZ_CHECK(tst_ccl_query(bibset, "x=234 - 1990",
312 "@and @attr 2=4 234 @attr 2=2 1990 "));
313 YAZ_CHECK(tst_ccl_query(bibset, "ti=a,b",
314 "@attr 4=1 @attr 1=4 a,b "));
315 YAZ_CHECK(tst_ccl_query(bibset, "ti=a, b",
316 "@attr 4=1 @attr 1=4 \"a, b\" "));
317 YAZ_CHECK(tst_ccl_query(bibset, "ti=a-b",
318 "@attr 4=2 @attr 1=4 a-b "));
319 YAZ_CHECK(tst_ccl_query(bibset, "ti=a - b",
320 "@attr 4=1 @attr 1=4 \"a - b\" "));
322 YAZ_CHECK(tst_ccl_query(bibset, "a?",
323 "@attr 5=1 @attr 4=2 @attr 1=1016 a "));
324 YAZ_CHECK(tst_ccl_query(bibset, "a b",
325 "@and @attr 4=2 @attr 1=1016 a "
326 "@attr 4=2 @attr 1=1016 b "));
328 YAZ_CHECK(tst_ccl_query(bibset, "a b?",
329 "@and @attr 4=2 @attr 1=1016 a "
330 "@attr 5=1 @attr 4=2 @attr 1=1016 b "));
332 YAZ_CHECK(tst_ccl_query(bibset, "title=a",
333 "@attr 1=/my/title a "));
335 YAZ_CHECK(tst_ccl_query(bibset, "reg=a?b#\"c?\"",
336 "@attr 5=102 a.*b.c\\\\? "));
337 YAZ_CHECK(tst_ccl_query(bibset, "z=a?b#\"c?\"",
338 "@attr 5=104 a?b#c\\\\? "));
340 YAZ_CHECK(tst_ccl_query(bibset, "reg=\\(",
342 YAZ_CHECK(tst_ccl_query(bibset, "z=\\(",
345 YAZ_CHECK(tst_ccl_query(bibset, "z=a b#",
346 "@attr 5=104 \"a b#\" "));
348 YAZ_CHECK(tst_ccl_query(bibset, "reg=\\\"",
350 YAZ_CHECK(tst_ccl_query(bibset, "z=\\\"",
353 YAZ_CHECK(tst_ccl_query(bibset, "reg=.",
355 YAZ_CHECK(tst_ccl_query(bibset, "z=.",
358 YAZ_CHECK(tst_ccl_query(bibset, "reg=\".\"",
360 YAZ_CHECK(tst_ccl_query(bibset, "z=\".\"",
363 YAZ_CHECK(tst_ccl_query(bibset, "reg=?\\?",
364 "@attr 5=102 .*\\\\? "));
365 YAZ_CHECK(tst_ccl_query(bibset, "z=?\\?",
366 "@attr 5=104 ?\\\\? "));
368 YAZ_CHECK(tst_ccl_query(bibset, "reg=\"?\\?\"",
370 YAZ_CHECK(tst_ccl_query(bibset, "z=\"?\\?\"",
373 YAZ_CHECK(tst_ccl_query(bibset, "reg=\\\\",
375 YAZ_CHECK(tst_ccl_query(bibset, "z=\\\\",
378 YAZ_CHECK(tst_ccl_query(bibset, "\\\\",
379 "@attr 4=2 @attr 1=1016 \\\\ "));
381 YAZ_CHECK(tst_ccl_query(bibset, "comb=a",
382 "@or @attr 4=2 @attr 1=1016 a "
383 "@attr 1=/my/title a "));
385 YAZ_CHECK(tst_ccl_query(bibset, "a? b?",
386 "@and @attr 5=1 @attr 4=2 @attr 1=1016 a "
387 "@attr 5=1 @attr 4=2 @attr 1=1016 b "));
389 YAZ_CHECK(tst_ccl_query(bibset, "\"a\"? \"b?\"",
390 "@and @attr 5=1 @attr 4=2 @attr 1=1016 a "
391 "@attr 4=2 @attr 1=1016 b? "));
393 YAZ_CHECK(tst_ccl_query(bibset, "@and",
394 "@attr 4=2 @attr 1=1016 \\@and "));
396 YAZ_CHECK(tst_ccl_query(bibset, "a@and",
397 "@attr 4=2 @attr 1=1016 a@and "));
399 YAZ_CHECK(tst_ccl_query(bibset, "}",
400 "@attr 4=2 @attr 1=1016 } "));
402 YAZ_CHECK(tst_ccl_query(bibset, "{",
403 "@attr 4=2 @attr 1=1016 \"{\" "));
405 YAZ_CHECK(tst_ccl_query(bibset, "\"a b c\"",
406 "@attr 4=1 @attr 1=1016 \"a b c\" "));
408 YAZ_CHECK(tst_ccl_query(bibset, "\"a b c \"",
409 "@attr 4=1 @attr 1=1016 \"a b c \" "));
411 YAZ_CHECK(tst_ccl_query(bibset, "ag=a",
414 YAZ_CHECK(tst_ccl_query(bibset, "ag=a b",
415 "@attr 4=2 \"a b\" "));
417 YAZ_CHECK(tst_ccl_query(bibset, "ag=a b \"c d\"",
418 "@and @attr 4=2 \"a b\" @attr 4=1 \"c d\" "));
420 YAZ_CHECK(tst_ccl_query(bibset, "ag=a b \"c\"",
421 "@attr 4=2 \"a b c\" "));
423 YAZ_CHECK(tst_ccl_query(bibset, "ag=a b \"\"",
424 "@attr 4=2 \"a b \" "));
426 YAZ_CHECK(tst_ccl_query(bibset, "ag=a \"b c\" d",
428 "@attr 4=2 a @attr 4=1 \"b c\" @attr 4=2 d "));
430 YAZ_CHECK(tst_ccl_query(bibset, "ag=\"a b c\"",
431 "@attr 4=1 \"a b c\" "));
433 YAZ_CHECK(tst_ccl_query(bibset, "ag=\"a b c\" \"d e\"",
434 "@and @attr 4=1 \"a b c\" @attr 4=1 \"d e\" "));
435 ccl_qual_rm(&bibset);
440 CCL_bibset bibset = ccl_qual_mk();
446 ccl_qual_fitem(bibset, "u=4 s=pw t=l,r", "ti");
447 ccl_qual_fitem(bibset, "1=1016 s=al,pw t=z", "term");
449 YAZ_CHECK(tst_ccl_query(bibset, "a?#",
450 "@attr 5=104 @attr 4=2 @attr 1=1016 a?# "));
452 YAZ_CHECK(tst_ccl_query(bibset, "a b?#",
453 "@and @attr 4=2 @attr 1=1016 a @attr 5=104 @attr 4=2 @attr 1=1016 b?# "));
455 YAZ_CHECK(tst_ccl_query(bibset, "a*",
456 "@attr 4=2 @attr 1=1016 a* "));
458 YAZ_CHECK(tst_ccl_query(bibset, "a?",
459 "@attr 5=104 @attr 4=2 @attr 1=1016 a? "));
461 ccl_qual_fitem(bibset, "*", "@truncation");
462 YAZ_CHECK(tst_ccl_query(bibset, "a*",
463 "@attr 5=104 @attr 4=2 @attr 1=1016 a? "));
465 YAZ_CHECK(tst_ccl_query(bibset, "a?",
466 "@attr 4=2 @attr 1=1016 a? "));
468 ccl_qual_fitem(bibset, "?", "@mask");
469 YAZ_CHECK(tst_ccl_query(bibset, "a?",
470 "@attr 5=104 @attr 4=2 @attr 1=1016 a# "));
473 ccl_qual_fitem(bibset, "", "@mask");
474 ccl_qual_fitem(bibset, "", "@truncation");
475 YAZ_CHECK(tst_ccl_query(bibset, "a?#",
476 "@attr 4=2 @attr 1=1016 a?# "));
478 ccl_qual_fitem(bibset, "og", "@and");
479 ccl_qual_fitem(bibset, "eller", "@or");
480 ccl_qual_fitem(bibset, "ikke", "@not");
482 YAZ_CHECK(tst_ccl_query(bibset, "a og b eller c ikke d",
483 "@not @or @and @attr 4=2 @attr 1=1016 a "
484 "@attr 4=2 @attr 1=1016 b "
485 "@attr 4=2 @attr 1=1016 c "
486 "@attr 4=2 @attr 1=1016 d "));
487 ccl_qual_rm(&bibset);
491 void tst_addinfo(void)
495 CCL_bibset bibset = ccl_qual_mk();
497 r = ccl_qual_fitem2(bibset, "u=4 s=pw t=l,r", "ti", &addinfo);
498 YAZ_CHECK(r == 0 && addinfo == 0);
500 r = ccl_qual_fitem2(bibset, "1=1016 s=al,pw t=z", "term", &addinfo);
501 YAZ_CHECK(r == 0 && addinfo == 0);
503 r = ccl_qual_fitem2(bibset, "x=", "term", &addinfo);
504 YAZ_CHECK(r != 0 && addinfo != 0);
506 r = ccl_qual_fitem2(bibset, "12=3", "term", &addinfo);
507 YAZ_CHECK(r == 0 && addinfo == 0);
509 r = ccl_qual_fitem2(bibset, "ab=3", "term", &addinfo);
510 YAZ_CHECK(r != 0 && addinfo != 0);
512 r = ccl_qual_fitem2(bibset, "x=ab", "term", &addinfo);
513 YAZ_CHECK(r != 0 && addinfo != 0);
515 r = ccl_qual_fitem2(bibset, "s=ab", "term", &addinfo);
516 YAZ_CHECK(r == 0 && addinfo == 0);
518 ccl_qual_rm(&bibset);
521 int main(int argc, char **argv)
523 YAZ_CHECK_INIT(argc, argv);
536 * c-file-style: "Stroustrup"
537 * indent-tabs-mode: nil
539 * vim: shiftwidth=4 tabstop=8 expandtab