xref: /netbsd-src/external/gpl2/groff/dist/src/libs/libbib/search.cpp (revision 89a07cf815a29524268025a1139fac4c5190f765)
1*89a07cf8Schristos /*	$NetBSD: search.cpp,v 1.1.1.1 2016/01/13 18:41:48 christos Exp $	*/
2*89a07cf8Schristos 
3*89a07cf8Schristos // -*- C++ -*-
4*89a07cf8Schristos /* Copyright (C) 1989, 1990, 1991, 1992, 2000, 2001
5*89a07cf8Schristos    Free Software Foundation, Inc.
6*89a07cf8Schristos      Written by James Clark (jjc@jclark.com)
7*89a07cf8Schristos 
8*89a07cf8Schristos This file is part of groff.
9*89a07cf8Schristos 
10*89a07cf8Schristos groff is free software; you can redistribute it and/or modify it under
11*89a07cf8Schristos the terms of the GNU General Public License as published by the Free
12*89a07cf8Schristos Software Foundation; either version 2, or (at your option) any later
13*89a07cf8Schristos version.
14*89a07cf8Schristos 
15*89a07cf8Schristos groff is distributed in the hope that it will be useful, but WITHOUT ANY
16*89a07cf8Schristos WARRANTY; without even the implied warranty of MERCHANTABILITY or
17*89a07cf8Schristos FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
18*89a07cf8Schristos for more details.
19*89a07cf8Schristos 
20*89a07cf8Schristos You should have received a copy of the GNU General Public License along
21*89a07cf8Schristos with groff; see the file COPYING.  If not, write to the Free Software
22*89a07cf8Schristos Foundation, 51 Franklin St - Fifth Floor, Boston, MA 02110-1301, USA. */
23*89a07cf8Schristos 
24*89a07cf8Schristos #include "lib.h"
25*89a07cf8Schristos 
26*89a07cf8Schristos #include <stdlib.h>
27*89a07cf8Schristos #include <assert.h>
28*89a07cf8Schristos #include <errno.h>
29*89a07cf8Schristos 
30*89a07cf8Schristos #include "posix.h"
31*89a07cf8Schristos #include "errarg.h"
32*89a07cf8Schristos #include "error.h"
33*89a07cf8Schristos #include "nonposix.h"
34*89a07cf8Schristos 
35*89a07cf8Schristos #include "refid.h"
36*89a07cf8Schristos #include "search.h"
37*89a07cf8Schristos 
38*89a07cf8Schristos int linear_truncate_len = 6;
39*89a07cf8Schristos const char *linear_ignore_fields = "XYZ";
40*89a07cf8Schristos 
search_list()41*89a07cf8Schristos search_list::search_list()
42*89a07cf8Schristos : list(0), niterators(0), next_fid(1)
43*89a07cf8Schristos {
44*89a07cf8Schristos }
45*89a07cf8Schristos 
~search_list()46*89a07cf8Schristos search_list::~search_list()
47*89a07cf8Schristos {
48*89a07cf8Schristos   assert(niterators == 0);
49*89a07cf8Schristos   while (list) {
50*89a07cf8Schristos     search_item *tem = list->next;
51*89a07cf8Schristos     delete list;
52*89a07cf8Schristos     list = tem;
53*89a07cf8Schristos   }
54*89a07cf8Schristos }
55*89a07cf8Schristos 
add_file(const char * filename,int silent)56*89a07cf8Schristos void search_list::add_file(const char *filename, int silent)
57*89a07cf8Schristos {
58*89a07cf8Schristos   search_item *p = make_index_search_item(filename, next_fid);
59*89a07cf8Schristos   if (!p) {
60*89a07cf8Schristos     int fd = open(filename, O_RDONLY | O_BINARY);
61*89a07cf8Schristos     if (fd < 0) {
62*89a07cf8Schristos       if (!silent)
63*89a07cf8Schristos 	error("can't open `%1': %2", filename, strerror(errno));
64*89a07cf8Schristos     }
65*89a07cf8Schristos     else
66*89a07cf8Schristos       p = make_linear_search_item(fd, filename, next_fid);
67*89a07cf8Schristos   }
68*89a07cf8Schristos   if (p) {
69*89a07cf8Schristos     search_item **pp;
70*89a07cf8Schristos     for (pp = &list; *pp; pp = &(*pp)->next)
71*89a07cf8Schristos       ;
72*89a07cf8Schristos     *pp = p;
73*89a07cf8Schristos     next_fid = p->next_filename_id();
74*89a07cf8Schristos   }
75*89a07cf8Schristos }
76*89a07cf8Schristos 
nfiles() const77*89a07cf8Schristos int search_list::nfiles() const
78*89a07cf8Schristos {
79*89a07cf8Schristos   int n = 0;
80*89a07cf8Schristos   for (search_item *ptr = list; ptr; ptr = ptr->next)
81*89a07cf8Schristos     n++;
82*89a07cf8Schristos   return n;
83*89a07cf8Schristos }
84*89a07cf8Schristos 
search_list_iterator(search_list * p,const char * q)85*89a07cf8Schristos search_list_iterator::search_list_iterator(search_list *p, const char *q)
86*89a07cf8Schristos : list(p), ptr(p->list), iter(0), query(strsave(q)),
87*89a07cf8Schristos   searcher(q, strlen(q), linear_ignore_fields, linear_truncate_len)
88*89a07cf8Schristos {
89*89a07cf8Schristos   list->niterators += 1;
90*89a07cf8Schristos }
91*89a07cf8Schristos 
~search_list_iterator()92*89a07cf8Schristos search_list_iterator::~search_list_iterator()
93*89a07cf8Schristos {
94*89a07cf8Schristos   list->niterators -= 1;
95*89a07cf8Schristos   a_delete query;
96*89a07cf8Schristos   delete iter;
97*89a07cf8Schristos }
98*89a07cf8Schristos 
next(const char ** pp,int * lenp,reference_id * ridp)99*89a07cf8Schristos int search_list_iterator::next(const char **pp, int *lenp, reference_id *ridp)
100*89a07cf8Schristos {
101*89a07cf8Schristos   while (ptr) {
102*89a07cf8Schristos     if (iter == 0)
103*89a07cf8Schristos       iter = ptr->make_search_item_iterator(query);
104*89a07cf8Schristos     if (iter->next(searcher, pp, lenp, ridp))
105*89a07cf8Schristos       return 1;
106*89a07cf8Schristos     delete iter;
107*89a07cf8Schristos     iter = 0;
108*89a07cf8Schristos     ptr = ptr->next;
109*89a07cf8Schristos   }
110*89a07cf8Schristos   return 0;
111*89a07cf8Schristos }
112*89a07cf8Schristos 
search_item(const char * nm,int fid)113*89a07cf8Schristos search_item::search_item(const char *nm, int fid)
114*89a07cf8Schristos : name(strsave(nm)), filename_id(fid), next(0)
115*89a07cf8Schristos {
116*89a07cf8Schristos }
117*89a07cf8Schristos 
~search_item()118*89a07cf8Schristos search_item::~search_item()
119*89a07cf8Schristos {
120*89a07cf8Schristos   a_delete name;
121*89a07cf8Schristos }
122*89a07cf8Schristos 
is_named(const char * nm) const123*89a07cf8Schristos int search_item::is_named(const char *nm) const
124*89a07cf8Schristos {
125*89a07cf8Schristos   return strcmp(name, nm) == 0;
126*89a07cf8Schristos }
127*89a07cf8Schristos 
next_filename_id() const128*89a07cf8Schristos int search_item::next_filename_id() const
129*89a07cf8Schristos {
130*89a07cf8Schristos   return filename_id + 1;
131*89a07cf8Schristos }
132*89a07cf8Schristos 
~search_item_iterator()133*89a07cf8Schristos search_item_iterator::~search_item_iterator()
134*89a07cf8Schristos {
135*89a07cf8Schristos }
136