From 045210068cdbb1ff9d2d0d70a6910839ca42558b Mon Sep 17 00:00:00 2001 From: Ken Moore Date: Thu, 18 Aug 2016 12:06:54 -0400 Subject: Update the new XDGDesktopList class a bit more: 1) Add in all the bits to make it auto-update as needed (optional init argument) 2) Have it also keep track of what previous files were *removed* when it updates. 3) Tweak the update routine to try and make it even faster. --- src-qt5/core/libLumina/LuminaXDG.cpp | 37 +++++++++++++++++++++++++++++------- src-qt5/core/libLumina/LuminaXDG.h | 22 ++++++++++++++------- 2 files changed, 45 insertions(+), 14 deletions(-) (limited to 'src-qt5') diff --git a/src-qt5/core/libLumina/LuminaXDG.cpp b/src-qt5/core/libLumina/LuminaXDG.cpp index 3e71fb5c..78016029 100644 --- a/src-qt5/core/libLumina/LuminaXDG.cpp +++ b/src-qt5/core/libLumina/LuminaXDG.cpp @@ -15,20 +15,33 @@ static QStringList mimeglobs; static qint64 mimechecktime; //====XDGDesktopList Functions ==== +XDGDesktopList::XDGDesktopList(QObject *parent, bool watchdirs) : QObject(parent){ + if(watchdirs){ + watcher = new QFileSystemWatcher(this); + connect(watcher, SIGNAL(fileChanged(const QString&)), this, SLOT(updateList()) ); + connect(watcher, SIGNAL(directoryChanged(const QString&)), this, SLOT(updateList()) ); + }else{ + watcher = 0; + } +} + +XDGDesktopList::~XDGDesktopList(){ + //nothing special to do here +} + void XDGDesktopList::updateList(){ //run the check routine QStringList appDirs = LXDG::systemApplicationDirs(); //get all system directories QStringList found, newfiles; //for avoiding duplicate apps (might be files with same name in different priority directories) QStringList oldkeys = files.keys(); - QList out; - bool ok; //for internal loop use only (to prevent re-initializing variable on every iteration) - QString path; //for internal loop use (to prevent re-initializing variable on every iteration) + bool appschanged = false; + //Variables for internal loop use only (to prevent re-initializing variable on every iteration) + bool ok; QString path; QDir dir; QStringList apps; XDGDesktop dFile; for(int i=0; iQFileInfo(path).lastModified()) ){ //Re-use previous data for this file (nothing changed) dFile = files[path]; @@ -36,6 +49,7 @@ void XDGDesktopList::updateList(){ }else{ ok=false; dFile = LXDG::loadDesktopFile(dir.absoluteFilePath(apps[a]),ok); //will change the "ok" variable as needed + appschanged = true; //flag that something changed - needed to load a file } if(ok && !found.contains(dFile.name)){ if(!files.contains(path)){ newfiles << path; } //brand new file (not an update to a previously-read file) @@ -45,10 +59,19 @@ void XDGDesktopList::updateList(){ } } //end loop over apps } //end loop over appDirs + //Save the extra info to the internal lists + removedApps = oldkeys; //files which were removed + newApps = newfiles; //files which were added //Now go through and cleanup any old keys where the associated file does not exist anymore for(int i=0; iremovePaths(QStringList() << watcher->files() << watcher->directories()); + watcher->addPaths(appDirs); + if(appschanged){ emit appsUpdated(); } + } } QList XDGDesktopList::apps(bool showAll, bool showHidden){ diff --git a/src-qt5/core/libLumina/LuminaXDG.h b/src-qt5/core/libLumina/LuminaXDG.h index 644ec65a..376fc86a 100644 --- a/src-qt5/core/libLumina/LuminaXDG.h +++ b/src-qt5/core/libLumina/LuminaXDG.h @@ -18,6 +18,7 @@ #define _LUMINA_LIBRARY_XDG_H #include +#include #include #include #include @@ -72,20 +73,27 @@ public: // ======================== // Data Structure for keeping track of known system applications // ======================== -class XDGDesktopList{ +class XDGDesktopList : public QObject{ + Q_OBJECT public: + //Functions + XDGDesktopList(QObject *parent = 0, bool watchdirs = false); + ~XDGDesktopList(); + //Main Interface functions + QList apps(bool showAll, bool showHidden); //showAll: include invalid files, showHidden: include NoShow/Hidden files + //Administration variables (not typically used directly) QDateTime lastCheck; - QStringList newApps; //list of "new" apps found during the last check + QStringList newApps, removedApps; //list of "new/removed" apps found during the last check QHash files; /// - //Functions - XDGDesktopList(){} - ~XDGDesktopList(){} - //Main Interface functions +public slots: void updateList(); //run the check routine - QList apps(bool showAll, bool showHidden); //showAll: include invalid files, showHidden: include NoShow/Hidden files +private: + QFileSystemWatcher *watcher; +signals: + void appsUpdated(); }; // ======================== -- cgit