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
|
/*------------------------------------------------------------------------------
* Copyright (C) 2003-2006 Ben van Klinken and the CLucene Team
*
* Distributable under the terms of either the Apache License (Version 2.0) or
* the GNU Lesser General Public License, as specified in the COPYING file.
------------------------------------------------------------------------------*/
#ifndef _lucene_search_CachingWrapperFilter_
#define _lucene_search_CachingWrapperFilter_
#include "CLucene/util/BitSet.h"
#include "CLucene/index/IndexReader.h"
#include "Filter.h"
CL_NS_DEF(search)
/**
* Wraps another filter's result and caches it. The purpose is to allow
* filters to implement this and allow itself to be cached. Alternatively,
* use the CachingWrapperFilter to cache the filter.
*/
class AbstractCachingFilter: public Filter
{
class BitSetHolder: LUCENE_BASE{
bool deleteBs;
public:
BitSetHolder(CL_NS(util)::BitSet* bits, bool deleteBs);
~BitSetHolder();
CL_NS(util)::BitSet* bits;
};
void closeCallback(CL_NS(index)::IndexReader* reader, void* param);
typedef CL_NS(util)::CLHashMap<CL_NS(index)::IndexReader*,
BitSetHolder*,
CL_NS(util)::Compare::Void<CL_NS(index)::IndexReader>,
CL_NS(util)::Equals::Void<CL_NS(index)::IndexReader>,
CL_NS(util)::Deletor::Object<CL_NS(index)::IndexReader>,
CL_NS(util)::Deletor::Object<BitSetHolder> > CacheType;
CacheType cache;
protected:
AbstractCachingFilter( const AbstractCachingFilter& copy );
virtual CL_NS(util)::BitSet* doBits( CL_NS(index)::IndexReader* reader ) = 0;
virtual bool doShouldDeleteBitSet( CL_NS(util)::BitSet* bits ){ return false; }
AbstractCachingFilter();
public:
virtual ~AbstractCachingFilter();
/** Returns a BitSet with true for documents which should be permitted in
search results, and false for those that should not. */
CL_NS(util)::BitSet* bits( CL_NS(index)::IndexReader* reader );
virtual Filter *clone() const = 0;
virtual TCHAR *toString() = 0;
bool shouldDeleteBitSet( const CL_NS(util)::BitSet* bits ) const{ return false; }
};
/**
* Wraps another filter's result and caches it. The purpose is to allow
* filters to simply filter, and then wrap with this class to add
* caching, keeping the two concerns decoupled yet composable.
*/
class CachingWrapperFilter: public AbstractCachingFilter
{
private:
Filter* filter;
bool deleteFilter;
protected:
CachingWrapperFilter( const CachingWrapperFilter& copy );
CL_NS(util)::BitSet* doBits( CL_NS(index)::IndexReader* reader );
bool doShouldDeleteBitSet( CL_NS(util)::BitSet* bits );
public:
CachingWrapperFilter( Filter* filter, bool deleteFilter=true );
~CachingWrapperFilter();
Filter *clone() const;
TCHAR *toString();
};
CL_NS_END
#endif
|