diff options
Diffstat (limited to 'debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc')
-rw-r--r-- | debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc b/debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc new file mode 100644 index 00000000..9e40f230 --- /dev/null +++ b/debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc @@ -0,0 +1,105 @@ +// +// Collection.cc +// +// Collection: Specifies a list of databases to use in the search +// +// Part of the ht://Dig package <http://www.htdig.org/> +// 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: Collection.cc,v 1.7 2004/05/28 13:15:24 lha Exp $ +// + +#ifdef HAVE_CONFIG_H +#include "htconfig.h" +#endif /* HAVE_CONFIG_H */ + +#include "htsearch.h" +#include "Collection.h" +#include "ResultMatch.h" +#include "WeightWord.h" +#include "StringMatch.h" +#include "QuotedStringList.h" +#include "URL.h" +#include "HtURLCodec.h" + +#ifdef HAVE_STD +#include <fstream> +#ifdef HAVE_NAMESPACES +using namespace std; +#endif +#else +#include <fstream.h> +#endif /* HAVE_STD */ + +#include <stdio.h> +#include <ctype.h> + +#ifndef _MSC_VER /* _WIN32 */ +#include <syslog.h> +#endif + +#include <locale.h> + +//***************************************************************************** +// +Collection::Collection(const char *name, const char *word_file, + const char *index_file, const char *doc_file, + const char *doc_excerpt) +{ + collectionName = name; + wordFile = word_file; + indexFile = index_file; + docFile = doc_file; + docExcerpt = doc_excerpt; + matches = NULL; + searchWords = NULL; + searchWordsPattern = NULL; + isopen = 0; +} + +Collection::~Collection() +{ + if(matches) delete matches; + if(searchWords) delete searchWords; + if(searchWordsPattern) delete searchWordsPattern; + Close(); +} + +void +Collection::Open() +{ + if (!isopen) + { + docDB.Read(docFile, indexFile, docExcerpt); + } + isopen = 1; +} + +void +Collection::Close() +{ + if (isopen) + { + docDB.Close(); + } + isopen = 0; +} + +DocumentRef * +Collection::getDocumentRef(int id) +{ + Open(); + return docDB[id]; +} + +int +Collection::ReadExcerpt(DocumentRef &ref) +{ + Open(); + return docDB.ReadExcerpt(ref); +} + + |