/* $Id: t5.c,v 1.4 2004/07/28 08:15:47 adam Exp $ Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004 Index Data Aps This file is part of the Zebra server. Zebra is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. Zebra is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Zebra; see the file LICENSE.zebra. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include /* read zebra.cfg from env var srcdir if it exists; otherwise current dir */ static ZebraService start_service() { char cfg[256]; char *srcdir = getenv("srcdir"); sprintf(cfg, "%.200s%szebra.cfg", srcdir ? srcdir : "", srcdir ? "/" : ""); return zebra_start(cfg); } static void expect(ZebraHandle zh, const char *pqf, int hits_expect, int *exit_code) { int hits; if (zebra_search_PQF (zh, pqf, "set1", &hits) != 0) { yaz_log(LOG_FATAL, "Search %s: failed", pqf); *exit_code = 1; } else if (hits != hits_expect) { yaz_log(LOG_FATAL, "Search %s: Expected %d, got %d", pqf, hits_expect, hits); *exit_code = 2; } } int main(int argc, char **argv) { int i, hits = -1; int exit_code = 0; ZebraService zs; ZebraHandle zh; const char *myrec[] = { "\nMy title\n\n", "\nMy x title\n\n", "\nMy title x\n\n" , 0} ; yaz_log_init_file("t5.log"); nmem_init (); zs = start_service(); zh = zebra_open (zs); zebra_select_database(zh, "Default"); zebra_init(zh); zebra_begin_trans (zh, 1); for (i = 0; myrec[i]; i++) zebra_add_record (zh, myrec[i], strlen(myrec[i])); zebra_end_trans (zh); expect(zh, "@attr 1=4 my", 3, &exit_code); expect(zh, "@attr 1=4 {my x}", 1, &exit_code); expect(zh, "@attr 1=4 {my x}", 1, &exit_code); expect(zh, "@attr 1=4 {x my}", 0, &exit_code); expect(zh, "@attr 1=4 {my x title}", 1, &exit_code); expect(zh, "@attr 1=4 {my title}", 2, &exit_code); expect(zh, "@attr 1=4 @and x title", 2, &exit_code); /* exl=0 distance=2 order=1 relation=2 (<=), known, unit=word */ expect(zh, "@prox 0 2 1 2 k 2 my x", 2, &exit_code); /* exl=0 distance=2 order=1 relation=2 (<=), known, unit=word */ expect(zh, "@prox 0 2 1 2 k 2 x my", 0, &exit_code); /* exl=0 distance=2 order=0 relation=2 (<=), known, unit=word */ expect(zh, "@prox 0 2 0 2 k 2 x my", 2, &exit_code); /* exl=0 distance=2 order=0 relation=3 (=), known, unit=word */ expect(zh, "@prox 0 2 1 3 k 2 my x", 1, &exit_code); /* exl=1 distance=2 order=0 relation=3 (=), known, unit=word */ expect(zh, "@prox 1 2 1 3 k 2 my x", 1, &exit_code); zebra_close (zh); zebra_stop (zs); nmem_exit (); xmalloc_trav ("x"); exit (exit_code); }