diff options
Diffstat (limited to 'debian/htdig/htdig-3.2.0b6/htsearch/Query.cc')
-rw-r--r-- | debian/htdig/htdig-3.2.0b6/htsearch/Query.cc | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/debian/htdig/htdig-3.2.0b6/htsearch/Query.cc b/debian/htdig/htdig-3.2.0b6/htsearch/Query.cc new file mode 100644 index 00000000..0be01033 --- /dev/null +++ b/debian/htdig/htdig-3.2.0b6/htsearch/Query.cc @@ -0,0 +1,89 @@ +// +// Query.cc +// +// Query: (abstract) a parsed, 'executable' digger database query +// a query tree is formed by leaf objects (ExactWordQuery) and +// node objects (OperatorQuery) derived from this class. +// Query execution results are returned as ResultList objects. +// Query evaluation is cached. Cache policy is delegated to the +// QueryCache class family. +// +// 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: Query.cc,v 1.4 2004/05/28 13:15:24 lha Exp $ +// + +#include "Query.h" +#include "VolatileCache.h" + +// +// the in-memory query result cache. the default instance is +// defined static so its destructor is called at program exit +// +VolatileCache theDefaultCache; + +QueryCache * +Query::cache = &theDefaultCache; + +extern int debug; + +// +// destructor +// +Query::~Query() +{ +} + +// +// return a ResultList with the query results +// results are initially fetched from the cache +// if not cached, the query is evaluated +// Weight of the results is adjusted at each invocation, as +// the same result list may be shared by different queries +// but different weights may be assigned to the word +// +// +ResultList * +Query::GetResults() +{ + ResultList *result = 0; + + // try to find in cache before trying eval + String signature; + if(cache) + { + signature = GetSignature(); + result = cache->Lookup(signature); + } + + // no cache or not in cache, evaluate + if(!result) + { + if(debug) cerr << "EVAL: " << signature << endl; + result = Evaluate(); + + if(cache) + { + cache->Add(signature, result); + } + } + + // adjust if something found/returned + if(result) + { + if(result->Count()) + { + AdjustWeight(*result); + } + else if(!result->IsIgnore()) + { + result = 0; + } + } + return result; +} + |