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 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 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 <https://htdig.sourceforge.net/>
// 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;
}
|