Add a new function to traverse the desktop files and to handle the data in AppDataBase.
Adjust the code structure.
This commit is contained in:
parent
e7cfd7bd83
commit
5b90706ca8
|
@ -24,7 +24,7 @@ AppSearchPlugin::AppSearchPlugin(QObject *parent) : QThread(parent), m_appSearch
|
|||
connect(this, SIGNAL(startTimer), m_timer, SLOT(start()));
|
||||
connect(this, &AppSearchPlugin::stopTimer, m_timer, &QTimer::stop);
|
||||
connect(m_timer, &QTimer::timeout, this, [ & ]{
|
||||
qWarning()<<"-------------->stopped by itself";
|
||||
qWarning() << "The app-search thread stopped because of timeout.";
|
||||
this->quit();
|
||||
});
|
||||
|
||||
|
|
|
@ -3,14 +3,21 @@
|
|||
#include <QCryptographicHash>
|
||||
#include <QFile>
|
||||
#include "app-db-manager.h"
|
||||
#include "../libsearch/file-utils.h"
|
||||
using namespace UkuiSearch;
|
||||
#include "file-utils.h"
|
||||
#include "convert-winid-to-desktop.h"
|
||||
|
||||
#define GENERAL_APP_DESKTOP_PATH "/usr/share/applications/"
|
||||
#define ANDROID_APP_DESKTOP_PATH QDir::homePath() + "/.local/share/applications/"
|
||||
#define SNAPD_APP_DESKTOP_PATH "/var/lib/snapd/desktop/applications/"
|
||||
|
||||
static AppDBManager *global_instance = AppDBManager::getInstance();
|
||||
#define LAST_LOCALE_NAME QDir::homePath() + "/.config/org.ukui/ukui-search/appdata/last-locale-name.conf"
|
||||
#define LOCALE_NAME_VALUE "CurrentLocaleName"
|
||||
|
||||
using namespace UkuiSearch;
|
||||
|
||||
static AppDBManager *global_instance;
|
||||
QMutex AppDBManager::s_installAppMapMutex;
|
||||
|
||||
AppDBManager *AppDBManager::getInstance()
|
||||
{
|
||||
if (!global_instance) {
|
||||
|
@ -18,9 +25,29 @@ AppDBManager *AppDBManager::getInstance()
|
|||
}
|
||||
return global_instance;
|
||||
}
|
||||
AppDBManager::AppDBManager(QObject *parent) : QObject(parent), m_database(new QSqlDatabase)
|
||||
|
||||
AppDBManager::AppDBManager(QObject *parent) : QObject(parent), m_database(QSqlDatabase())
|
||||
{
|
||||
openDataBase();
|
||||
//链接数据库
|
||||
if (openDataBase()) {
|
||||
//监听系统语言变化
|
||||
m_qSettings = new QSettings(LAST_LOCALE_NAME, QSettings::IniFormat);
|
||||
m_localeChanged = false;
|
||||
m_qSettings->beginGroup(LOCALE_NAME_VALUE);
|
||||
QString lastLocale = m_qSettings->value(LOCALE_NAME_VALUE).toString();
|
||||
if (QLocale::system().name().compare(lastLocale)) {
|
||||
qDebug() << "I'm going to update the locale name in conf file.";
|
||||
if (!lastLocale.isEmpty()) {
|
||||
m_localeChanged = true;
|
||||
}
|
||||
m_qSettings->setValue(LOCALE_NAME_VALUE, QLocale::system().name());
|
||||
}
|
||||
m_qSettings->endGroup();
|
||||
|
||||
//初始化数据库
|
||||
initDataBase();
|
||||
|
||||
//初始化FileSystemWatcher
|
||||
m_watchAppDir = new QFileSystemWatcher(this);
|
||||
m_watchAppDir->addPath(GENERAL_APP_DESKTOP_PATH);
|
||||
QDir androidPath(ANDROID_APP_DESKTOP_PATH);
|
||||
|
@ -35,20 +62,31 @@ AppDBManager::AppDBManager(QObject *parent) : QObject(parent), m_database(new QS
|
|||
}
|
||||
m_watchAppDir->addPath(SNAPD_APP_DESKTOP_PATH);
|
||||
|
||||
initDateBaseConnection();
|
||||
|
||||
//监听desktop文件所在目录,TODO:directoryChange会发多次信号,需要计时器阻塞
|
||||
connect(m_watchAppDir, &QFileSystemWatcher::directoryChanged, this, [ = ](const QString & path) {
|
||||
qDebug() << "m_watchAppDir directoryChanged:" << path;
|
||||
if (m_database->transaction()) {
|
||||
this->updateAppInfoDB();
|
||||
if (!m_database->commit()) {
|
||||
if (m_database.transaction()) {
|
||||
// this->updateAppInfoDB();
|
||||
this->updateAllData2DB();
|
||||
if (!m_database.commit()) {
|
||||
qWarning() << "Failed to commit !";
|
||||
m_database->rollback();
|
||||
m_database.rollback();
|
||||
}
|
||||
} else {
|
||||
qWarning() << "Failed to start transaction mode!!!";
|
||||
}
|
||||
});
|
||||
|
||||
//监控应用进程开启
|
||||
connect(KWindowSystem::self(), &KWindowSystem::windowAdded, [ = ](WId id) {
|
||||
QString desktopfp = ConvertWinidToDesktop::getConverter().tranIdToDesktop(id);
|
||||
if (!desktopfp.isEmpty()) {
|
||||
AppDBManager::getInstance()->updateAppLaunchTimes(desktopfp);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
qDebug() << "App-db-manager does nothing.";
|
||||
}
|
||||
}
|
||||
|
||||
AppDBManager::~AppDBManager()
|
||||
|
@ -62,8 +100,8 @@ AppDBManager::~AppDBManager()
|
|||
|
||||
void AppDBManager::buildAppInfoDB()
|
||||
{
|
||||
QSqlQuery sql(*m_database);
|
||||
QString cmd = QString("CREATE TABLE IF NOT EXISTS appInfo(%1,%2,%3,%4,%5,%6,%7,%8,%9,%10,%11,%12,%13,%14,%15,%16,%17,%18,%19,%20)")
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = QString("CREATE TABLE IF NOT EXISTS appInfo(%1, %2, %3, %4, %5, %6, %7, %8,%9, %10, %11, %12, %13, %14, %15, %16, %17, %18, %19, %20, %21)")
|
||||
// .arg("ID INT")//自增id
|
||||
.arg("DESKTOP_FILE_PATH TEXT")//desktop文件路径
|
||||
.arg("MODIFYED_TIME TEXT")//YYYYMMDDHHmmSS 修改日期
|
||||
|
@ -73,6 +111,7 @@ void AppDBManager::buildAppInfoDB()
|
|||
.arg("NAME_ZH TEXT")//应用中文名称
|
||||
.arg("PINYIN_NAME TEXT")//中文拼音
|
||||
.arg("FIRST_LETTER_OF_PINYIN TEXT")//中文拼音首字母
|
||||
.arg("FIRST_LETTER_ALL")//中英文首字母(只包含一个,目前方案取拼音首字母的第一项,由于模糊拼音算法可能出问题)
|
||||
.arg("ICON TEXT")//图标名称(或路径)
|
||||
.arg("TYPE TEXT")//应用类型
|
||||
.arg("CATEGORY TEXT")//应用分类
|
||||
|
@ -87,7 +126,7 @@ void AppDBManager::buildAppInfoDB()
|
|||
.arg("PRIMARY KEY (DESKTOP_FILE_PATH)");
|
||||
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -101,28 +140,28 @@ void AppDBManager::updateAppInfoDB()
|
|||
this->getAllDesktopFilePath(SNAPD_APP_DESKTOP_PATH);
|
||||
QStringList filePathList;
|
||||
this->getFilePathList(filePathList);
|
||||
QSqlQuery sql(*m_database);
|
||||
QString cmd;
|
||||
if (!sql.exec("SELECT COUNT(*) FROM appInfo")) {
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = "SELECT COUNT(*) FROM appInfo";
|
||||
if (!sql.exec(cmd)) {
|
||||
this->buildAppInfoDB();
|
||||
for (auto &filePath : filePathList) {
|
||||
this->addAppDesktopFile2DB(filePath);
|
||||
}
|
||||
} else {
|
||||
cmd = QString("SELECT COUNT(*) FROM appInfo");
|
||||
if (sql.exec(cmd)) {
|
||||
if (sql.next()) {
|
||||
//删除多余项
|
||||
if (sql.value(0).toInt() > filePathList.size()) {
|
||||
int size = sql.value(0).toInt();
|
||||
cmd = QString("SELECT DESKTOP_FILE_PATH FROM appInfo");
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
QString path;
|
||||
for (int i = 0; i<size; ++i) {
|
||||
if (!sql.next()) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
path = sql.value(0).toString();
|
||||
|
@ -132,6 +171,7 @@ void AppDBManager::updateAppInfoDB()
|
|||
}
|
||||
}
|
||||
}
|
||||
//添加新增项,根据md5判断desktop文件是否改变以更新对应项
|
||||
for (QString &filePath : filePathList) {
|
||||
cmd = QString("SELECT COUNT(*) FROM appInfo WHERE DESKTOP_FILE_PATH = '%0'").arg(filePath);
|
||||
if (sql.exec(cmd)) {
|
||||
|
@ -141,11 +181,11 @@ void AppDBManager::updateAppInfoDB()
|
|||
} else {
|
||||
cmd = QString("SELECT MD5 FROM appInfo WHERE DESKTOP_FILE_PATH = '%0'").arg(filePath);
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
if (!sql.next()) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
if (sql.value(0).toString() != getAppDesktopMd5(filePath)) {
|
||||
|
@ -153,20 +193,20 @@ void AppDBManager::updateAppInfoDB()
|
|||
}
|
||||
}
|
||||
} else {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -246,41 +286,172 @@ void AppDBManager::getAllDesktopFilePath(QString path) {
|
|||
}
|
||||
}
|
||||
|
||||
void AppDBManager::initDateBaseConnection()
|
||||
void AppDBManager::loadDesktopFilePaths(QString path, QFileInfoList &infolist)
|
||||
{
|
||||
if (m_database->transaction()) {
|
||||
this->updateAppInfoDB();
|
||||
if (!m_database->commit()) {
|
||||
QDir dir(path);
|
||||
dir.setSorting(QDir::DirsFirst);
|
||||
dir.setFilter(QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot);
|
||||
infolist.append(dir.entryInfoList());
|
||||
}
|
||||
|
||||
void AppDBManager::updateAllData2DB()
|
||||
{
|
||||
bool firstExec = false;
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = "SELECT DESKTOP_FILE_PATH,MD5 FROM appInfo";
|
||||
QMap<QString, QString> dataMap;
|
||||
if (!sql.exec(cmd)) {
|
||||
qDebug() << "Fail to read database, because: " << m_database.lastError();
|
||||
this->buildAppInfoDB();
|
||||
firstExec = true;
|
||||
} else {
|
||||
sql.exec(cmd);
|
||||
while (sql.next()) {
|
||||
dataMap.insert(sql.value("DESKTOP_FILE_PATH").toString(), sql.value("MD5").toString());
|
||||
}
|
||||
}
|
||||
|
||||
//遍历desktop文件
|
||||
QFileInfoList infos;
|
||||
this->loadDesktopFilePaths(GENERAL_APP_DESKTOP_PATH, infos);
|
||||
this->loadDesktopFilePaths(ANDROID_APP_DESKTOP_PATH, infos);
|
||||
this->loadDesktopFilePaths(SNAPD_APP_DESKTOP_PATH, infos);
|
||||
if(infos.size() < 1) {
|
||||
return;
|
||||
}
|
||||
XdgDesktopFile desktopfile;
|
||||
for (int i = 0; i < infos.length(); i++) {
|
||||
QFileInfo fileInfo = infos.at(i);
|
||||
QString path = fileInfo.filePath();
|
||||
//对目录递归
|
||||
if (fileInfo.isDir()) {
|
||||
loadDesktopFilePaths(path, infos);
|
||||
continue;
|
||||
}
|
||||
//排除非法路径(黑名单 + 非desktop文件)
|
||||
if (m_excludedDesktopfiles.contains(path) or !path.endsWith(".desktop")) {
|
||||
continue;
|
||||
}
|
||||
|
||||
desktopfile.load(path);
|
||||
//排除NoDisplay和NotShowIn字段,排除loaclized名字为空
|
||||
if (desktopfile.value("NoDisplay").toString().contains("true") or
|
||||
desktopfile.value("NotShowIn").toString().contains("UKUI") or
|
||||
desktopfile.localizedValue("Name").toString().isEmpty()) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!firstExec) {
|
||||
//数据库有记录
|
||||
if (dataMap.contains(path)) {
|
||||
if (!QString::compare(dataMap.value(path), getAppDesktopMd5(path))) {
|
||||
//判断系统语言是否改变
|
||||
if (m_localeChanged) {
|
||||
this->updateLocaleData2DB(path);
|
||||
}
|
||||
dataMap.remove(path);
|
||||
continue;
|
||||
} else {
|
||||
//数据库有记录但md5值改变则update
|
||||
this->updateAppDesktopFile2DB(path);
|
||||
dataMap.remove(path);
|
||||
continue;
|
||||
}
|
||||
} else {
|
||||
//数据库中没有记录则insert
|
||||
this->addAppDesktopFile2DB(path);
|
||||
dataMap.remove(path);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
//数据库为空则全部insert
|
||||
this->addAppDesktopFile2DB(path);
|
||||
dataMap.remove(path);
|
||||
}
|
||||
|
||||
//遍历完成后重置标志位
|
||||
m_localeChanged = false;
|
||||
|
||||
//数据库冗余项直接delete
|
||||
if (!dataMap.isEmpty()) {
|
||||
for (auto i = dataMap.constBegin(); i != dataMap.constEnd(); i++) {
|
||||
this->deleteAppDesktopFile2DB(i.key());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
bool AppDBManager::updateLocaleData2DB(QString desktopPath)
|
||||
{
|
||||
bool res(true);
|
||||
XdgDesktopFile desktopFile;
|
||||
desktopFile.load(desktopPath);
|
||||
QString localName = desktopFile.localizedValue("Name", "NULL").toString();
|
||||
QString firstLetter2All = localName;
|
||||
|
||||
if (localName.contains(QRegExp("[\\x4e00-\\x9fa5]+"))) {
|
||||
firstLetter2All = FileUtils::findMultiToneWords(localName).at(0);
|
||||
}
|
||||
|
||||
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = QString("UPDATE appInfo SET "
|
||||
"LOCAL_NAME = '%0', FIRST_LETTER_ALL = '%1'"
|
||||
"WHERE DESKTOP_FILE_PATH='%2'")
|
||||
.arg(localName)
|
||||
.arg(firstLetter2All)
|
||||
.arg(desktopPath);
|
||||
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
res = false;
|
||||
}
|
||||
if (res) {
|
||||
qDebug() << "Already to update the locale app-data of " << desktopPath;
|
||||
} else {
|
||||
qDebug() << "Fail to update the locale app-data of " << desktopPath;
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
void AppDBManager::initDataBase()
|
||||
{
|
||||
if (m_database.transaction()) {
|
||||
// this->updateAppInfoDB();
|
||||
this->updateAllData2DB();
|
||||
if (!m_database.commit()) {
|
||||
qWarning() << "Failed to commit !";
|
||||
m_database->rollback();
|
||||
m_database.rollback();
|
||||
}
|
||||
} else {
|
||||
qWarning() << "Failed to start transaction mode!!!";
|
||||
}
|
||||
}
|
||||
|
||||
void AppDBManager::openDataBase()
|
||||
bool AppDBManager::openDataBase()
|
||||
{
|
||||
bool res(true);
|
||||
|
||||
QDir dir;
|
||||
if (!dir.exists(APP_DATABASE_PATH)) {
|
||||
dir.mkpath(APP_DATABASE_PATH);
|
||||
}
|
||||
if (QSqlDatabase::contains(CONNECTION_NAME)) {
|
||||
*m_database = QSqlDatabase::database(CONNECTION_NAME);
|
||||
m_database = QSqlDatabase::database(CONNECTION_NAME);
|
||||
} else {
|
||||
*m_database = QSqlDatabase::addDatabase("QSQLITE", CONNECTION_NAME);
|
||||
m_database->setDatabaseName(APP_DATABASE_PATH + APP_DATABASE_NAME);
|
||||
m_database = QSqlDatabase::addDatabase("QSQLITE", CONNECTION_NAME);
|
||||
m_database.setDatabaseName(APP_DATABASE_PATH + APP_DATABASE_NAME);
|
||||
}
|
||||
if(!m_database->open()) {
|
||||
qWarning() << m_database->lastError();
|
||||
QApplication::quit();
|
||||
if(!m_database.open()) {
|
||||
qWarning() << "Fail to open AppDataBase, because" << m_database.lastError();
|
||||
res = false;
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
void AppDBManager::closeDataBase()
|
||||
{
|
||||
m_database->close();
|
||||
delete m_database;
|
||||
m_database.close();
|
||||
// delete m_database;
|
||||
QSqlDatabase::removeDatabase(CONNECTION_NAME);
|
||||
}
|
||||
|
||||
|
@ -306,11 +477,18 @@ void AppDBManager::getInstallAppMap(QMap<QString, QStringList> &installAppMap)
|
|||
bool AppDBManager::addAppDesktopFile2DB(QString &desktopfd)
|
||||
{
|
||||
bool res(true);
|
||||
QSqlQuery sql(*m_database);
|
||||
QSqlQuery sql(m_database);
|
||||
XdgDesktopFile desktopfile;
|
||||
desktopfile.load(desktopfd);
|
||||
QString hanzi, pinyin, firstLetterOfPinyin;
|
||||
QString localName = desktopfile.localizedValue("Name", "NULL").toString();
|
||||
QString firstLtter2All = localName;
|
||||
bool isHanzi = true;
|
||||
|
||||
if (localName.contains(QRegExp("[\\x4e00-\\x9fa5]+"))) {
|
||||
firstLtter2All = FileUtils::findMultiToneWords(localName).at(0);
|
||||
}
|
||||
|
||||
if (desktopfile.contains("Name[zh_CN]")) {
|
||||
hanzi = desktopfile.value("Name[zh_CN]").toString();
|
||||
} else {
|
||||
|
@ -319,6 +497,7 @@ bool AppDBManager::addAppDesktopFile2DB(QString &desktopfd)
|
|||
isHanzi = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (isHanzi) {
|
||||
QStringList pinyinList = FileUtils::findMultiToneWords(hanzi);
|
||||
for (int i = 0; i<pinyinList.size(); ++i) {
|
||||
|
@ -331,21 +510,26 @@ bool AppDBManager::addAppDesktopFile2DB(QString &desktopfd)
|
|||
}
|
||||
|
||||
QString cmd = QString("INSERT INTO appInfo "
|
||||
"(DESKTOP_FILE_PATH,MODIFYED_TIME,INSERT_TIME,LOCAL_NAME,NAME_EN,NAME_ZH,PINYIN_NAME,FIRST_LETTER_OF_PINYIN,ICON,TYPE,CATEGORY,EXEC,COMMENT,MD5,LAUNCH_TIMES,FAVORITES,LAUNCHED,TOP,LOCK) "
|
||||
"VALUES('%1','%2','%3','%4','%5','%6','%7','%8','%9','%10','%11','%12','%13','%14',%15,%16,%17,%18,%19)")
|
||||
"(DESKTOP_FILE_PATH, MODIFYED_TIME, INSERT_TIME, "
|
||||
"LOCAL_NAME, NAME_EN, NAME_ZH, PINYIN_NAME, "
|
||||
"FIRST_LETTER_OF_PINYIN, FIRST_LETTER_ALL, "
|
||||
"ICON, TYPE, CATEGORY, EXEC, COMMENT, MD5, "
|
||||
"LAUNCH_TIMES, FAVORITES, LAUNCHED, TOP, LOCK) "
|
||||
"VALUES('%1','%2','%3','%4','%5','%6','%7','%8','%9','%10','%11','%12','%13','%14','%15',%16,%17,%18,%19,%20)")
|
||||
.arg(desktopfd)
|
||||
.arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"))
|
||||
.arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"))
|
||||
.arg(desktopfile.localizedValue("Name").toString())
|
||||
.arg(localName)
|
||||
.arg(desktopfile.value("Name").toString())
|
||||
.arg(hanzi)
|
||||
.arg(pinyin)
|
||||
.arg(firstLetterOfPinyin)
|
||||
.arg(firstLtter2All)
|
||||
.arg(desktopfile.value("Icon").toString())
|
||||
.arg(desktopfile.value("Type").toString())
|
||||
.arg(desktopfile.value("Categories").toString())
|
||||
.arg(desktopfile.value("Exec").toString())
|
||||
.arg(desktopfile.value("Comment").toString())
|
||||
.arg(desktopfile.value("Comment").toString().replace("'", "''"))
|
||||
.arg(getAppDesktopMd5(desktopfd))
|
||||
.arg(0)
|
||||
.arg(0)
|
||||
|
@ -353,7 +537,7 @@ bool AppDBManager::addAppDesktopFile2DB(QString &desktopfd)
|
|||
.arg(0)
|
||||
.arg(0);
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
res = false;
|
||||
}
|
||||
if (res) {
|
||||
|
@ -364,13 +548,13 @@ bool AppDBManager::addAppDesktopFile2DB(QString &desktopfd)
|
|||
return res;
|
||||
}
|
||||
|
||||
bool AppDBManager::deleteAppDesktopFile2DB(QString &desktopfd)
|
||||
bool AppDBManager::deleteAppDesktopFile2DB(const QString &desktopfd)
|
||||
{
|
||||
bool res(true);
|
||||
QSqlQuery sql(*m_database);
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = QString("DELETE FROM appInfo WHERE DESKTOP_FILE_PATH = '%0'").arg(desktopfd);
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
res = false;
|
||||
}
|
||||
if (res) {
|
||||
|
@ -391,7 +575,14 @@ bool AppDBManager::updateAppDesktopFile2DB(QString &desktopfd)
|
|||
return this->deleteAppDesktopFile2DB(desktopfd);
|
||||
}
|
||||
QString hanzi, pinyin, firstLetterOfPinyin;
|
||||
QString localName = desktopfile.localizedValue("Name", "NULL").toString();
|
||||
QString firstLetter2All = localName;
|
||||
bool isHanzi = true;
|
||||
|
||||
if (localName.contains(QRegExp("[\\x4e00-\\x9fa5]+"))) {
|
||||
firstLetter2All = FileUtils::findMultiToneWords(localName).at(0);
|
||||
}
|
||||
|
||||
if (desktopfile.contains("Name[zh_CN]")) {
|
||||
hanzi = desktopfile.value("Name[zh_CN]").toString();
|
||||
} else {
|
||||
|
@ -400,8 +591,10 @@ bool AppDBManager::updateAppDesktopFile2DB(QString &desktopfd)
|
|||
isHanzi = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (isHanzi) {
|
||||
QStringList pinyinList = FileUtils::findMultiToneWords(hanzi);
|
||||
firstLetter2All = pinyinList.at(0);
|
||||
for (int i = 0; i<pinyinList.size(); ++i) {
|
||||
if (i % 2) {
|
||||
firstLetterOfPinyin += pinyinList.at(i);
|
||||
|
@ -410,7 +603,8 @@ bool AppDBManager::updateAppDesktopFile2DB(QString &desktopfd)
|
|||
}
|
||||
}
|
||||
}
|
||||
QSqlQuery sql(*m_database);
|
||||
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = QString("UPDATE appInfo SET "
|
||||
"MODIFYED_TIME='%0',"
|
||||
"LOCAL_NAME='%1',"
|
||||
|
@ -418,28 +612,30 @@ bool AppDBManager::updateAppDesktopFile2DB(QString &desktopfd)
|
|||
"NAME_ZH='%3'"
|
||||
",PINYIN_NAME='%4',"
|
||||
"FIRST_LETTER_OF_PINYIN='%5',"
|
||||
"ICON='%6',"
|
||||
"TYPE='%7',"
|
||||
"CATEGORY='%8',"
|
||||
"EXEC='%9',"
|
||||
"COMMENT='%10',"
|
||||
"MD5='%11' "
|
||||
"WHERE DESKTOP_FILE_PATH='%12'")
|
||||
"FIRST_LETTER_ALL='%6'"
|
||||
"ICON='%7',"
|
||||
"TYPE='%8',"
|
||||
"CATEGORY='%9',"
|
||||
"EXEC='%10',"
|
||||
"COMMENT='%11',"
|
||||
"MD5='%12' "
|
||||
"WHERE DESKTOP_FILE_PATH='%13'")
|
||||
.arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"))
|
||||
.arg(desktopfile.localizedValue("Name").toString())
|
||||
.arg(localName)
|
||||
.arg(desktopfile.value("Name").toString())
|
||||
.arg(hanzi)
|
||||
.arg(pinyin)
|
||||
.arg(firstLetterOfPinyin)
|
||||
.arg(firstLetter2All)
|
||||
.arg(desktopfile.value("Icon").toString())
|
||||
.arg(desktopfile.value("Type").toString())
|
||||
.arg(desktopfile.value("Categories").toString())
|
||||
.arg(desktopfile.value("Exec").toString())
|
||||
.arg(desktopfile.value("Comment").toString())
|
||||
.arg(desktopfile.value("Comment").toString().replace("'", "''"))
|
||||
.arg(getAppDesktopMd5(desktopfd))
|
||||
.arg(desktopfd);
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << m_database->lastError() << cmd;
|
||||
qWarning() << m_database.lastError() << cmd;
|
||||
res = false;
|
||||
}
|
||||
if (res) {
|
||||
|
@ -453,8 +649,8 @@ bool AppDBManager::updateAppDesktopFile2DB(QString &desktopfd)
|
|||
bool AppDBManager::updateAppLaunchTimes(QString &desktopfp)
|
||||
{
|
||||
bool res(true);
|
||||
if (m_database->transaction()) {
|
||||
QSqlQuery sql(*m_database);
|
||||
if (m_database.transaction()) {
|
||||
QSqlQuery sql(m_database);
|
||||
QString cmd = QString("SELECT LAUNCH_TIMES FROM appInfo WHERE DESKTOP_FILE_PATH='%1'").arg(desktopfp);
|
||||
if (sql.exec(cmd)) {
|
||||
if (sql.next()) {
|
||||
|
@ -464,7 +660,7 @@ bool AppDBManager::updateAppLaunchTimes(QString &desktopfp)
|
|||
.arg(1)
|
||||
.arg(desktopfp);
|
||||
if (!sql.exec(cmd)) {
|
||||
qWarning() << "Set app favorites state failed!" << m_database->lastError();
|
||||
qWarning() << "Set app favorites state failed!" << m_database.lastError();
|
||||
res = false;
|
||||
}
|
||||
} else {
|
||||
|
@ -475,9 +671,9 @@ bool AppDBManager::updateAppLaunchTimes(QString &desktopfp)
|
|||
qWarning() << "Failed to exec:" << cmd;
|
||||
res = false;
|
||||
}
|
||||
if (!m_database->commit()) {
|
||||
if (!m_database.commit()) {
|
||||
qWarning() << "Failed to commit !" << cmd;
|
||||
m_database->rollback();
|
||||
m_database.rollback();
|
||||
res = false;
|
||||
}
|
||||
} else {
|
||||
|
|
|
@ -11,6 +11,7 @@
|
|||
#include <QDateTime>
|
||||
#include <QFileSystemWatcher>
|
||||
#include <QMutex>
|
||||
#include <QSettings>
|
||||
#include "app-db-common-defines.h"
|
||||
|
||||
#define CONNECTION_NAME QLatin1String("ukss-appdb-connection")
|
||||
|
@ -51,25 +52,31 @@ public:
|
|||
void getInstallAppMap(QMap<QString, QStringList> &installAppMap);
|
||||
|
||||
bool addAppDesktopFile2DB(QString &desktopfd);
|
||||
bool deleteAppDesktopFile2DB(QString &desktopfd);
|
||||
bool deleteAppDesktopFile2DB(const QString &desktopfd);
|
||||
bool updateAppDesktopFile2DB(QString &desktopfd);
|
||||
bool updateAppLaunchTimes(QString &desktopfp);
|
||||
void updateAllData2DB();
|
||||
bool updateLocaleData2DB(QString desktopPath);
|
||||
|
||||
private:
|
||||
explicit AppDBManager(QObject *parent = nullptr);
|
||||
~AppDBManager();
|
||||
|
||||
void getAllDesktopFilePath(QString path);
|
||||
void loadDesktopFilePaths(QString path, QFileInfoList &infolist);
|
||||
|
||||
void initDateBaseConnection();
|
||||
void openDataBase();
|
||||
void initDataBase();
|
||||
bool openDataBase();
|
||||
void closeDataBase();
|
||||
|
||||
void buildAppInfoDB();
|
||||
void updateAppInfoDB();
|
||||
void getAllDesktopFilePath(QString path);
|
||||
void getFilePathList(QStringList &pathList);
|
||||
|
||||
QSqlDatabase *m_database = nullptr;
|
||||
QSettings *m_qSettings = nullptr;
|
||||
bool m_localeChanged;
|
||||
|
||||
QSqlDatabase m_database;
|
||||
|
||||
QFileSystemWatcher *m_watchAppDir = nullptr;
|
||||
|
||||
|
@ -119,6 +126,9 @@ private:
|
|||
"/usr/share/applications/openjdk-8-policytool.desktop",
|
||||
"/usr/share/applications/kylin-io-monitor.desktop",
|
||||
"/usr/share/applications/wps-office-uninstall.desktop",
|
||||
|
||||
//原本额外排除的目录,不知道额外的原因,有可能之后有问题--bjj20220621
|
||||
"/usr/share/applications/screensavers"
|
||||
};
|
||||
|
||||
};
|
||||
|
|
|
@ -26,6 +26,12 @@ ConvertWinidToDesktop::ConvertWinidToDesktop(QObject *parent) : QObject(parent)
|
|||
{
|
||||
}
|
||||
|
||||
ConvertWinidToDesktop &ConvertWinidToDesktop::getConverter()
|
||||
{
|
||||
static ConvertWinidToDesktop instance;
|
||||
return instance;
|
||||
}
|
||||
|
||||
QString ConvertWinidToDesktop::tranIdToDesktop(WId id)
|
||||
{
|
||||
KWindowInfo info(id, 0, NET::WM2AllProperties);
|
||||
|
|
|
@ -47,12 +47,16 @@ class ConvertWinidToDesktop : public QObject
|
|||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
explicit ConvertWinidToDesktop(QObject *parent = nullptr);
|
||||
~ConvertWinidToDesktop();
|
||||
static ConvertWinidToDesktop &getConverter();
|
||||
|
||||
QString tranIdToDesktop(WId id);
|
||||
|
||||
private:
|
||||
explicit ConvertWinidToDesktop(QObject *parent = nullptr);
|
||||
ConvertWinidToDesktop(const ConvertWinidToDesktop&) = delete;
|
||||
ConvertWinidToDesktop& operator =(const ConvertWinidToDesktop&) = delete;
|
||||
~ConvertWinidToDesktop();
|
||||
|
||||
QString m_classClass = nullptr;
|
||||
QString m_className = nullptr;
|
||||
QString m_statusName = nullptr;
|
||||
|
|
|
@ -59,9 +59,9 @@ int main(int argc, char *argv[])
|
|||
#if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0))
|
||||
QApplication::setHighDpiScaleFactorRoundingPolicy(Qt::HighDpiScaleFactorRoundingPolicy::PassThrough);
|
||||
#endif
|
||||
UkuiSearchAppDataService ukss(argc, argv, "ukui-search-app-data-service");
|
||||
if (ukss.isRunning())
|
||||
UkuiSearchAppDataService appDB(argc, argv, "ukui-search-app-data-service");
|
||||
if (appDB.isRunning()) {
|
||||
return 0;
|
||||
|
||||
return ukss.exec();
|
||||
}
|
||||
return appDB.exec();
|
||||
}
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
#include <QDebug>
|
||||
#include "ukui-search-app-data-service.h"
|
||||
#include "app-db-manager.h"
|
||||
#include "convert-winid-to-desktop.h"
|
||||
|
||||
using namespace UkuiSearch;
|
||||
|
||||
UkuiSearchAppDataService::UkuiSearchAppDataService(int &argc, char *argv[], const QString &applicationName):
|
||||
QtSingleApplication (applicationName, argc, argv)
|
||||
{
|
||||
|
@ -12,17 +12,12 @@ UkuiSearchAppDataService::UkuiSearchAppDataService(int &argc, char *argv[], cons
|
|||
setQuitOnLastWindowClosed(false);
|
||||
|
||||
if (!this->isRunning()) {
|
||||
connect(this, &QtSingleApplication::messageReceived, [=](QString msg) {
|
||||
qDebug() << "First running";
|
||||
AppDBManager::getInstance();
|
||||
|
||||
connect(this, &QtSingleApplication::messageReceived, [ & ](QString msg) {
|
||||
this->parseCmd(msg, true);
|
||||
});
|
||||
//监控应用进程开启
|
||||
connect(KWindowSystem::self(), &KWindowSystem::windowAdded, [ = ](WId id) {
|
||||
ConvertWinidToDesktop reply;
|
||||
QString desktopfp = reply.tranIdToDesktop(id);
|
||||
if (!desktopfp.isEmpty()) {
|
||||
AppDBManager::getInstance()->updateAppLaunchTimes(desktopfp);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
//parse cmd
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
QT += core gui dbus sql xml KWindowSystem
|
||||
QT += core gui dbus sql KWindowSystem
|
||||
|
||||
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
||||
|
||||
|
@ -6,8 +6,7 @@ greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
|||
TARGET = ukui-search-app-data-service
|
||||
VERSION = 1.0.0
|
||||
DEFINES += VERSION='\\"$${VERSION}\\"'
|
||||
CONFIG += c++11 link_pkgconfig no_keywords lrelease
|
||||
PKGCONFIG += glib-2.0 gio-unix-2.0 gio-2.0 poppler-qt5
|
||||
CONFIG += c++11 no_keywords
|
||||
|
||||
# The following define makes your compiler emit warnings if you use
|
||||
# any Qt feature that has been marked deprecated (the exact warnings
|
||||
|
@ -24,23 +23,19 @@ QMAKE_CXXFLAGS += -Werror=return-type -Werror=return-local-addr -Werror=uninitia
|
|||
#include(../libsearch/appdata/appdata.pri)
|
||||
include(../3rd-parties/qtsingleapplication/qtsingleapplication.pri)
|
||||
|
||||
LIBS += -lQt5Xdg -lquazip5 -luchardet -ltesseract
|
||||
LIBS += -lQt5Xdg
|
||||
|
||||
SOURCES += \
|
||||
main.cpp \
|
||||
convert-winid-to-desktop.cpp \
|
||||
app-db-manager.cpp \
|
||||
ukui-search-app-data-service.cpp \
|
||||
../libsearch/file-utils.cpp \
|
||||
../libsearch/gobject-template.cpp
|
||||
|
||||
HEADERS += \
|
||||
convert-winid-to-desktop.h \
|
||||
app-db-manager.h \
|
||||
ukui-search-app-data-service.h \
|
||||
app-db-common-defines.h \
|
||||
../libsearch/file-utils.h \
|
||||
../libsearch/gobject-template.h
|
||||
|
||||
target.path = /usr/bin
|
||||
INSTALLS += target
|
||||
|
@ -52,3 +47,7 @@ INSTALLS += desktop
|
|||
LIBS += -L$$OUT_PWD/../libchinese-segmentation/ -lchinese-segmentation
|
||||
INCLUDEPATH += $$PWD/../libchinese-segmentation
|
||||
DEPENDPATH += $$PWD/../libchinese-segmentation
|
||||
|
||||
LIBS += -L$$OUT_PWD/../libsearch/ -lukui-search
|
||||
INCLUDEPATH += $$PWD/../libsearch
|
||||
DEPENDPATH += $$PWD/../libsearch
|
||||
|
|
|
@ -58,8 +58,6 @@ private:
|
|||
void initDiskWatcher();
|
||||
|
||||
void handleDisk();
|
||||
void handleAddedUDiskDevice(QDBusMessage msg);
|
||||
void handleRemovedUDiskDevice(QDBusMessage msg);
|
||||
|
||||
void handleIndexItemAppend(const QString &path, QStringList &blackList);
|
||||
void handleIndexItemRemove(const QString &path);
|
||||
|
@ -86,6 +84,11 @@ private:
|
|||
QStringList m_currentUDiskDeviceList;
|
||||
QString m_removedUDiskDevice;
|
||||
QMap<QString, QStringList> m_currentUDiskDeviceInfo;
|
||||
|
||||
private Q_SLOTS:
|
||||
void handleAddedUDiskDevice(QDBusMessage msg);
|
||||
void handleRemovedUDiskDevice(QDBusMessage msg);
|
||||
|
||||
Q_SIGNALS:
|
||||
void udiskRemoved();
|
||||
void appendIndexItem(const QString&, const QStringList&);
|
||||
|
|
Loading…
Reference in New Issue