Switch to side-by-side view

--- a/src/query/docseqdb.h
+++ b/src/query/docseqdb.h
@@ -16,35 +16,35 @@
  */
 #ifndef _DOCSEQDB_H_INCLUDED_
 #define _DOCSEQDB_H_INCLUDED_
-/* @(#$Id: docseqdb.h,v 1.1 2007-01-19 10:32:39 dockes Exp $  (C) 2004 J.F.Dockes */
-#include <string>
-#include <list>
-#ifndef NO_NAMESPACES
-using std::string;
-using std::list;
-#endif
+/* @(#$Id: docseqdb.h,v 1.2 2007-01-19 15:22:50 dockes Exp $  (C) 2004 J.F.Dockes */
+#include "docseq.h"
+#include "refcntr.h"
 
-#include "docseq.h"
-namespace Rcl {
-class Db;
-}
+#include "searchdata.h"
 
 /** A DocSequence from a Db query (there should be one active for this
-    to make sense */
+    to make sense) */
 class DocSequenceDb : public DocSequence {
  public:
-    DocSequenceDb(Rcl::Db *d, const string &t) : 
-	DocSequence(t), m_db(d), m_rescnt(-1) 
+    DocSequenceDb(Rcl::Db *d, const string &t, RefCntr<Rcl::SearchData> sdata) 
+	: DocSequence(t), m_db(d), m_sdata(sdata), m_rescnt(-1) 
 	{}
     virtual ~DocSequenceDb() {}
     virtual bool getDoc(int num, Rcl::Doc &doc, int *percent, string * = 0);
     virtual int getResCnt();
-    virtual void getTerms(list<string>&);
+    virtual bool getTerms(vector<string>& terms, 
+			  vector<vector<string> >& groups, 
+			  vector<int>& gslks) const {
+	return m_sdata.getptr()->getTerms(terms, groups, gslks);
+    }
+
     virtual string getAbstract(Rcl::Doc &doc);
+    virtual string getDescription() {return m_sdata->getDescription();}
 
  private:
-    Rcl::Db *m_db;
-    int      m_rescnt;
+    Rcl::Db                 *m_db;
+    RefCntr<Rcl::SearchData> m_sdata;
+    int                      m_rescnt;
 };
 
 #endif /* _DOCSEQDB_H_INCLUDED_ */