Add blacklist function;

Using a queue to return file search results.
This commit is contained in:
zhangpengfei 2021-01-08 19:08:24 +08:00
parent 61c64186b6
commit f77e1c180b
6 changed files with 230 additions and 99 deletions

View File

@ -16,6 +16,7 @@ GlobalSettings *GlobalSettings::getInstance()
GlobalSettings::GlobalSettings(QObject *parent) : QObject(parent) GlobalSettings::GlobalSettings(QObject *parent) : QObject(parent)
{ {
m_settings = new QSettings("org.ukui", "ukui-search", this); m_settings = new QSettings("org.ukui", "ukui-search", this);
m_block_dirs_settings = new QSettings("org.ukui","ukui-search-block-dirs",this);
//the default number of transparency in mainwindow is 0.7 //the default number of transparency in mainwindow is 0.7
//if someone changes the num in mainwindow, here should be modified too //if someone changes the num in mainwindow, here should be modified too
m_cache.insert(TRANSPARENCY_KEY, 0.7); m_cache.insert(TRANSPARENCY_KEY, 0.7);
@ -77,9 +78,27 @@ void GlobalSettings::resetAll()
}); });
} }
QList<QString> GlobalSettings::getBlockDirs() bool GlobalSettings::setBlockDirs(const QString &path, QString &returnMessage)
{ {
return m_cache.keys(); QStringList blockDirs = m_block_dirs_settings->allKeys();
for(QString i:blockDirs)
{
if(path.startsWith(i))
{
returnMessage = QString(tr("Parent folder has been blocked!"));
return false;
}
if(i.startsWith(path))
m_block_dirs_settings->remove(i);
}
m_block_dirs_settings->setValue(path,"0");
return true;
}
QStringList GlobalSettings::getBlockDirs()
{
return m_block_dirs_settings->allKeys();
} }
void GlobalSettings::setValue(const QString &key, const QVariant &value) void GlobalSettings::setValue(const QString &key, const QVariant &value)

View File

@ -34,7 +34,15 @@ public Q_SLOTS:
void setValue(const QString&, const QVariant&); void setValue(const QString&, const QVariant&);
void reset(const QString&); void reset(const QString&);
void resetAll(); void resetAll();
QList<QString> getBlockDirs(); /**
* @brief setBlockDirs
* set path for blacklist,return true if success,otherwise return false.
* @param path path to be blocked
* @param returnMessage this message will be set when return false.
* @return
*/
bool setBlockDirs(const QString& path, QString &returnMessage);
QStringList getBlockDirs();
void forceSync(const QString& = nullptr); void forceSync(const QString& = nullptr);
@ -44,6 +52,7 @@ private:
QSettings* m_settings; QSettings* m_settings;
QGSettings* m_gsettings; QGSettings* m_gsettings;
QSettings *m_block_dirs_settings;
QMap<QString, QVariant> m_cache; QMap<QString, QVariant> m_cache;
QMutex m_mutex; QMutex m_mutex;

View File

@ -1,82 +1,103 @@
#include "file-searcher.h"
#include <QFileInfo> #include <QFileInfo>
#include <QDebug> #include <QDebug>
#include <QtConcurrent>
#include <chinese-segmentation.h> #include <chinese-segmentation.h>
#include "file-searcher.h"
#include "global-settings.h"
FileSearcher::FileSearcher(QObject *parent) : QObject(parent) FileSearcher::FileSearcher(QObject *parent) : QObject(parent)
{ {
} }
void FileSearcher::onKeywordSearch(QString keyword, int begin, int num) void FileSearcher::onKeywordSearch(QString keyword)
{
//file
QtConcurrent::run([=](){
int begin = 0;
int num = 20;
int resultCount = 0;
while(1)
{
resultCount = keywordSearchfile(keyword,"1",1,begin,num);
if(resultCount == 0 || resultCount == -1)
break;
begin += num;
}
});
Q_EMIT this->resultFile(m_search_result_file);
//dir
QtConcurrent::run([=](){
int begin = 0;
int num = 20;
int resultCount = 0;
while(1)
{
resultCount = keywordSearchfile(keyword,"0",1,begin,num);
if(resultCount == 0 || resultCount == -1)
break;
begin += num;
}
});
Q_EMIT this->resultDir(m_search_result_dir);
//content
QtConcurrent::run([=](){
int begin = 0;
int num = 10;
int resultCount = 0;
while(1)
{
keywordSearchContent(keyword,begin,num);
if(resultCount == 0 || resultCount == -1)
break;
begin += num;
}
});
Q_EMIT this->resultContent(m_search_result_content);
}
int FileSearcher::keywordSearchfile(QString keyword, QString value, unsigned slot, int begin, int num)
{ {
QVector<QStringList> searchResult;
try try
{ {
qDebug()<<"--search start--"; qDebug()<<"--search start--";
Xapian::Database db(INDEX_PATH); Xapian::Database db(INDEX_PATH);
Xapian::Query query = creatQueryForFileSearch(keyword,db);
Xapian::Enquire enquire(db); Xapian::Enquire enquire(db);
Xapian::QueryParser qp;
qp.set_default_op(Xapian::Query::OP_PHRASE);
qp.set_database(db);
auto userInput = keyword;
std::string queryStr = keyword.replace(""," ").toStdString(); Xapian::Query queryFile;
// std::string s =db.get_spelling_suggestion(queryStr,10); if(!value.isEmpty())
// qDebug()<<"spelling_suggestion!"<<QString::fromStdString(s);
qDebug()<<"queryStr!"<<QString::fromStdString(queryStr);
//Creat a query
Xapian::Query queryPhrase = qp.parse_query(queryStr,Xapian::QueryParser::FLAG_PHRASE);
std::vector<Xapian::Query> v;
for(int i=0;i<userInput.size();i++)
{ {
v.push_back(Xapian::Query(QString(userInput.at(i)).toStdString())); std::string slotValue = value.toStdString();
qDebug()<<userInput.at(i); Xapian::Query queryValue = Xapian::Query(Xapian::Query::OP_VALUE_RANGE,slot,slotValue,slotValue);
qDebug()<<QString::fromStdString(Xapian::Query(QString(userInput.at(i)).toStdString()).get_description()); queryFile = Xapian::Query(Xapian::Query::OP_AND,query,queryValue);
}
else
{
queryFile = query;
} }
Xapian::Query queryNear =Xapian::Query(Xapian::Query::OP_NEAR, v.begin(), v.end());
Xapian::Query query = Xapian::Query(Xapian::Query::OP_AND,queryNear,queryPhrase);
//1- dir 2-file qDebug()<<QString::fromStdString(queryFile.get_description());
unsigned slot = 1;
std::string value = "1";
Xapian::Query queryValue1 = Xapian::Query(Xapian::Query::OP_VALUE_GE,slot,value);
value = "0";
Xapian::Query queryValue0 = Xapian::Query(Xapian::Query::OP_VALUE_LE,1,value);
Xapian::Query queryDir = Xapian::Query(Xapian::Query::OP_AND,query,queryValue1);
Xapian::Query queryFile = Xapian::Query(Xapian::Query::OP_AND,query,queryValue0);
qDebug()<<QString::fromStdString(query.get_description());
enquire.set_query(queryDir);
//dir result
Xapian::MSet result = enquire.get_mset(begin, begin+num);
qDebug()<< "find dir results count=" <<static_cast<int>(result.get_matches_estimated());
searchResult.append(getResult(result));
enquire.set_query(queryFile); enquire.set_query(queryFile);
//file result Xapian::MSet result = enquire.get_mset(begin, begin+num);
result = enquire.get_mset(begin, begin+num); int resultCount = static_cast<int>(result.get_matches_estimated());
qDebug()<< "find file results count=" <<static_cast<int>(result.get_matches_estimated()); qDebug()<< "find results count=" <<resultCount;
searchResult.append(getResult(result)); getResult(result,value);
qDebug()<< "--search finish--"; qDebug()<< "--search finish--";
return resultCount;
} }
catch(const Xapian::Error &e) catch(const Xapian::Error &e)
{ {
qWarning() <<QString::fromStdString(e.get_description()); qWarning() <<QString::fromStdString(e.get_description());
return; qDebug()<< "--search finish--";
return -1;
} }
Q_EMIT this->result(searchResult);
return;
} }
void FileSearcher::onKeywordSearchContent(QString keyword, int begin, int num) int FileSearcher::keywordSearchContent(QString keyword, int begin, int num)
{ {
QMap<QString,QStringList> searchResult = QMap<QString,QStringList>();
try try
{ {
qDebug()<<"--content search start--"; qDebug()<<"--content search start--";
@ -108,24 +129,52 @@ void FileSearcher::onKeywordSearchContent(QString keyword, int begin, int num)
enquire.set_query(query); enquire.set_query(query);
//dir result //dir result
Xapian::MSet result = enquire.get_mset(begin, begin+num); Xapian::MSet result = enquire.get_mset(begin, begin+num);
qDebug()<< "find results count=" <<static_cast<int>(result.get_matches_estimated()); int resultCount = static_cast<int>(result.get_matches_estimated());
qDebug()<< "find results count=" <<resultCount;
searchResult = getContentResult(result,words); getContentResult(result,words);
qDebug()<< "--content search finish--"; qDebug()<< "--content search finish--";
return resultCount;
} }
catch(const Xapian::Error &e) catch(const Xapian::Error &e)
{ {
qWarning() <<QString::fromStdString(e.get_description()); qWarning() <<QString::fromStdString(e.get_description());
qDebug()<< "--content search finish--"; qDebug()<< "--content search finish--";
return; return -1;
} }
Q_EMIT this->contentResult(searchResult); }
// qDebug()<<searchResult; Xapian::Query FileSearcher::creatQueryForFileSearch(QString keyword, Xapian::Database &db)
return; {
Xapian::QueryParser qp;
qp.set_default_op(Xapian::Query::OP_PHRASE);
qp.set_database(db);
auto userInput = keyword;
std::string queryStr = keyword.replace(""," ").toStdString();
// std::string s =db.get_spelling_suggestion(queryStr,10);
// qDebug()<<"spelling_suggestion!"<<QString::fromStdString(s);
qDebug()<<"queryStr!"<<QString::fromStdString(queryStr);
//Creat a query
Xapian::Query queryPhrase = qp.parse_query(queryStr,Xapian::QueryParser::FLAG_PHRASE);
std::vector<Xapian::Query> v;
for(int i=0;i<userInput.size();i++)
{
v.push_back(Xapian::Query(QString(userInput.at(i)).toStdString()));
qDebug()<<QString::fromStdString(Xapian::Query(QString(userInput.at(i)).toStdString()).get_description());
}
Xapian::Query queryNear =Xapian::Query(Xapian::Query::OP_NEAR, v.begin(), v.end());
return Xapian::Query(Xapian::Query::OP_AND,queryNear,queryPhrase);
} }
QStringList FileSearcher::getResult(Xapian::MSet &result) Xapian::Query FileSearcher::creatQueryForContentSearch(QString keyword, Xapian::Database &db)
{
}
QStringList FileSearcher::getResult(Xapian::MSet &result, QString value)
{ {
//QStringList *pathTobeDelete = new QStringList; //QStringList *pathTobeDelete = new QStringList;
//Delete those path doc which is not already exist. //Delete those path doc which is not already exist.
@ -140,18 +189,34 @@ QStringList FileSearcher::getResult(Xapian::MSet &result)
std::string data = doc.get_data(); std::string data = doc.get_data();
Xapian::weight docScoreWeight = it.get_weight(); Xapian::weight docScoreWeight = it.get_weight();
Xapian::percent docScorePercent = it.get_percent(); Xapian::percent docScorePercent = it.get_percent();
QFileInfo *info = new QFileInfo(QString::fromStdString(data)); QString path = QString::fromStdString(data);
if(isBlocked(path))
continue;
QFileInfo *info = new QFileInfo(path);
if(!info->exists()) if(!info->exists())
{ {
// pathTobeDelete->append(QString::fromStdString(data)); // pathTobeDelete->append(QString::fromStdString(data));
qDebug()<<QString::fromStdString(data)<<"is not exist!!"; qDebug()<<path<<"is not exist!!";
} }
else else
{ {
searchResult.append(QString::fromStdString(data)); switch (value.toInt())
{
case 1:
m_search_result_dir->enqueue(path);
break;
case 0:
m_search_result_file->enqueue(path);
break;
default:
break;
} }
qDebug()<< "doc="<< QString::fromStdString(data) << ",weight=" <<docScoreWeight << ",percent=" << docScorePercent; searchResult.append(path);
}
qDebug()<< "doc="<< path << ",weight=" <<docScoreWeight << ",percent=" << docScorePercent;
} }
// if(!pathTobeDelete->isEmpty()) // if(!pathTobeDelete->isEmpty())
// deleteAllIndex(pathTobeDelete) // deleteAllIndex(pathTobeDelete)
@ -179,6 +244,10 @@ QMap<QString,QStringList> FileSearcher::getContentResult(Xapian::MSet &result, s
double docScoreWeight = it.get_weight(); double docScoreWeight = it.get_weight();
Xapian::percent docScorePercent = it.get_percent(); Xapian::percent docScorePercent = it.get_percent();
QString path = QString::fromStdString(doc.get_value(1)); QString path = QString::fromStdString(doc.get_value(1));
if(isBlocked(path))
continue;
QFileInfo *info = new QFileInfo(path); QFileInfo *info = new QFileInfo(path);
if(!info->exists()) if(!info->exists())
@ -200,6 +269,7 @@ QMap<QString,QStringList> FileSearcher::getContentResult(Xapian::MSet &result, s
snippets.append(snippet); snippets.append(snippet);
++count; ++count;
} }
m_search_result_content->enqueue(qMakePair(path,snippets));
searchResult.insert(path,snippets); searchResult.insert(path,snippets);
qDebug()<< "path="<< path << ",weight=" <<docScoreWeight << ",percent=" << docScorePercent; qDebug()<< "path="<< path << ",weight=" <<docScoreWeight << ",percent=" << docScorePercent;
} }
@ -207,3 +277,15 @@ QMap<QString,QStringList> FileSearcher::getContentResult(Xapian::MSet &result, s
// deleteAllIndex(pathTobeDelete) // deleteAllIndex(pathTobeDelete)
return searchResult; return searchResult;
} }
bool FileSearcher::isBlocked(QString &path)
{
QStringList blockList = GlobalSettings::getInstance()->getBlockDirs();
for(QString i :blockList)
{
if(path.startsWith(i))
return true;
}
return false;
}

View File

@ -6,6 +6,8 @@
#include <QStandardPaths> #include <QStandardPaths>
#include <QVector> #include <QVector>
#include <QMap> #include <QMap>
#include <QQueue>
#include <QPair>
#define INDEX_PATH (QStandardPaths::writableLocation(QStandardPaths::HomeLocation)+"/.config/org.ukui/index_data").toStdString() #define INDEX_PATH (QStandardPaths::writableLocation(QStandardPaths::HomeLocation)+"/.config/org.ukui/index_data").toStdString()
#define CONTENT_INDEX_PATH (QStandardPaths::writableLocation(QStandardPaths::HomeLocation)+"/.config/org.ukui/content_index_data").toStdString() #define CONTENT_INDEX_PATH (QStandardPaths::writableLocation(QStandardPaths::HomeLocation)+"/.config/org.ukui/content_index_data").toStdString()
@ -17,15 +19,34 @@ public:
explicit FileSearcher(QObject *parent = nullptr); explicit FileSearcher(QObject *parent = nullptr);
public Q_SLOTS: public Q_SLOTS:
void onKeywordSearch(QString keyword, int begin = 0, int num = 20); void onKeywordSearch(QString keyword);
void onKeywordSearchContent(QString keyword, int begin = 0, int num = 20);
Q_SIGNALS: Q_SIGNALS:
void result(QVector<QStringList> resultP); void resultFile(QQueue<QString> *);
void contentResult(QMap<QString,QStringList> resultC); void resultDir(QQueue<QString> *);
void resultContent(QQueue<QPair<QString,QStringList>> *);
private: private:
QStringList getResult(Xapian::MSet &result); int keywordSearchfile(QString keyword, QString value,unsigned slot = 1,int begin = 0, int num = 20);
int keywordSearchContent(QString keyword, int begin = 0, int num = 20);
/**
* @brief FileSearcher::creatQueryForFileSearch
* This part shall be optimized frequently to provide a more stable search function.
* @param keyword
* @param db
* @return Xapian::Query
*/
Xapian::Query creatQueryForFileSearch(QString keyword, Xapian::Database &db);
Xapian::Query creatQueryForContentSearch(QString keyword, Xapian::Database &db);
QStringList getResult(Xapian::MSet &result, QString value);
QMap<QString,QStringList> getContentResult(Xapian::MSet &result,std::string &keyWord); QMap<QString,QStringList> getContentResult(Xapian::MSet &result,std::string &keyWord);
bool isBlocked(QString &path);
QQueue<QString> *m_search_result_file;
QQueue<QString> *m_search_result_dir;
QQueue<QPair<QString,QStringList>> *m_search_result_content;
}; };
#endif // FILESEARCHER_H #endif // FILESEARCHER_H

View File

@ -79,7 +79,7 @@ bool IndexGenerator::creatAllIndex(QList<QString> *messageList)
{ {
insertIntoContentDatabase(m_doc_list_content->at(i)); insertIntoContentDatabase(m_doc_list_content->at(i));
if(++count == 9999) if(++count == 1000)
{ {
count = 0; count = 0;
m_database_content->commit(); m_database_content->commit();

View File

@ -255,25 +255,25 @@ void MainWindow::searchContent(QString searchcontent){
//内容搜索测试用数据,每个文件(路径)对应一段文本内容 //内容搜索测试用数据,每个文件(路径)对应一段文本内容
FileSearcher *search = new FileSearcher(); FileSearcher *search = new FileSearcher();
//iaom--------this part shall be rewrite
connect(search, &FileSearcher::contentResult, this, [ = ](QMap<QString,QStringList> map) { // connect(search, &FileSearcher::contentResult, this, [ = ](QMap<QString,QStringList> map) {
m_types.append(SearchItem::SearchType::Contents); // m_types.append(SearchItem::SearchType::Contents);
QStringList pathlist, contentList; // QStringList pathlist, contentList;
qDebug() << map; // qDebug() << map;
for (auto i : map.keys()){ // for (auto i : map.keys()){
QString temp; // QString temp;
pathlist << i; // pathlist << i;
for (auto s : map[i]){ // for (auto s : map[i]){
temp.append(s); // temp.append(s);
} // }
contentList.append(temp); // contentList.append(temp);
} // }
m_lists.append(pathlist); // m_lists.append(pathlist);
m_contentFrame->setContentList(contentList); // m_contentFrame->setContentList(contentList);
}); // });
QTime t1 = QTime::currentTime(); QTime t1 = QTime::currentTime();
search->onKeywordSearchContent(searchcontent); // search->onKeywordSearch(searchcontent);
QTime t2 = QTime::currentTime(); QTime t2 = QTime::currentTime();
qDebug() << t1; qDebug() << t1;
qDebug() << t2; qDebug() << t2;
@ -289,21 +289,21 @@ void MainWindow::searchContent(QString searchcontent){
//文件搜索 //文件搜索
FileSearcher *searcher = new FileSearcher(); FileSearcher *searcher = new FileSearcher();
//iaom--------this part shall be rewrite
// connect(searcher,&FileSearcher::result,[=](QVector<QStringList> resultV){
connect(searcher,&FileSearcher::result,[=](QVector<QStringList> resultV){ // QStringList list1 = resultV.at(0);
// QStringList list2 = resultV.at(1);
QStringList list1 = resultV.at(0); // // QVector<QStringList> lists;
QStringList list2 = resultV.at(1); // m_lists.append(list1);
// m_lists.append(list2);
// QVector<QStringList> lists; // // QVector<int> types;
m_lists.append(list1); // m_types.append(SearchItem::SearchType::Dirs);
m_lists.append(list2); // m_types.append(SearchItem::SearchType::Files);
// QVector<int> types; // m_contentFrame->refreshSearchList(m_types, m_lists, searchcontent);
m_types.append(SearchItem::SearchType::Dirs); // });
m_types.append(SearchItem::SearchType::Files); // searcher->onKeywordSearch(searchcontent,0,10);
m_contentFrame->refreshSearchList(m_types, m_lists, searchcontent);
});
searcher->onKeywordSearch(searchcontent,0,10);
// QStringList res = IndexGenerator::IndexSearch(searchcontent); // QStringList res = IndexGenerator::IndexSearch(searchcontent);
// types.append(SearchItem::SearchType::Files); // types.append(SearchItem::SearchType::Files);
// lists.append(res); // lists.append(res);