File: GParser.h

package info (click to toggle)
htdig 1%3A3.2.0b6-3.1etch1
  • links: PTS
  • area: main
  • in suites: etch
  • size: 14,936 kB
  • ctags: 9,369
  • sloc: ansic: 49,626; cpp: 46,470; sh: 23,053; xml: 4,180; perl: 2,543; makefile: 868; php: 79; asm: 14
file content (47 lines) | stat: -rw-r--r-- 1,054 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#ifndef _GParser_h_
#define _GParser_h_

//
// GParser.h
//
// GParser: An alternate boolean parser, does not use operator precedence.
//          -- but why is it called G? :-)
//
// Part of the ht://Dig package   <http://www.htdig.org/>
// Copyright (c) 1995-2004 The ht://Dig Group
// For copyright details, see the file COPYING in your distribution
// or the GNU Library General Public License (LGPL) version 2 or later
// <http://www.gnu.org/copyleft/lgpl.html>
//
// $Id: GParser.h,v 1.4 2004/05/28 13:15:24 lha Exp $
//

#include "QueryParser.h"
#include "BooleanLexer.h"

class OperatorQuery;

class GParser : public QueryParser
{
public:
	GParser() {}
	~GParser() {}

private:
	// apply the single-level syntax
	Query *ParseExpression();

	// apply the factor syntax
	Query *ParseFactor();

	// return the adequate operator for an operator keyword
	OperatorQuery *MakeOperatorQuery(const String &op) const;

	// give the parent access to the lexical analyzer
	QueryLexer &Token() { return token; }

	// the lexer
	BooleanLexer token;
};

#endif