22 #ifndef XAPIAN_INCLUDED_REMOTE_DATABASE_H
23 #define XAPIAN_INCLUDED_REMOTE_DATABASE_H
108 const std::string & body = std::string())
const;
141 (void)
get_message(message, required_type, required_type);
166 std::string_view
term)
const;
200 bool sort_value_forward,
202 int percent_threshold,
double weight_threshold,
205 const std::vector<opt_ptr_spy>& matchspies)
const;
253 std::string_view tname)
const;
304 void set_metadata(std::string_view key, std::string_view value);
314 void add_synonym(std::string_view word, std::string_view synonym)
const;
317 std::string_view synonym)
const;
333 std::string_view prefix,
static Xapian::Query query(Xapian::Query::op op, const string &t1=string(), const string &t2=string(), const string &t3=string(), const string &t4=string(), const string &t5=string(), const string &t6=string(), const string &t7=string(), const string &t8=string(), const string &t9=string(), const string &t10=string())
Abstract base class for leaf postlists.
A postlist in a remote database.
RemoteConnection which owns its own fd(s).
const std::string & get_context() const
Return the context to report with errors.
int get_read_fd() const
Return the underlying fd this remote connection reads from.
RemoteDatabase is the baseclass for remote database implementations.
bool get_message_or_done(std::string &message, reply_type required_type) const
Xapian::doccount doccount
The remote document count, given at open.
void set_metadata(std::string_view key, std::string_view value)
Set the metadata associated with a given key.
bool locked() const
Return true if the database is open for writing.
LeafPostList * open_leaf_post_list(std::string_view term, bool) const
Create a LeafPostList for use during a match.
void set_query(const Xapian::Query &query, Xapian::termcount qlen, Xapian::valueno collapse_key, Xapian::doccount collapse_max, Xapian::Enquire::docid_order order, Xapian::valueno sort_key, Xapian::Enquire::Internal::sort_setting sort_by, bool sort_value_forward, double time_limit, int percent_threshold, double weight_threshold, const Xapian::Weight &wtscheme, const Xapian::RSet &omrset, const std::vector< opt_ptr_spy > &matchspies) const
Set the query.
TermList * open_synonym_keylist(std::string_view prefix) const
Open a termlist returning each term which has synonyms.
RemoteDatabase(const RemoteDatabase &)
Don't allow copying.
bool update_stats(message_type msg_code=MSG_UPDATE, const std::string &body=std::string()) const
void operator=(const RemoteDatabase &)
Don't allow assignment.
TermList * open_allterms(std::string_view prefix) const
Iterate all terms.
Xapian::termcount get_unique_terms(Xapian::docid did) const
Get the number of unique terms in document.
bool has_positional_info
Has positional information?
void clear_synonyms(std::string_view word) const
Clear all synonyms for a term.
std::string uuid
The UUID of the remote database.
void do_close()
Close the socket.
void send_global_stats(Xapian::doccount first, Xapian::doccount maxitems, Xapian::doccount check_at_least, const Xapian::KeyMaker *sorter, const Xapian::Weight::Internal &stats) const
Send the global stats to the remote server.
void cancel()
Cancel pending modifications to the database.
void get_message(std::string &message, reply_type required_type) const
std::string get_value_upper_bound(Xapian::valueno slot) const
Get an upper bound on the values stored in the given value slot.
TermList * open_synonym_termlist(std::string_view term) const
Open a termlist returning synonyms for a term.
TermList * open_term_list(Xapian::docid did) const
Get remote termlist.
Xapian::termcount doclen_lbound
A lower bound on the smallest document length in this database.
Xapian::termcount get_doclength(Xapian::docid did) const
TermList * open_metadata_keylist(std::string_view prefix) const
Get remote metadata key list.
PositionList * open_position_list(Xapian::docid did, std::string_view tname) const
void delete_document(Xapian::docid did)
bool pending_reply
Are we currently expecting a reply?
std::string get_metadata(std::string_view key) const
Get the metadata associated with a given key.
void request_document(Xapian::docid did) const
Request a document.
bool has_positions() const
Check whether this database contains any positional information.
Xapian::Document::Internal * open_document(Xapian::docid did, bool lazy) const
Get a remote document.
bool uncommitted_changes
True if there are (or may be) uncommitted changes.
Xapian::valueno mru_slot
The value slot for the most recently used value statistics.
Xapian::termcount get_doclength_upper_bound() const
Get an upper bound on the length of a document in this DB.
Xapian::doccount read_post_list(const std::string &term, NetworkPostList &pl) const
bool term_exists(std::string_view term) const
Check if term exists.
Xapian::termcount get_wdf_upper_bound(std::string_view term) const
Get an upper bound on the wdf of term term.
bool reopen()
Reopen the database to the latest available revision.
Xapian::Internal::opt_intrusive_ptr< Xapian::MatchSpy > opt_ptr_spy
void remove_synonym(std::string_view word, std::string_view synonym) const
Remove a synonym for a term.
bool get_posting(Xapian::docid &did, double &w, std::string &value)
int get_backend_info(std::string *path) const
Get backend information about this database.
void add_synonym(std::string_view word, std::string_view synonym) const
Add a synonym for a term.
RemoteDatabase(std::pair< int, std::string > fd_and_context, double timeout_, bool writable, int flags)
Constructor.
double timeout
The timeout value used in network communications, in seconds.
OwnedRemoteConnection link
The object which does the I/O.
TermList * open_term_list_direct(Xapian::docid did) const
Like open_term_list() but without MultiTermList wrapper.
void keep_alive()
Send a keep-alive message.
Xapian::doccount get_value_freq(Xapian::valueno slot) const
Return the frequency of a given value slot.
ValueStats mru_valstats
The most recently used value statistics.
void get_freqs(std::string_view term, Xapian::doccount *termfreq_ptr, Xapian::termcount *collfreq_ptr) const
Returns frequencies for a term.
void add_spelling(std::string_view word, Xapian::termcount freqinc) const
Add a word to the spelling dictionary.
int get_read_fd() const
Get the underlying fd this remote connection reads from.
Xapian::totallength get_total_length() const
Return the total length of all documents in this database.
Xapian::docid add_document(const Xapian::Document &doc)
reply_type get_message(std::string &message, reply_type required_type, reply_type required_type2) const
Receive a message from the server.
void read_value_stats(Xapian::valueno slot) const
Read the value statistics for a value from a remote database.
std::string get_uuid() const
Get a UUID for the database.
Xapian::docid get_lastdocid() const
Get the last used docid.
std::string reconstruct_text(Xapian::docid did, size_t length, std::string_view prefix, Xapian::termpos start_pos, Xapian::termpos end_pos) const
void commit()
Commit pending modifications to the database.
void replace_document(Xapian::docid did, const Xapian::Document &doc)
std::string get_description() const
Return a string describing this object.
Xapian::termcount remove_spelling(std::string_view word, Xapian::termcount freqdec) const
Remove a word from the spelling dictionary.
PostList * open_post_list(std::string_view term) const
Return a PostList suitable for use in a PostingIterator.
Xapian::termcount get_doclength_lower_bound() const
Get a lower bound on the length of a document in this DB.
Xapian::MSet get_mset(const std::vector< opt_ptr_spy > &matchspies) const
Get the MSet from the remote server.
void send_message(message_type type, std::string_view data) const
Send a message to the server.
Xapian::totallength total_length
The total length of all documents in this database.
std::string get_value_lower_bound(Xapian::valueno slot) const
Get a lower bound on the values stored in the given value slot.
Xapian::termcount get_wdfdocmax(Xapian::docid did) const
Get the max wdf in document.
Xapian::doccount get_doccount() const
Get the document count.
Xapian::docid lastdocid
The remote last docid, given at open.
Xapian::termcount positionlist_count(Xapian::docid did, std::string_view term) const
Get the length of the position list.
void close()
Close the database.
Xapian::termcount doclen_ubound
An upper bound on the greatest document length in this database.
void accumulate_remote_stats(Xapian::Weight::Internal &total) const
Accumulate stats from the remote server.
Virtual base class for Database internals.
Abstract base class for a document.
Class representing a document.
docid_order
Ordering of docids.
Abstract base class for postlists.
Virtual base class for key making functors.
Class representing a list of search results.
Abstract base class for iterating term positions in a document.
Class representing a query.
Class representing a set of documents judged as relevant.
Abstract base class for termlists.
Class to hold statistics for a given collection.
Abstract base class for weighting schemes.
Virtual base class for Database internals.
Xapian::Enquire internals.
The Xapian namespace contains public interfaces for the Xapian library.
unsigned XAPIAN_TERMCOUNT_BASE_TYPE termcount
A counts of terms.
unsigned valueno
The number for a value slot in a document.
unsigned XAPIAN_DOCID_BASE_TYPE doccount
A count of documents.
unsigned XAPIAN_DOCID_BASE_TYPE docid
A unique identifier for a document.
unsigned XAPIAN_TERMPOS_BASE_TYPE termpos
A term position within a document or query.
XAPIAN_TOTALLENGTH_TYPE totallength
The total length of all documents in a database.
RemoteConnection class used by the remote backend.
message_type
Message types (client -> server).
reply_type
Reply types (server -> client).
Class to hold statistics for a given slot.