summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGluzskiy Alexandr <sss@sss.chaoslab.ru>2018-01-12 14:10:50 +0300
committerGluzskiy Alexandr <sss@sss.chaoslab.ru>2018-01-12 14:10:50 +0300
commitfc7664eebedf663b000fe74244154d0e2e57dbcb (patch)
tree490f713a79e6fd993b50e846da7b875a91819179
parent75edf9a8cdef1e5e92892fd6b81f83537437ae67 (diff)
retroshare: icon cache for filetransfers dialog
-rw-r--r--net-p2p/retroshare/files/ft_icon_cache.patch122
-rw-r--r--net-p2p/retroshare/retroshare-scm.ebuild1
2 files changed, 123 insertions, 0 deletions
diff --git a/net-p2p/retroshare/files/ft_icon_cache.patch b/net-p2p/retroshare/files/ft_icon_cache.patch
new file mode 100644
index 0000000..e0ba274
--- /dev/null
+++ b/net-p2p/retroshare/files/ft_icon_cache.patch
@@ -0,0 +1,122 @@
+diff --git a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp
+index 196bc90ac..e09c5020b 100644
+--- a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp
++++ b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp
+@@ -966,7 +966,7 @@ int TransfersDialog::addDLItem(int row, const FileInfo &fileInfo)
+ QString fileName = QString::fromUtf8(fileInfo.fname.c_str());
+
+ DLListModel->setData(DLListModel->index(row, COLUMN_NAME), fileName);
+- DLListModel->setData(DLListModel->index(row, COLUMN_NAME), FilesDefs::getIconFromFilename(fileName), Qt::DecorationRole);
++ DLListModel->setData(DLListModel->index(row, COLUMN_NAME), icon_cache.get_icon(fileName), Qt::DecorationRole);
+
+ DLListModel->setData(DLListModel->index(row, COLUMN_COMPLETED), QVariant((qlonglong)completed));
+ DLListModel->setData(DLListModel->index(row, COLUMN_DLSPEED), QVariant((double)fileDlspeed));
+@@ -1166,7 +1166,7 @@ int TransfersDialog::addULItem(int row, const FileInfo &fileInfo)
+ //ULListModel->setItem(row, COLUMN_UPROGRESS, new ProgressItem(NULL));
+
+ ULListModel->setData(ULListModel->index(row, COLUMN_UNAME), fileName);
+- ULListModel->setData(ULListModel->index(row, COLUMN_UNAME), FilesDefs::getIconFromFilename(fileName), Qt::DecorationRole);
++ ULListModel->setData(ULListModel->index(row, COLUMN_UNAME), icon_cache.get_icon((fileName)), Qt::DecorationRole);
+ ULListModel->setData(ULListModel->index(row, COLUMN_UHASH), fileHash);
+ ULListModel->setData(ULListModel->index(row, COLUMN_UHASH), fileHash, Qt::UserRole);
+ }
+@@ -2288,3 +2288,65 @@ void TransfersDialog::filterChanged(const QString& /*text*/)
+ DLLFilterModel->setFilterKeyColumn(filterColumn);
+ DLLFilterModel->setFilterRegExp(text);
+ }
++
++//shitcode begin
++
++TransfersDialog_dirty_icon_cache::TransfersDialog_dirty_icon_cache() :
++ FileTypePicture(":/images/FileTypePicture.png"), FileTypeVideo(":/images/FileTypeVideo.png"), FileTypeAudio(":/images/FileTypeAudio.png"),
++ FileTypeArchive(":/images/FileTypeArchive.png"), FileTypeProgram(":/images/FileTypeProgram.png"), FileTypeCDImage(":/images/FileTypeCDImage.png"),
++ FileTypeDocument(":/images/FileTypeDocument.png"), pdf(":/images/mimetypes/pdf.png"), rscollection_16(":/images/mimetypes/rscollection-16.png"),
++ FileTypeAny(":/images/FileTypeAny.png"), patch(":/images/mimetypes/patch.png"), source_cpp(":/images/mimetypes/source_cpp.png"),
++ source_h(":/images/mimetypes/source_h.png"), source_c(":/images/mimetypes/source_c.png")
++{
++}
++
++QIcon& TransfersDialog_dirty_icon_cache::get_icon(const QString& filename)
++{
++ //mostly copypaste from static QString getInfoFromFilename(const QString& filename, bool anyForUnknown, bool image)
++ QString ext = QFileInfo(filename).suffix().toLower();
++
++ if (ext == "jpg" || ext == "jpeg" || ext == "tif" || ext == "tiff" || ext == "png" || ext == "gif" || ext == "bmp" || ext == "ico" || ext == "svg") {
++ return FileTypePicture;
++ } else if (ext == "avi" || ext == "mpg" || ext == "mpeg" || ext == "wmv" || ext == "divx" || ext == "ts" ||
++ ext == "mkv" || ext == "mp4" || ext == "flv" || ext == "mov" || ext == "asf" || ext == "xvid" ||
++ ext == "vob" || ext == "qt" || ext == "rm" || ext == "3gp" || ext == "ogm") {
++ return FileTypeVideo;
++ } else if (ext == "ogg" || ext == "mp3" || ext == "mp1" || ext == "mp2" || ext == "wav" || ext == "wma" || ext == "m4a" || ext == "flac" ||ext == "xpm") {
++ return FileTypeAudio;
++ } else if (ext == "tar" || ext == "bz2" || ext == "zip" || ext == "gz" || ext == "7z" || ext == "msi" ||
++ ext == "rar" || ext == "rpm" || ext == "ace" || ext == "jar" || ext == "tgz" || ext == "lha" ||
++ ext == "cab" || ext == "cbz"|| ext == "cbr" || ext == "alz" || ext == "sit" || ext == "arj" || ext == "deb") {
++ return FileTypeArchive;
++ } else if (ext == "app" || ext == "bat" || ext == "cgi" || ext == "com" ||
++ ext == "exe" || ext == "js" || ext == "pif" ||
++ ext == "py" || ext == "pl" || ext == "sh" || ext == "vb" || ext == "ws") {
++ return FileTypeProgram;
++ } else if (ext == "iso" || ext == "nrg" || ext == "mdf" || ext == "img" || ext == "dmg" || ext == "bin" || ext == "uif") {
++ return FileTypeCDImage;
++ } else if (ext == "txt" || ext == "ui" ||
++ ext == "doc" || ext == "rtf" || ext == "sxw" || ext == "xls" || ext == "pps" || ext == "xml" || ext == "nfo" ||
++ ext == "reg" || ext == "sxc" || ext == "odt" || ext == "ods" || ext == "dot" || ext == "ppt" || ext == "css" || ext == "crt" ||
++ ext == "html" || ext == "htm" || ext == "php") {
++ return FileTypeDocument;
++ } else if (ext == "pdf") {
++ return pdf;
++ } else if (ext == RsCollection::ExtensionString) {
++ return rscollection_16;
++ } else if (ext == "sub" || ext == "srt") {
++ return FileTypeAny;
++ } else if (ext == "nds") {
++ return FileTypeAny;
++ } else if (ext == "patch" || ext == "diff") {
++ return patch;
++ } else if (ext == "cpp") {
++ return source_cpp;
++ } else if (ext == "h") {
++ return source_h;
++ } else if (ext == "c") {
++ return source_c;
++ }
++
++ return FileTypeAny;
++}
++
++//shitcode end
+diff --git a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h
+index 30efe212d..2cb5877f2 100644
+--- a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h
++++ b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h
+@@ -45,6 +45,20 @@ class SearchDialog;
+ class LocalSharedFilesDialog;
+ class RemoteSharedFilesDialog;
+
++
++//shitcode begin
++class TransfersDialog_dirty_icon_cache
++{
++public:
++ TransfersDialog_dirty_icon_cache();
++ QIcon& get_icon(const QString& filename);
++private:
++ QIcon FileTypePicture, FileTypeVideo, FileTypeAudio, FileTypeArchive, FileTypeProgram, FileTypeCDImage, FileTypeDocument, \
++ pdf, rscollection_16, FileTypeAny, patch, source_cpp, source_h, source_c;
++};
++
++//shitcode end
++
+ class TransfersDialog : public RsAutoUpdatePage
+ {
+ Q_OBJECT
+@@ -247,6 +261,8 @@ private:
+
+ QTreeView *downloadList;
+
++ TransfersDialog_dirty_icon_cache icon_cache;
++
+ /** Adds a new action to the toolbar. */
+ void addAction(QAction *action, const char *slot = 0);
+
diff --git a/net-p2p/retroshare/retroshare-scm.ebuild b/net-p2p/retroshare/retroshare-scm.ebuild
index ac96b7b..374f485 100644
--- a/net-p2p/retroshare/retroshare-scm.ebuild
+++ b/net-p2p/retroshare/retroshare-scm.ebuild
@@ -83,6 +83,7 @@ PATCHES=(
"${FILESDIR}/hidden_service.patch"
"${FILESDIR}/cflags.patch"
"${FILESDIR}/disable_key_array_redraw.patch"
+ "${FILESDIR}/ft_icon_cache.patch"
)