Browse Source

- Added some more function for rss feeds grouping

adaptive-webui-19844
Christophe Dumez 15 years ago
parent
commit
05569a5011
  1. 29
      src/rss.cpp
  2. 6
      src/rss.h

29
src/rss.cpp

@ -104,6 +104,7 @@ RssFolder* RssFolder::addFolder(QStringList full_path) { @@ -104,6 +104,7 @@ RssFolder* RssFolder::addFolder(QStringList full_path) {
Q_ASSERT(!this->contains(name));
RssFolder *subfolder = new RssFolder(this, rssmanager, BTSession, name);
(*this)[name] = subfolder;
return subfolder;
} else {
QString subfolder_name = full_path.takeFirst();
// Check if the subfolder exists and create it if it does not
@ -291,6 +292,26 @@ QList<RssStream*> RssFolder::getAllFeeds() const { @@ -291,6 +292,26 @@ QList<RssStream*> RssFolder::getAllFeeds() const {
return streams;
}
void RssFolder::removeFileRef(RssFile* item) {
if(item->getType() == RssFile::STREAM) {
Q_ASSERT(this->contains(((RssStream*)item)->getUrl()));
this->remove(((RssStream*)item)->getUrl());
} else {
Q_ASSERT(this->contains(((RssFolder*)item)->getName()));
this->remove(((RssFolder*)item)->getName());
}
}
void RssFolder::addFile(RssFile * item) {
if(item->getType() == RssFile::STREAM) {
Q_ASSERT(!this->contains(((RssStream*)item)->getUrl()));
(*this)[((RssStream*)item)->getUrl()] = item;
} else {
Q_ASSERT(!this->contains(((RssFolder*)item)->getName()));
(*this)[((RssFolder*)item)->getName()] = item;
}
}
/** RssManager **/
RssManager::RssManager(bittorrent *BTSession): RssFolder(0, this, BTSession, QString::null) {
@ -337,6 +358,14 @@ void RssManager::forwardFeedIconChanged(QString url, QString icon_path) { @@ -337,6 +358,14 @@ void RssManager::forwardFeedIconChanged(QString url, QString icon_path) {
emit feedIconChanged(url, icon_path);
}
void RssManager::moveFile(QStringList old_path, QStringList new_path) {
RssFile* item = getFile(old_path);
RssFolder* src_folder = item->getParent();
QString new_name = new_path.takeLast();
RssFolder* dest_folder = (RssFolder*)getFile(new_path);
dest_folder->addFile(item);
src_folder->removeFileRef(item);
}
void RssManager::saveStreamList(){
QList<QPair<QString, QString> > streamsList;

6
src/rss.h

@ -91,6 +91,7 @@ public: @@ -91,6 +91,7 @@ public:
virtual QString getName() const = 0;
virtual void rename(QStringList path, QString new_name) = 0;
virtual void markAllAsRead() = 0;
virtual RssFolder* getParent() = 0;
};
// Item of a rss stream, single information
@ -388,6 +389,7 @@ public slots: @@ -388,6 +389,7 @@ public slots:
public:
RssStream(RssFolder* parent, RssManager *rssmanager, bittorrent *BTSession, QString _url);
~RssStream();
RssFolder* getParent() { return parent; }
FileType getType() const;
void refresh();
QStringList getPath() const;
@ -434,6 +436,7 @@ private: @@ -434,6 +436,7 @@ private:
public:
RssFolder(RssFolder *parent, RssManager *rssmanager, bittorrent *BTSession, QString name);
~RssFolder();
RssFolder* getParent() { return parent; }
unsigned int getNbUnRead() const;
FileType getType() const;
RssStream* addStream(QStringList full_path);
@ -448,6 +451,8 @@ public: @@ -448,6 +451,8 @@ public:
public slots:
void refreshAll();
void removeFileRef(RssFile* item);
void addFile(RssFile * item);
void removeFile(QStringList full_path);
void refresh(QStringList full_path);
void processFinishedDownload(QString url, QString path);
@ -473,6 +478,7 @@ public slots: @@ -473,6 +478,7 @@ public slots:
void saveStreamList();
void forwardFeedInfosChanged(QString url, QString aliasOrUrl, unsigned int nbUnread);
void forwardFeedIconChanged(QString url, QString icon_path);
void moveFile(QStringList old_path, QStringList new_path);
public:
RssManager(bittorrent *BTSession);

Loading…
Cancel
Save