1 /* $Id: xpath4.c,v 1.5 2004-12-02 11:28:20 adam Exp $
2 Copyright (C) 2003,2004
5 This file is part of the Zebra server.
7 Zebra is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
12 Zebra is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 You should have received a copy of the GNU General Public License
18 along with Zebra; see the file LICENSE.zebra. If not, write to the
19 Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
26 /** xpath4.c - Attributes */
28 const char *myrec[] = {
30 " <title>foo</title> \n"
31 " <title>bar</title> \n"
32 " <author>gryf</author> \n"
36 " <title>foo bar</title> \n"
37 " <author>gryf</author> \n"
41 " <title lang=en>foo gryf</title> \n"
42 " <author>grunt</author> \n"
46 " <title lang=da>foo grunt</title> \n"
47 " <value>bar</value> \n"
51 " <title lang=en>double english</title> \n"
52 " <title lang=da>double danish</title> \n"
53 " <author>grunt</author> \n"
57 " <title>hamlet</title> \n"
58 " <author>foo bar grunt grunt grunt</author> \n"
75 " <nestattr level=outer> \n"
77 " <nestattr level=inner> \n"
87 int main(int argc, char **argv)
89 ZebraService zs = start_up("zebraxpath.cfg", argc, argv);
90 ZebraHandle zh = zebra_open(zs);
93 yaz_log_init_level( yaz_log_mask_str_x("xpath4,rsbetween", LOG_DEFAULT_LEVEL));
98 #define q(qry,hits) do_query(__LINE__,zh,qry,hits)
100 q("@attr 1=/record/title foo",4);
101 q("@attr 1=/record/title bar",2);
102 q("@attr 1=/record/title[@lang='da'] foo",1);
103 q("@attr 1=/record/title[@lang='en'] foo",1);
105 q("@attr 1=/record/title[@lang='en'] english",1);
106 q("@attr 1=/record/title[@lang='da'] english",0);
107 q("@attr 1=/record/title[@lang='da'] danish",1);
108 q("@attr 1=/record/title[@lang='en'] danish",0);
110 q("@attr 1=/record/title @and foo bar",2);
111 /* The previous one returns two hits, as the and applies to the whole
112 record, so it matches <title>foo</title><title>bar</title>
113 This might not have to be like that, but currently that is what
115 q("@and @attr 1=/record/title foo @attr 1=/record/title bar ",2);
117 /* check we get all the occureences for 'grunt' */
118 /* this can only be seen in the log, with debugs on. bug #202 */
119 q("@attr 1=/record/author grunt",3);
121 /* check nested tags */
122 q("@attr 1=/record/nested before",0);
123 q("@attr 1=/record/nested early",1);
124 q("@attr 1=/record/nested middle",1);
125 q("@attr 1=/record/nested late",1);
126 q("@attr 1=/record/nested after",0);
128 q("@attr 1=/record/nested/nested before",0);
129 q("@attr 1=/record/nested/nested early",0);
130 q("@attr 1=/record/nested/nested middle",1);
131 q("@attr 1=/record/nested/nested late",0);
132 q("@attr 1=/record/nested/nested after",0);
134 q("@attr 1=/record/nestattr[@level='outer'] before",0);
135 q("@attr 1=/record/nestattr[@level='outer'] early",1);
136 q("@attr 1=/record/nestattr[@level='outer'] middle",1);
137 q("@attr 1=/record/nestattr[@level='outer'] late",1);
138 q("@attr 1=/record/nestattr[@level='outer'] after",0);
140 q("@attr 1=/record/nestattr[@level='inner'] before",0);
141 q("@attr 1=/record/nestattr[@level='inner'] early",0);
142 q("@attr 1=/record/nestattr[@level='inner'] middle",0);
143 q("@attr 1=/record/nestattr[@level='inner'] late",0);
144 q("@attr 1=/record/nestattr[@level='inner'] after",0);
146 q("@attr 1=/record/nestattr/nestattr[@level='inner'] before",0);
147 q("@attr 1=/record/nestattr/nestattr[@level='inner'] early",0);
148 q("@attr 1=/record/nestattr/nestattr[@level='inner'] middle",1);
149 q("@attr 1=/record/nestattr/nestattr[@level='inner'] late",0);
150 q("@attr 1=/record/nestattr/nestattr[@level='inner'] after",0);
152 return close_down(zh, zs, 0);