summaryrefslogtreecommitdiffstats
path: root/debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc
diff options
context:
space:
mode:
Diffstat (limited to 'debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc')
-rw-r--r--debian/htdig/htdig-3.2.0b6/htsearch/Collection.cc105
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);
+}
+
+