3 /* $Id: xpath4.c,v 1.4 2004-11-05 18:08:06 heikki Exp $
4 Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004
7 This file is part of the Zebra server.
9 Zebra is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 2, or (at your option) any later
14 Zebra is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
19 You should have received a copy of the GNU General Public License
20 along with Zebra; see the file LICENSE.zebra. If not, write to the
21 Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
28 /** xpath4.c - Attributes */
30 const char *myrec[] = {
32 " <title>foo</title> \n"
33 " <title>bar</title> \n"
34 " <author>gryf</author> \n"
38 " <title>foo bar</title> \n"
39 " <author>gryf</author> \n"
43 " <title lang=en>foo gryf</title> \n"
44 " <author>grunt</author> \n"
48 " <title lang=da>foo grunt</title> \n"
49 " <value>bar</value> \n"
53 " <title lang=en>double english</title> \n"
54 " <title lang=da>double danish</title> \n"
55 " <author>grunt</author> \n"
59 " <title>hamlet</title> \n"
60 " <author>foo bar grunt grunt grunt</author> \n"
77 " <nestattr level=outer> \n"
79 " <nestattr level=inner> \n"
89 int main(int argc, char **argv)
91 ZebraService zs = start_up("zebraxpath.cfg", argc, argv);
92 ZebraHandle zh = zebra_open (zs);
95 yaz_log_init_level( yaz_log_mask_str_x("xpath4,rsbetween", LOG_DEFAULT_LEVEL));
100 #define q(qry,hits) do_query(__LINE__,zh,qry,hits)
102 q("@attr 1=/record/title foo",4);
103 q("@attr 1=/record/title bar",2);
104 q("@attr 1=/record/title[@lang='da'] foo",1);
105 q("@attr 1=/record/title[@lang='en'] foo",1);
107 q("@attr 1=/record/title[@lang='en'] english",1);
108 q("@attr 1=/record/title[@lang='da'] english",0);
109 q("@attr 1=/record/title[@lang='da'] danish",1);
110 q("@attr 1=/record/title[@lang='en'] danish",0);
112 q("@attr 1=/record/title @and foo bar",2);
113 /* The previous one returns two hits, as the and applies to the whole
114 record, so it matches <title>foo</title><title>bar</title>
115 This might not have to be like that, but currently that is what
117 q("@and @attr 1=/record/title foo @attr 1=/record/title bar ",2);
119 /* check we get all the occureences for 'grunt' */
120 /* this can only be seen in the log, with debugs on. bug #202 */
121 q("@attr 1=/record/author grunt",3);
123 /* check nested tags */
124 q("@attr 1=/record/nested before",0);
125 q("@attr 1=/record/nested early",1);
126 q("@attr 1=/record/nested middle",1);
127 q("@attr 1=/record/nested late",1);
128 q("@attr 1=/record/nested after",0);
130 q("@attr 1=/record/nested/nested before",0);
131 q("@attr 1=/record/nested/nested early",0);
132 q("@attr 1=/record/nested/nested middle",1);
133 q("@attr 1=/record/nested/nested late",0);
134 q("@attr 1=/record/nested/nested after",0);
136 q("@attr 1=/record/nestattr[@level='outer'] before",0);
137 q("@attr 1=/record/nestattr[@level='outer'] early",1);
138 q("@attr 1=/record/nestattr[@level='outer'] middle",1);
139 q("@attr 1=/record/nestattr[@level='outer'] late",1);
140 q("@attr 1=/record/nestattr[@level='outer'] after",0);
142 q("@attr 1=/record/nestattr[@level='inner'] before",0);
143 q("@attr 1=/record/nestattr[@level='inner'] early",0);
144 q("@attr 1=/record/nestattr[@level='inner'] middle",0);
145 q("@attr 1=/record/nestattr[@level='inner'] late",0);
146 q("@attr 1=/record/nestattr[@level='inner'] after",0);
148 q("@attr 1=/record/nestattr/nestattr[@level='inner'] before",0);
149 q("@attr 1=/record/nestattr/nestattr[@level='inner'] early",0);
150 q("@attr 1=/record/nestattr/nestattr[@level='inner'] middle",1);
151 q("@attr 1=/record/nestattr/nestattr[@level='inner'] late",0);
152 q("@attr 1=/record/nestattr/nestattr[@level='inner'] after",0);
154 return close_down(zh, zs, 0);