mirror of
https://github.com/clementine-player/Clementine
synced 2024-12-17 20:09:50 +01:00
Add more robust subdirectory detection in LibraryWatcher.
This commit is contained in:
parent
97f3885f58
commit
761737eb4d
@ -46,6 +46,9 @@ void MacFSListener::EventStreamCallback(
|
|||||||
for (int i = 0; i < num_events; ++i) {
|
for (int i = 0; i < num_events; ++i) {
|
||||||
QString path = QString::fromUtf8(paths[i]);
|
QString path = QString::fromUtf8(paths[i]);
|
||||||
qLog(Debug) << "Something changed at:" << path;
|
qLog(Debug) << "Something changed at:" << path;
|
||||||
|
if (path.endsWith('/')) {
|
||||||
|
path.chop(1);
|
||||||
|
}
|
||||||
emit me->PathChanged(path);
|
emit me->PathChanged(path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -115,7 +115,7 @@ LibraryWatcher::ScanTransaction::~ScanTransaction() {
|
|||||||
if (watcher_->monitor_) {
|
if (watcher_->monitor_) {
|
||||||
// Watch the new subdirectories
|
// Watch the new subdirectories
|
||||||
foreach (const Subdirectory& subdir, new_subdirs) {
|
foreach (const Subdirectory& subdir, new_subdirs) {
|
||||||
watcher_->AddWatch(subdir.path);
|
watcher_->AddWatch(watcher_->watched_dirs_[dir_], subdir.path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -207,7 +207,7 @@ void LibraryWatcher::AddDirectory(const Directory& dir, const SubdirectoryList&
|
|||||||
ScanSubdirectory(subdir.path, subdir, &transaction);
|
ScanSubdirectory(subdir.path, subdir, &transaction);
|
||||||
|
|
||||||
if (monitor_)
|
if (monitor_)
|
||||||
AddWatch(subdir.path);
|
AddWatch(data, subdir.path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -546,13 +546,14 @@ uint LibraryWatcher::GetMtimeForCue(const QString& cue_path) {
|
|||||||
: 0;
|
: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LibraryWatcher::AddWatch(const QString& path) {
|
void LibraryWatcher::AddWatch(DirData dir, const QString& path) {
|
||||||
if (!QFile::exists(path))
|
if (!QFile::exists(path))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
connect(fs_watcher_, SIGNAL(PathChanged(const QString&)), this,
|
connect(fs_watcher_, SIGNAL(PathChanged(const QString&)), this,
|
||||||
SLOT(DirectoryChanged(const QString&)), Qt::UniqueConnection);
|
SLOT(DirectoryChanged(const QString&)), Qt::UniqueConnection);
|
||||||
fs_watcher_->AddPath(path);
|
fs_watcher_->AddPath(path);
|
||||||
|
subdir_mapping_[path] = dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LibraryWatcher::RemoveDirectory(const Directory& dir) {
|
void LibraryWatcher::RemoveDirectory(const Directory& dir) {
|
||||||
@ -573,11 +574,11 @@ bool LibraryWatcher::FindSongByPath(const SongList& list, const QString& path, S
|
|||||||
|
|
||||||
void LibraryWatcher::DirectoryChanged(const QString &subdir) {
|
void LibraryWatcher::DirectoryChanged(const QString &subdir) {
|
||||||
// Find what dir it was in
|
// Find what dir it was in
|
||||||
Directory dir;
|
QHash<QString, DirData>::const_iterator it = subdir_mapping_.constFind(subdir);
|
||||||
foreach (const DirData& info, watched_dirs_) {
|
if (it == subdir_mapping_.constEnd()) {
|
||||||
if (subdir.startsWith(info.dir.path))
|
return;
|
||||||
dir = info.dir;
|
|
||||||
}
|
}
|
||||||
|
Directory dir = it->dir;
|
||||||
|
|
||||||
qLog(Debug) << "Subdir" << subdir << "changed under directory" << dir.path << "id" << dir.id;
|
qLog(Debug) << "Subdir" << subdir << "changed under directory" << dir.path << "id" << dir.id;
|
||||||
|
|
||||||
@ -700,7 +701,7 @@ void LibraryWatcher::ReloadSettings() {
|
|||||||
foreach (const DirData& data, watched_dirs_.values()) {
|
foreach (const DirData& data, watched_dirs_.values()) {
|
||||||
SubdirectoryList subdirs = backend_->SubdirsInDirectory(data.dir.id);
|
SubdirectoryList subdirs = backend_->SubdirsInDirectory(data.dir.id);
|
||||||
foreach (const Subdirectory& subdir, subdirs) {
|
foreach (const Subdirectory& subdir, subdirs) {
|
||||||
AddWatch(subdir.path);
|
AddWatch(data, subdir.path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
#include "directory.h"
|
#include "directory.h"
|
||||||
#include "core/song.h"
|
#include "core/song.h"
|
||||||
|
|
||||||
|
#include <QHash>
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QStringList>
|
#include <QStringList>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
@ -140,13 +141,18 @@ class LibraryWatcher : public QObject {
|
|||||||
ScanTransaction* t, bool force_noincremental = false);
|
ScanTransaction* t, bool force_noincremental = false);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
// One of these gets stored for each Directory we're watching
|
||||||
|
struct DirData {
|
||||||
|
Directory dir;
|
||||||
|
};
|
||||||
|
|
||||||
static bool FindSongByPath(const SongList& list, const QString& path, Song* out);
|
static bool FindSongByPath(const SongList& list, const QString& path, Song* out);
|
||||||
inline static QString NoExtensionPart( const QString &fileName );
|
inline static QString NoExtensionPart( const QString &fileName );
|
||||||
inline static QString ExtensionPart( const QString &fileName );
|
inline static QString ExtensionPart( const QString &fileName );
|
||||||
inline static QString DirectoryPart( const QString &fileName );
|
inline static QString DirectoryPart( const QString &fileName );
|
||||||
QString PickBestImage(const QStringList& images);
|
QString PickBestImage(const QStringList& images);
|
||||||
QString ImageForSong(const QString& path, QMap<QString, QStringList>& album_art);
|
QString ImageForSong(const QString& path, QMap<QString, QStringList>& album_art);
|
||||||
void AddWatch(const QString& path);
|
void AddWatch(DirData dir, const QString& path);
|
||||||
uint GetMtimeForCue(const QString& cue_path);
|
uint GetMtimeForCue(const QString& cue_path);
|
||||||
void PerformScan(bool incremental, bool ignore_mtimes);
|
void PerformScan(bool incremental, bool ignore_mtimes);
|
||||||
|
|
||||||
@ -171,16 +177,12 @@ class LibraryWatcher : public QObject {
|
|||||||
const QString& matching_cue, QSet<QString>* cues_processed);
|
const QString& matching_cue, QSet<QString>* cues_processed);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// One of these gets stored for each Directory we're watching
|
|
||||||
struct DirData {
|
|
||||||
Directory dir;
|
|
||||||
};
|
|
||||||
|
|
||||||
LibraryBackend* backend_;
|
LibraryBackend* backend_;
|
||||||
TaskManager* task_manager_;
|
TaskManager* task_manager_;
|
||||||
QString device_name_;
|
QString device_name_;
|
||||||
|
|
||||||
FileSystemWatcherInterface* fs_watcher_;
|
FileSystemWatcherInterface* fs_watcher_;
|
||||||
|
QHash<QString, DirData> subdir_mapping_;
|
||||||
|
|
||||||
/* A list of words use to try to identify the (likely) best image
|
/* A list of words use to try to identify the (likely) best image
|
||||||
* found in an directory to use as cover artwork.
|
* found in an directory to use as cover artwork.
|
||||||
@ -203,10 +205,6 @@ class LibraryWatcher : public QObject {
|
|||||||
CueParser* cue_parser_;
|
CueParser* cue_parser_;
|
||||||
|
|
||||||
static QStringList sValidImages;
|
static QStringList sValidImages;
|
||||||
|
|
||||||
#ifdef Q_OS_DARWIN
|
|
||||||
static const int kMaxWatches = 100;
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline QString LibraryWatcher::NoExtensionPart( const QString &fileName ) {
|
inline QString LibraryWatcher::NoExtensionPart( const QString &fileName ) {
|
||||||
|
Loading…
Reference in New Issue
Block a user