You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
238 lines
5.6 KiB
238 lines
5.6 KiB
/*
|
|
|
|
DBSE 3
|
|
(c) 2000-2003 Andrea Rizzi
|
|
License: GPLv2
|
|
|
|
*/
|
|
#ifndef DATABASE_2_H
|
|
#define DATABASE_2_H
|
|
|
|
#include <tqstring.h>
|
|
#include <tqvaluelist.h>
|
|
#include <db4/db_cxx.h>
|
|
#include <tqobject.h>
|
|
#include <tqregexp.h>
|
|
|
|
#include "dbentries.h"
|
|
|
|
|
|
class DBSESettings
|
|
{
|
|
public:
|
|
//DatabaseInterface Settings
|
|
uint scoreWordByWord;
|
|
uint scoreGlossary;
|
|
uint scoreDivide;
|
|
uint scoreExact;
|
|
uint scoreSentence;
|
|
uint scoreAlpha;
|
|
uint scoreDynamic;
|
|
uint scoreChunkByChunk;
|
|
uint minScore;
|
|
bool firstCapital;
|
|
bool allCapital;
|
|
bool accelerator;
|
|
bool sameLetter;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
class DataBase : Db
|
|
{
|
|
public:
|
|
DataBase(TQString dbpath, TQString dbname, TQString dblang);
|
|
|
|
int open(DBTYPE type,unsigned int flags=0);
|
|
|
|
//Standard access (overload std functions)
|
|
|
|
|
|
|
|
int del(DBItem * key){
|
|
key->set();
|
|
int r = Db::del(0,key,0);
|
|
key->get();
|
|
return r;
|
|
}
|
|
|
|
|
|
|
|
int get(DBItem * key,DBItem *data){
|
|
key->set();
|
|
data->set();
|
|
int r = Db::get(0,key,data,0);
|
|
key->get();
|
|
data->get();
|
|
return r;
|
|
}
|
|
int put(DBItem * key,DBItem *data,int fl=0){
|
|
key->set();
|
|
data->set();
|
|
int r= Db::put(0,key,data,0);
|
|
key->get();
|
|
data->get();
|
|
return r;
|
|
}
|
|
|
|
int del(DBItemNum * key){
|
|
int r = Db::del(0,key,0);
|
|
return r;
|
|
}
|
|
|
|
int get(DBItemNum * key,DBItem *data){
|
|
data->set();
|
|
int r = Db::get(0,key,data,0);
|
|
data->get();
|
|
return r;
|
|
}
|
|
int put(DBItemNum * key,DBItem *data)
|
|
{
|
|
data->set();
|
|
int r= Db::put(0,key,data,0);
|
|
data->get();
|
|
return r;
|
|
}
|
|
|
|
//Overload, using this you loose the Key!!
|
|
int del(int i){DBItemNum n(i); return del(&n);}
|
|
int get(int i,DBItem *data){DBItemNum n(i); return get(&n,data);}
|
|
int put(int i,DBItem *data){DBItemNum n(i); return put(&n,data);}
|
|
|
|
unsigned int getLast();
|
|
int close(unsigned int i) {return Db::close( i); }
|
|
|
|
//For scrolling
|
|
// int getFirst(DBItem *key,DBItem *data,TQString table);
|
|
// int getNext(DBItem *key,DBItem *data,TQString table);
|
|
// bool isEnd(TQString table);
|
|
private:
|
|
TQString filename;
|
|
TQString database;
|
|
DBTYPE mytype;
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class QueryResult //from DBInterface to KDBSearchEngine
|
|
{
|
|
public:
|
|
QueryResult();
|
|
QueryResult(TQString r);
|
|
QueryResult(TQString r,TQString o,int s);
|
|
void setRichResult(TQString r) { richr=r; }
|
|
void setRichOriginal(TQString r) { richo=r; }
|
|
|
|
TQString richResult() {return richr;}
|
|
TQString richOriginal() {return richo;}
|
|
|
|
TQString result(){ return res; }
|
|
TQString original() {return orig; }
|
|
int score() {return sco;}
|
|
//info contains originalkey,catalog,date,author etc...
|
|
ResultInfo info(){ResultInfo i; i.info="no info"; return i;}
|
|
|
|
|
|
private:
|
|
TQString res;
|
|
TQString orig;
|
|
TQString richr;
|
|
TQString richo;
|
|
int sco;
|
|
|
|
};
|
|
|
|
class SearchFilter
|
|
{
|
|
int filter; //placeholder
|
|
};
|
|
|
|
|
|
|
|
class DataBaseInterface : public TQObject
|
|
{
|
|
|
|
public:
|
|
//move result list typedef to AbstractAlgorthm or somewhere else
|
|
typedef TQValueList<QueryResult> ResultList;
|
|
typedef TQPair<DBItemMainKey,DBItemMainData> MainEntry;
|
|
|
|
DataBaseInterface( TQString dir, DBSESettings *sets);
|
|
~DataBaseInterface();
|
|
|
|
//Ask the Database to stop now.
|
|
void stop(bool b=true) {_stopNow=b;}
|
|
|
|
//Search words
|
|
ResultList wordsMatch(TQString query,SearchFilter *filter=0,bool notify=true);
|
|
|
|
//Edit database functions.
|
|
//addEntry and sync all the tables
|
|
bool addEntry(TQString original,TQString translated,InputInfo *info);
|
|
//FIXME:implement me!
|
|
bool removeEntry(TQString original);
|
|
|
|
//FIXME: go persistent!
|
|
TQMap<TQString,float> correlation(TQString word,SearchFilter *filter=0,bool notify=true,float minSign=0.2);
|
|
|
|
|
|
// Read the database
|
|
MainEntry get(const TQString& query,SearchFilter *filter=0);
|
|
MainEntry getFromIndex(uint i);
|
|
DBItemMultiIndex::IndexList getAlpha(const TQString& query);
|
|
DBItemMultiIndex::IndexList getWordIndex(const TQString& query);
|
|
MainEntry getSentence(const TQString& query);
|
|
|
|
//Database status check functions
|
|
bool mainOk() {return main!=0;}
|
|
bool catalogOk() {return catalog!=0;}
|
|
bool alphaOk() {return alpha!=0;}
|
|
bool sentenceOk() {return sentence!=0;}
|
|
bool numindexOk() {return numindex!=0;}
|
|
bool wordsindexOk() {return wordsindex!=0;}
|
|
bool externalOk() {return external!=0;}
|
|
bool wordOk() {return word!=0;}
|
|
bool transwordOk() {return transword!=0;}
|
|
bool correlationOk() {return corr!=0;}
|
|
bool stopNow() {return _stopNow;}
|
|
|
|
// signals:
|
|
// void newResult(QueryResult);
|
|
|
|
DBSESettings *getSettings() {return settings;}
|
|
|
|
private:
|
|
DataBase * openMyDataBase(const TQString& prefix,const TQString& name,const TQString& l,DBTYPE tt);
|
|
DataBase *main;
|
|
DataBase *numindex;
|
|
DataBase *wordsindex;
|
|
DataBase *catalog;
|
|
DataBase *alpha;
|
|
DataBase *sentence;
|
|
DataBase *word;
|
|
DataBase *external;
|
|
DataBase *transword;
|
|
DataBase *corr;
|
|
bool _stopNow;
|
|
DBSESettings *settings;
|
|
|
|
//FIXME:Move to KBabel common library.
|
|
public:
|
|
TQString format( TQString _s,TQString t);
|
|
TQString formatRegExp(TQString _s, TQString t, TQString tre,TQString stringSearch,TQString stringReplace);
|
|
static TQStringList words(TQString s);
|
|
static TQStringList sentences(TQString s);
|
|
static TQStringList sentencesSeparator(TQString s);
|
|
static TQString simple(TQString str,bool ck=false);
|
|
static bool isUpper(TQChar s);
|
|
static bool isLower(TQChar s);
|
|
|
|
};
|
|
|
|
#endif
|
|
|