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
|
/* quartz_document.cc: Implementation of document for Quartz database
*
* ----START-LICENCE----
* Copyright 1999,2000,2001 BrightStation PLC
* Copyright 2002 Ananova Ltd
* Copyright 2003,2004 Olly Betts
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA
* -----END-LICENCE-----
*/
#include <config.h>
#include "omdebug.h"
#include "quartz_database.h"
#include "quartz_document.h"
#include "quartz_values.h"
#include "quartz_record.h"
/** Create a QuartzDocument: this is only called by
* QuartzDatabase::open_document().
*/
QuartzDocument::QuartzDocument(Xapian::Internal::RefCntPtr<const Xapian::Database::Internal> database_,
const QuartzValueTable *value_table_,
const QuartzRecordTable *record_table_,
Xapian::docid did_, bool lazy)
: Xapian::Document::Internal(database_.get(), did_),
database(database_),
value_table(value_table_),
record_table(record_table_)
{
DEBUGCALL(DB, void, "QuartzDocument", "[database_], " << value_table_ << ", " << record_table_ << ", " << did_ << ", " << lazy);
// FIXME: this should work but isn't great - in fact I wonder if
// we should cache the results anyway...
if (!lazy) (void)record_table->get_record(did);
}
/** Destroy a QuartzDocument.
*/
QuartzDocument::~QuartzDocument()
{
DEBUGCALL(DB, void, "~QuartzDocument", "");
}
/** Retrieve a value from the database
*
* @param valueid The value number to retrieve.
*/
string
QuartzDocument::do_get_value(Xapian::valueno valueid) const
{
DEBUGCALL(DB, string, "QuartzDocument::do_get_value", valueid);
string retval;
value_table->get_value(retval, did, valueid);
RETURN(retval);
}
/** Retrieve all value values from the database
*/
map<Xapian::valueno, string>
QuartzDocument::do_get_all_values() const
{
DEBUGCALL(DB, void, "QuartzDocument::do_get_all_values", "");
map<Xapian::valueno, string> value_map;
value_table->get_all_values(value_map, did);
return value_map;
}
/** Retrieve the document data from the database
*/
string
QuartzDocument::do_get_data() const
{
DEBUGCALL(DB, string, "QuartzDocument::do_get_data", "");
RETURN(record_table->get_record(did));
}
|