xapian-core  1.4.25
Public Member Functions | Private Member Functions | Private Attributes | Friends | List of all members
InMemoryPostList Class Reference

A PostList in an inmemory database. More...

#include <inmemory_database.h>

+ Inheritance diagram for InMemoryPostList:
+ Collaboration diagram for InMemoryPostList:

Public Member Functions

Xapian::doccount get_termfreq () const
 Return the exact term frequency. More...
 
Xapian::docid get_docid () const
 Return the current docid. More...
 
Xapian::termcount get_doclength () const
 Return the length of current document. More...
 
Xapian::termcount get_unique_terms () const
 Return the number of unique terms in the current document. More...
 
Xapian::termcount get_wdf () const
 Return the wdf for the document at the current position. More...
 
PositionListread_position_list ()
 Read the position list for the term in the current document and return a pointer to it (owned by the PostList). More...
 
PositionListopen_position_list () const
 Read the position list for the term in the current document and return a pointer to it (not owned by the PostList). More...
 
PostListnext (double w_min)
 Advance the current position to the next document in the postlist. More...
 
PostListskip_to (Xapian::docid did, double w_min)
 Skip forward to the specified docid. More...
 
bool at_end () const
 Return true if the current position is past the last entry in this list. More...
 
Xapian::termcount get_wdf_upper_bound () const
 
string get_description () const
 Return a string description of this object. More...
 
- Public Member Functions inherited from LeafPostList
 ~LeafPostList ()
 
void set_termweight (const Xapian::Weight *weight_)
 Set the weighting scheme to use during matching. More...
 
double resolve_lazy_termweight (Xapian::Weight *weight_, Xapian::Weight::Internal *stats, Xapian::termcount qlen, Xapian::termcount wqf, double factor)
 
Xapian::doccount get_termfreq_min () const
 Get a lower bound on the number of documents indexed by this term. More...
 
Xapian::doccount get_termfreq_max () const
 Get an upper bound on the number of documents indexed by this term. More...
 
Xapian::doccount get_termfreq_est () const
 Get an estimate of the number of documents indexed by this term. More...
 
double get_maxweight () const
 Return an upper bound on what get_weight() can return. More...
 
double get_weight () const
 Return the weight contribution for the current position. More...
 
double recalc_maxweight ()
 Recalculate the upper bound on what get_weight() can return. More...
 
TermFreqs get_termfreq_est_using_stats (const Xapian::Weight::Internal &stats) const
 Get an estimate for the termfreq and reltermfreq, given the stats. More...
 
Xapian::termcount count_matching_subqs () const
 Count the number of leaf subqueries which match at the current position. More...
 
void gather_position_lists (OrPositionList *orposlist)
 Gather PositionList* objects for a subtree. More...
 
virtual LeafPostListopen_nearby_postlist (const std::string &term_) const
 Open another postlist from the same database. More...
 
void set_term (const std::string &term_)
 Set the term name. More...
 
- Public Member Functions inherited from Xapian::PostingIterator::Internal
virtual ~Internal ()
 We have virtual methods and want to be able to delete derived classes using a pointer to the base class, so we need a virtual destructor. More...
 
virtual const std::string * get_sort_key () const
 
virtual const std::string * get_collapse_key () const
 If the collapse key is already known, return it. More...
 
virtual Internalcheck (Xapian::docid did, double w_min, bool &valid)
 Check if the specified docid occurs in this postlist. More...
 
Internalnext ()
 Advance the current position to the next document in the postlist. More...
 
Internalskip_to (Xapian::docid did)
 Skip forward to the specified docid. More...
 
- Public Member Functions inherited from Xapian::Internal::intrusive_base
 intrusive_base ()
 Construct with no references. More...
 

Private Member Functions

 InMemoryPostList (const InMemoryDatabase *db, const InMemoryTerm &imterm, const std::string &term_)
 

Private Attributes

vector< InMemoryPosting >::const_iterator pos
 
vector< InMemoryPosting >::const_iterator end
 
Xapian::doccount termfreq
 
bool started
 
InMemoryPositionList mypositions
 List of positions of the current term. More...
 
Xapian::Internal::intrusive_ptr< const InMemoryDatabasedb
 
Xapian::termcount wdf_upper_bound
 

Friends

class InMemoryDatabase
 

Additional Inherited Members

- Public Attributes inherited from Xapian::Internal::intrusive_base
unsigned _refs
 Reference count. More...
 
- Protected Member Functions inherited from LeafPostList
 LeafPostList (const std::string &term_)
 Only constructable as a base class for derived classes. More...
 
- Protected Member Functions inherited from Xapian::PostingIterator::Internal
 Internal ()
 Only constructable as a base class for derived classes. More...
 
- Protected Attributes inherited from LeafPostList
const Xapian::Weightweight
 
bool need_doclength
 
bool need_unique_terms
 
std::string term
 The term name for this postlist (empty for an alldocs postlist). More...
 

Detailed Description

A PostList in an inmemory database.

Definition at line 138 of file inmemory_database.h.

Constructor & Destructor Documentation

◆ InMemoryPostList()

InMemoryPostList::InMemoryPostList ( const InMemoryDatabase db,
const InMemoryTerm imterm,
const std::string &  term_ 
)
private

Definition at line 82 of file inmemory_database.cc.

References InMemoryTerm::collection_freq, end, pos, and wdf_upper_bound.

Member Function Documentation

◆ at_end()

bool InMemoryPostList::at_end ( ) const
virtual

Return true if the current position is past the last entry in this list.

Implements Xapian::PostingIterator::Internal.

Definition at line 150 of file inmemory_database.cc.

References db, end, InMemoryDatabase::is_closed(), pos, and InMemoryDatabase::throw_database_closed().

Referenced by get_docid(), next(), and skip_to().

◆ get_description()

string InMemoryPostList::get_description ( ) const
virtual

Return a string description of this object.

Implements Xapian::PostingIterator::Internal.

Definition at line 157 of file inmemory_database.cc.

References Xapian::Internal::str(), and termfreq.

◆ get_docid()

Xapian::docid InMemoryPostList::get_docid ( ) const
virtual

◆ get_doclength()

Xapian::termcount InMemoryPostList::get_doclength ( ) const
virtual

◆ get_termfreq()

Xapian::doccount InMemoryPostList::get_termfreq ( ) const
virtual

Return the exact term frequency.

Leaf postlists have an exact termfreq, which get_termfreq_min(), get_termfreq_max(), and get_termfreq_est() all report.

Implements LeafPostList.

Definition at line 101 of file inmemory_database.cc.

References termfreq.

◆ get_unique_terms()

Xapian::termcount InMemoryPostList::get_unique_terms ( ) const
virtual

Return the number of unique terms in the current document.

Implements Xapian::PostingIterator::Internal.

Definition at line 170 of file inmemory_database.cc.

References db, get_docid(), and InMemoryDatabase::get_unique_terms().

◆ get_wdf()

Xapian::termcount InMemoryPostList::get_wdf ( ) const
virtual

Return the wdf for the document at the current position.

The default implementation throws Xapian::UnimplementedError.

Reimplemented from Xapian::PostingIterator::Internal.

Definition at line 191 of file inmemory_database.cc.

References db, InMemoryDatabase::is_closed(), and InMemoryDatabase::throw_database_closed().

◆ get_wdf_upper_bound()

Xapian::termcount InMemoryPostList::get_wdf_upper_bound ( ) const
virtual

◆ next()

PostList * InMemoryPostList::next ( double  w_min)
virtual

Advance the current position to the next document in the postlist.

The list starts before the first entry in the list, so next(), skip_to() or check() must be called before any methods which need the context of the current position.

Parameters
w_minThe minimum weight contribution that is needed (this is just a hint which PostList subclasses may ignore).
Returns
If a non-NULL pointer is returned, then the caller should substitute the returned pointer for its pointer to us, and then delete us. This "pruning" can only happen for a non-leaf subclass of this class.

Implements Xapian::PostingIterator::Internal.

Definition at line 116 of file inmemory_database.cc.

References Assert, at_end(), db, end, InMemoryDatabase::is_closed(), pos, started, and InMemoryDatabase::throw_database_closed().

◆ open_position_list()

PositionList * InMemoryPostList::open_position_list ( ) const
virtual

Read the position list for the term in the current document and return a pointer to it (not owned by the PostList).

The default implementation throws Xapian::UnimplementedError.

Reimplemented from Xapian::PostingIterator::Internal.

Definition at line 184 of file inmemory_database.cc.

References db, InMemoryDatabase::is_closed(), pos, and InMemoryDatabase::throw_database_closed().

◆ read_position_list()

PositionList * InMemoryPostList::read_position_list ( )
virtual

Read the position list for the term in the current document and return a pointer to it (owned by the PostList).

The default implementation throws Xapian::UnimplementedError.

Reimplemented from Xapian::PostingIterator::Internal.

Definition at line 176 of file inmemory_database.cc.

References db, InMemoryDatabase::is_closed(), mypositions, pos, InMemoryPositionList::set_data(), and InMemoryDatabase::throw_database_closed().

◆ skip_to()

PostList * InMemoryPostList::skip_to ( Xapian::docid  did,
double  w_min 
)
virtual

Skip forward to the specified docid.

If the specified docid isn't in the list, position ourselves on the first document after it (or at_end() if no greater docids are present).

Parameters
w_minThe minimum weight contribution that is needed (this is just a hint which PostList subclasses may ignore).
Returns
If a non-NULL pointer is returned, then the caller should substitute the returned pointer for its pointer to us, and then delete us. This "pruning" can only happen for a non-leaf subclass of this class.

Implements Xapian::PostingIterator::Internal.

Definition at line 130 of file inmemory_database.cc.

References Assert, at_end(), db, InMemoryDatabase::is_closed(), Xapian::PostingIterator::Internal::next(), started, and InMemoryDatabase::throw_database_closed().

Friends And Related Function Documentation

◆ InMemoryDatabase

friend class InMemoryDatabase
friend

Definition at line 139 of file inmemory_database.h.

Member Data Documentation

◆ db

Xapian::Internal::intrusive_ptr<const InMemoryDatabase> InMemoryPostList::db
private

◆ end

vector<InMemoryPosting>::const_iterator InMemoryPostList::end
private

Definition at line 143 of file inmemory_database.h.

Referenced by at_end(), InMemoryPostList(), and next().

◆ mypositions

InMemoryPositionList InMemoryPostList::mypositions
private

List of positions of the current term.

This list is populated when read_position_list() is called.

Definition at line 150 of file inmemory_database.h.

Referenced by read_position_list().

◆ pos

vector<InMemoryPosting>::const_iterator InMemoryPostList::pos
private

◆ started

bool InMemoryPostList::started
private

Definition at line 145 of file inmemory_database.h.

Referenced by get_docid(), next(), and skip_to().

◆ termfreq

Xapian::doccount InMemoryPostList::termfreq
private

Definition at line 144 of file inmemory_database.h.

Referenced by get_description(), and get_termfreq().

◆ wdf_upper_bound

Xapian::termcount InMemoryPostList::wdf_upper_bound
private

Definition at line 154 of file inmemory_database.h.

Referenced by get_wdf_upper_bound(), and InMemoryPostList().


The documentation for this class was generated from the following files: