diff options
author | Gluzskiy Alexandr <sss@sss.chaoslab.ru> | 2018-02-12 10:04:58 +0300 |
---|---|---|
committer | Gluzskiy Alexandr <sss@sss.chaoslab.ru> | 2018-02-12 10:04:58 +0300 |
commit | 51d18c9e43f395b67d03c6cb534284a2319a5845 (patch) | |
tree | 0ef4874d2ccd9afbae9ba6f53fdc636ca1ccdaf6 | |
parent | 40063eb85691fbeb592bb1adbf3729f9f556f310 (diff) |
retroshare: new filetransfers ui code merged by upstream
-rw-r--r-- | net-p2p/retroshare/files/rs-ft-1169.diff | 1177 | ||||
-rw-r--r-- | net-p2p/retroshare/retroshare-scm.ebuild | 1 |
2 files changed, 0 insertions, 1178 deletions
diff --git a/net-p2p/retroshare/files/rs-ft-1169.diff b/net-p2p/retroshare/files/rs-ft-1169.diff deleted file mode 100644 index 1896f9b..0000000 --- a/net-p2p/retroshare/files/rs-ft-1169.diff +++ /dev/null @@ -1,1177 +0,0 @@ -diff --git a/RetroShare.pro b/RetroShare.pro -index 833173029..dba75453e 100644 ---- a/RetroShare.pro -+++ b/RetroShare.pro -@@ -56,12 +56,12 @@ retroshare_qml_app { - } - } - --retroshare_plugins { -- SUBDIRS += plugins -- plugins.file = plugins/plugins.pro -- plugins.depends = retroshare_gui -- plugins.target = plugins --} -+#retroshare_plugins { -+# SUBDIRS += plugins -+# plugins.file = plugins/plugins.pro -+# plugins.depends = retroshare_gui -+# plugins.target = plugins -+#} - - wikipoos { - SUBDIRS += pegmarkdown -diff --git a/libresapi/src/api/FileSharingHandler.cpp b/libresapi/src/api/FileSharingHandler.cpp -index 856275d9c..a6296973d 100644 ---- a/libresapi/src/api/FileSharingHandler.cpp -+++ b/libresapi/src/api/FileSharingHandler.cpp -@@ -500,7 +500,7 @@ void FileSharingHandler::handleDownload(Request& req, Response& resp) - FileInfo finfo; - mRsFiles->FileDetails(hash, RS_FILE_HINTS_REMOTE, finfo); - -- for(std::list<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) -+ for(std::vector<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) - srcIds.push_back((*it).peerId); - - if(!mRsFiles->FileRequest(name, hash, static_cast<uint64_t>(size), "", -diff --git a/libresapi/src/api/TransfersHandler.cpp b/libresapi/src/api/TransfersHandler.cpp -index f563f377c..c696411da 100644 ---- a/libresapi/src/api/TransfersHandler.cpp -+++ b/libresapi/src/api/TransfersHandler.cpp -@@ -91,7 +91,7 @@ void TransfersHandler::handleControlDownload(Request &req, Response &resp) - FileInfo finfo; - mFiles->FileDetails(hash, RS_FILE_HINTS_REMOTE, finfo); - -- for(std::list<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) -+ for(std::vector<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) - srcIds.push_back((*it).peerId); - - bool ok = req.mStream.isOK(); -@@ -213,8 +213,7 @@ void TransfersHandler::handleUploads(Request & /* req */, Response &resp) - FileInfo fi; - if(mFiles->FileDetails(*lit, RS_FILE_HINTS_UPLOAD, fi)) - { -- std::list<TransferInfo>::iterator pit; -- for(pit = fi.peers.begin(); pit != fi.peers.end(); ++pit) -+ for( std::vector<TransferInfo>::iterator pit = fi.peers.begin(); pit != fi.peers.end(); ++pit) - { - if (pit->peerId == ownId) //don't display transfer to ourselves - continue ; -diff --git a/libretroshare/src/ft/ftcontroller.cc b/libretroshare/src/ft/ftcontroller.cc -index 382d13cb6..29713cb3e 100644 ---- a/libretroshare/src/ft/ftcontroller.cc -+++ b/libretroshare/src/ft/ftcontroller.cc -@@ -301,7 +301,7 @@ void ftController::searchForDirectSources() - FileInfo info ; // Info needs to be re-allocated each time, to start with a clear list of peers (it's not cleared down there) - - if( mSearch->search(it->first, RS_FILE_HINTS_REMOTE | RS_FILE_HINTS_SPEC_ONLY, info) ) -- for( std::list<TransferInfo>::const_iterator pit = info.peers.begin(); pit != info.peers.end(); ++pit ) -+ for( std::vector<TransferInfo>::const_iterator pit = info.peers.begin(); pit != info.peers.end(); ++pit ) - { - bool bAllowDirectDL = false; - switch (mFilePermDirectDLPolicy) { -@@ -1029,7 +1029,7 @@ bool ftController::FileRequest(const std::string& fname, const RsFileHash& hash - } - - std::list<RsPeerId>::const_iterator it; -- std::list<TransferInfo>::const_iterator pit; -+ std::vector<TransferInfo>::const_iterator pit; - - #ifdef CONTROL_DEBUG - std::cerr << "ftController::FileRequest(" << fname << ","; -@@ -1622,6 +1622,8 @@ bool ftController::FileDetails(const RsFileHash &hash, FileInfo &info) - bool isDownloading = false; - bool isSuspended = false; - -+ info.peers.clear(); -+ - for(pit = peerIds.begin(); pit != peerIds.end(); ++pit) - { - if (it->second->mTransfer->getPeerState(*pit, state, tfRate)) -diff --git a/libretroshare/src/retroshare/rstypes.h b/libretroshare/src/retroshare/rstypes.h -index 9c098db59..cc04d2312 100644 ---- a/libretroshare/src/retroshare/rstypes.h -+++ b/libretroshare/src/retroshare/rstypes.h -@@ -208,7 +208,7 @@ class FileInfo - uint64_t transfered; - double tfRate; /* in kbytes */ - uint32_t downloadStatus; // FT_STATE_DOWNLOADING & co. See rstypes.h -- std::list<TransferInfo> peers; -+ std::vector<TransferInfo> peers; - - DwlSpeed priority ; - time_t lastTS; -diff --git a/retroshare-gui/src/gui/FileTransfer/DLListDelegate.h b/retroshare-gui/src/gui/FileTransfer/DLListDelegate.h -index 7516b17af..11bfd149f 100644 ---- a/retroshare-gui/src/gui/FileTransfer/DLListDelegate.h -+++ b/retroshare-gui/src/gui/FileTransfer/DLListDelegate.h -@@ -27,26 +27,25 @@ -
-
- // Defines for download list list columns
--#define COLUMN_NAME 0
--#define COLUMN_SIZE 1
--#define COLUMN_COMPLETED 2
--#define COLUMN_DLSPEED 3
--#define COLUMN_PROGRESS 4
--#define COLUMN_SOURCES 5
--#define COLUMN_STATUS 6
--#define COLUMN_PRIORITY 7
--#define COLUMN_REMAINING 8
-+#define COLUMN_NAME 0
-+#define COLUMN_SIZE 1
-+#define COLUMN_COMPLETED 2
-+#define COLUMN_DLSPEED 3
-+#define COLUMN_PROGRESS 4
-+#define COLUMN_SOURCES 5
-+#define COLUMN_STATUS 6
-+#define COLUMN_PRIORITY 7
-+#define COLUMN_REMAINING 8
- #define COLUMN_DOWNLOADTIME 9
--#define COLUMN_ID 10
--#define COLUMN_LASTDL 11
--#define COLUMN_PATH 12
--#define COLUMN_COUNT 13
--
--#define PRIORITY_NULL 0.0
--#define PRIORITY_FASTER 0.1
--#define PRIORITY_AVERAGE 0.2
--#define PRIORITY_SLOWER 0.3
--
-+#define COLUMN_ID 10
-+#define COLUMN_LASTDL 11
-+#define COLUMN_PATH 12
-+#define COLUMN_COUNT 13
-+
-+#define PRIORITY_NULL 0.0
-+#define PRIORITY_FASTER 0.1
-+#define PRIORITY_AVERAGE 0.2
-+#define PRIORITY_SLOWER 0.3
-
- #define MAX_CHAR_TMP 128
-
-diff --git a/retroshare-gui/src/gui/FileTransfer/SearchDialog.cpp b/retroshare-gui/src/gui/FileTransfer/SearchDialog.cpp -index ee85a1d92..bc2f08644 100644 ---- a/retroshare-gui/src/gui/FileTransfer/SearchDialog.cpp -+++ b/retroshare-gui/src/gui/FileTransfer/SearchDialog.cpp -@@ -368,7 +368,7 @@ void SearchDialog::getSourceFriendsForHash(const RsFileHash& hash,std::list<RsPe - FileInfo finfo ; - rsFiles->FileDetails(hash, RS_FILE_HINTS_REMOTE,finfo) ; - -- for(std::list<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) -+ for(std::vector<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) - { - std::cerr << " adding peerid " << (*it).peerId << std::endl ; - srcIds.push_back((*it).peerId) ; -diff --git a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp -index 196bc90ac..5cda97e5c 100644 ---- a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp -+++ b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.cpp -@@ -76,10 +76,10 @@ - #define IMAGE_STOP ":/images/stop.png" - #define IMAGE_PREVIEW ":/images/preview.png" - #define IMAGE_PRIORITY ":/images/filepriority.png" --#define IMAGE_PRIORITYLOW ":/images/prioritylow.png" --#define IMAGE_PRIORITYNORMAL ":/images/prioritynormal.png" --#define IMAGE_PRIORITYHIGH ":/images/priorityhigh.png" --#define IMAGE_PRIORITYAUTO ":/images/priorityauto.png" -+#define IMAGE_PRIORITYLOW ":/images/prioritylow.png" -+#define IMAGE_PRIORITYNORMAL ":/images/prioritynormal.png" -+#define IMAGE_PRIORITYHIGH ":/images/priorityhigh.png" -+#define IMAGE_PRIORITYAUTO ":/images/priorityauto.png" - #define IMAGE_SEARCH ":/icons/svg/magnifying-glass.svg" - #define IMAGE_EXPAND ":/images/edit_add24.png" - #define IMAGE_COLLAPSE ":/images/edit_remove24.png" -@@ -98,6 +98,591 @@ - - Q_DECLARE_METATYPE(FileProgressInfo) - -+class RsDownloadListModel : public QAbstractItemModel -+{ -+ // Q_OBJECT -+ -+public: -+ explicit RsDownloadListModel(QObject *parent = NULL) : QAbstractItemModel(parent) {} -+ ~RsDownloadListModel(){} -+ -+ enum Roles{ SortRole = Qt::UserRole+1 }; -+ -+ int rowCount(const QModelIndex& parent = QModelIndex()) const -+ { -+ void *ref = (parent.isValid())?parent.internalPointer():NULL ; -+ -+ if(!ref) -+ return mDownloads.size() ; -+ -+ uint32_t entry = 0 ; -+ int source_id ; -+ -+ if(!convertRefPointerToTabEntry(ref,entry,source_id) || entry >= mDownloads.size()) -+ return 0 ; -+ -+ return mDownloads[entry].peers.size(); // costly -+ } -+ int columnCount(const QModelIndex &parent = QModelIndex()) const -+ { -+ return 13 ; -+ } -+ bool hasChildren(const QModelIndex &parent = QModelIndex()) const -+ { -+ void *ref = (parent.isValid())?parent.internalPointer():NULL ; -+ uint32_t entry = 0; -+ int source_id=0 ; -+ -+ if(!ref) -+ return true ; -+ -+ if(!convertRefPointerToTabEntry(ref,entry,source_id) || entry >= mDownloads.size() || source_id > -1) -+ return false ; -+ -+ return !mDownloads[entry].peers.empty(); // costly -+ } -+ -+ QModelIndex index(int row, int column, const QModelIndex & parent = QModelIndex()) const -+ { -+ if(row < 0) -+ return QModelIndex(); -+ -+ void *ref = (parent.isValid())?parent.internalPointer():NULL ; -+ uint32_t entry = 0; -+ int source_id=0 ; -+ void *subref = NULL ; -+ -+ if(!ref) // top level. The entry is that of a transfer -+ { -+ if(!convertTabEntryToRefPointer(row,-1,subref)) -+ return QModelIndex() ; -+ -+ return createIndex(row,column,subref) ; -+ } -+ -+ if(!convertRefPointerToTabEntry(ref,entry,source_id) || entry >= mDownloads.size() || int(mDownloads[entry].peers.size()) <= source_id) -+ return QModelIndex() ; -+ -+ if(source_id != -1) -+ std::cerr << "ERROR: parent.source_id != -1 in index()" << std::endl; -+ -+ if(!convertTabEntryToRefPointer(entry,row,subref)) -+ return QModelIndex() ; -+ -+ return createIndex(row,column,subref) ; -+ } -+ QModelIndex parent(const QModelIndex& child) const -+ { -+ void *ref = (child.isValid())?child.internalPointer():NULL ; -+ uint32_t entry = 0; -+ int source_id=0 ; -+ -+ if(!ref) -+ return QModelIndex() ; -+ -+ if(!convertRefPointerToTabEntry(ref,entry,source_id) || entry >= mDownloads.size() || int(mDownloads[entry].peers.size()) <= source_id) -+ return QModelIndex() ; -+ -+ if(source_id < 0) -+ return QModelIndex() ; -+ -+ void *subref =NULL; -+ -+ if(!convertTabEntryToRefPointer(entry,-1,subref)) -+ return QModelIndex() ; -+ -+ return createIndex(entry,0,subref) ; -+ } -+ -+ QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const -+ { -+ if(role != Qt::DisplayRole) -+ return QVariant(); -+ -+ switch(section) -+ { -+ default: -+ case COLUMN_NAME: return tr("Name", "i.e: file name"); -+ case COLUMN_SIZE: return tr("Size", "i.e: file size"); -+ case COLUMN_COMPLETED: return tr("Completed", ""); -+ case COLUMN_DLSPEED: return tr("Speed", "i.e: Download speed"); -+ case COLUMN_PROGRESS: return tr("Progress / Availability", "i.e: % downloaded"); -+ case COLUMN_SOURCES: return tr("Sources", "i.e: Sources"); -+ case COLUMN_STATUS: return tr("Status"); -+ case COLUMN_PRIORITY: return tr("Speed / Queue position"); -+ case COLUMN_REMAINING: return tr("Remaining"); -+ case COLUMN_DOWNLOADTIME: return tr("Download time", "i.e: Estimated Time of Arrival / Time left"); -+ case COLUMN_ID: return tr("Hash"); -+ case COLUMN_LASTDL: return tr("Last Time Seen", "i.e: Last Time Receiced Data"); -+ case COLUMN_PATH: return tr("Path", "i.e: Where file is saved"); -+ } -+ } -+ -+ QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const -+ { -+ if(!index.isValid()) -+ return QVariant(); -+ -+ int coln = index.column() ; -+ -+ switch(role) -+ { -+ case Qt::SizeHintRole: return sizeHintRole(index.column()) ; -+ case Qt::TextAlignmentRole: -+ case Qt::TextColorRole: -+ case Qt::WhatsThisRole: -+ case Qt::EditRole: -+ case Qt::ToolTipRole: -+ case Qt::StatusTipRole: -+ return QVariant(); -+ } -+ -+ void *ref = (index.isValid())?index.internalPointer():NULL ; -+ uint32_t entry = 0; -+ int source_id=0 ; -+ -+ if(!ref) -+ return false ; -+ -+ if(!convertRefPointerToTabEntry(ref,entry,source_id) || entry >= mDownloads.size()) -+ { -+ std::cerr << "Bad pointer: " << (void*)ref << std::endl; -+ return false ; -+ } -+ -+ const FileInfo& finfo(mDownloads[entry]) ; -+ -+ switch(role) -+ { -+ case Qt::DisplayRole: return displayRole (finfo,source_id,index.column()) ; -+ case Qt::DecorationRole: return decorationRole(finfo,source_id,index.column()) ; -+ case Qt::UserRole: return userRole (finfo,source_id,index.column()) ; -+ default: -+ return QVariant(); -+ } -+ } -+ -+ QVariant sizeHintRole(int col) const -+ { -+ switch(col) -+ { -+ default: -+ case COLUMN_NAME: return QVariant( 170 ); -+ case COLUMN_SIZE: return QVariant( 70 ); -+ case COLUMN_COMPLETED: return QVariant( 75 ); -+ case COLUMN_DLSPEED: return QVariant( 75 ); -+ case COLUMN_PROGRESS: return QVariant( 170 ); -+ case COLUMN_SOURCES: return QVariant( 90 ); -+ case COLUMN_STATUS: return QVariant( 100 ); -+ case COLUMN_PRIORITY: return QVariant( 100 ); -+ case COLUMN_REMAINING: return QVariant( 100 ); -+ case COLUMN_DOWNLOADTIME: return QVariant( 100 ); -+ case COLUMN_ID: return QVariant( 100 ); -+ case COLUMN_LASTDL: return QVariant( 100 ); -+ case COLUMN_PATH: return QVariant( 100 ); -+ } -+ } -+ -+ -+ QVariant displayRole(const FileInfo& fileInfo,int source_id,int col) const -+ { -+ if(source_id == -1) // toplevel -+ switch(col) -+ { -+ case COLUMN_NAME: return QVariant(QString::fromUtf8(fileInfo.fname.c_str())); -+ case COLUMN_COMPLETED: return QVariant((qlonglong)fileInfo.transfered); -+ case COLUMN_DLSPEED: return QVariant((double)((fileInfo.downloadStatus == FT_STATE_DOWNLOADING) ? (fileInfo.tfRate * 1024.0) : 0.0)); -+ case COLUMN_PROGRESS: return QVariant((float)((fileInfo.size == 0) ? 0 : (fileInfo.transfered * 100.0 / (float)fileInfo.size))); -+ case COLUMN_STATUS: -+ { -+ QString status; -+ switch (fileInfo.downloadStatus) -+ { -+ case FT_STATE_FAILED: status = tr("Failed"); break; -+ case FT_STATE_OKAY: status = tr("Okay"); break; -+ case FT_STATE_WAITING: status = tr("Waiting"); break; -+ case FT_STATE_DOWNLOADING: status = tr("Downloading"); break; -+ case FT_STATE_COMPLETE: status = tr("Complete"); break; -+ case FT_STATE_QUEUED: status = tr("Queued"); break; -+ case FT_STATE_PAUSED: status = tr("Paused"); break; -+ case FT_STATE_CHECKING_HASH:status = tr("Checking..."); break; -+ default: status = tr("Unknown"); break; -+ } -+ return QVariant(status); -+ } -+ -+ case COLUMN_PRIORITY: -+ { -+ double priority = PRIORITY_NULL; -+ -+ if (fileInfo.downloadStatus == FT_STATE_QUEUED) -+ priority = fileInfo.queue_position; -+ else if (fileInfo.downloadStatus == FT_STATE_COMPLETE) -+ priority = 0; -+ else -+ switch (fileInfo.priority) -+ { -+ case SPEED_LOW: priority = PRIORITY_SLOWER; break; -+ case SPEED_NORMAL: priority = PRIORITY_AVERAGE; break; -+ case SPEED_HIGH: priority = PRIORITY_FASTER; break; -+ default: priority = PRIORITY_AVERAGE; break; -+ } -+ -+ return QVariant(priority); -+ } -+ -+ case COLUMN_REMAINING: return QVariant((qlonglong)(fileInfo.size - fileInfo.transfered)); -+ case COLUMN_DOWNLOADTIME: return QVariant((qlonglong)(fileInfo.tfRate > 0)?( (fileInfo.size - fileInfo.transfered) / (fileInfo.tfRate * 1024.0) ) : 0); -+ case COLUMN_LASTDL: -+ { -+ qint64 qi64LastDL = fileInfo.lastTS ; -+ -+ if (qi64LastDL == 0) // file is complete, or any raison why the time has not been set properly -+ { -+ QFileInfo file; -+ -+ if (fileInfo.downloadStatus == FT_STATE_COMPLETE) -+ file = QFileInfo(QString::fromUtf8(fileInfo.path.c_str()), QString::fromUtf8(fileInfo.fname.c_str())); -+ else -+ file = QFileInfo(QString::fromUtf8(rsFiles->getPartialsDirectory().c_str()), QString::fromUtf8(fileInfo.hash.toStdString().c_str())); -+ -+ //Get Last Access on File -+ if (file.exists()) -+ qi64LastDL = file.lastModified().toTime_t(); -+ } -+ return QVariant(qi64LastDL) ; -+ } -+ case COLUMN_PATH: -+ { -+ QString strPath = QString::fromUtf8(fileInfo.path.c_str()); -+ QString strPathAfterDL = strPath; -+ strPathAfterDL.replace(QString::fromUtf8(rsFiles->getDownloadDirectory().c_str()),""); -+ -+ return QVariant(strPathAfterDL); -+ } -+ -+ case COLUMN_SOURCES: -+ { -+ int active = 0; -+ QString fileHash = QString::fromStdString(fileInfo.hash.toStdString()); -+ -+ if (fileInfo.downloadStatus != FT_STATE_COMPLETE) -+ for (std::vector<TransferInfo>::const_iterator pit = fileInfo.peers.begin() ; pit != fileInfo.peers.end(); ++pit) -+ { -+ const TransferInfo& transferInfo = *pit; -+ -+ // //unique combination: fileHash + peerId, variant: hash + peerName (too long) -+ // QString hashFileAndPeerId = fileHash + QString::fromStdString(transferInfo.peerId.toStdString()); -+ -+ // double peerDlspeed = 0; -+ // if ((uint32_t)transferInfo.status == FT_STATE_DOWNLOADING && fileInfo.downloadStatus != FT_STATE_PAUSED && fileInfo.downloadStatus != FT_STATE_COMPLETE) -+ // peerDlspeed = transferInfo.tfRate * 1024.0; -+ -+ // FileProgressInfo peerpinfo; -+ // peerpinfo.cmap = fcinfo.compressed_peer_availability_maps[transferInfo.peerId]; -+ // peerpinfo.type = FileProgressInfo::DOWNLOAD_SOURCE ; -+ // peerpinfo.progress = 0.0; // we don't display completion for sources. -+ // peerpinfo.nb_chunks = peerpinfo.cmap._map.empty() ? 0 : fcinfo.chunks.size(); -+ -+ // get the sources (number of online peers) -+ if (transferInfo.tfRate > 0 && fileInfo.downloadStatus == FT_STATE_DOWNLOADING) -+ ++active; -+ } -+ -+ return QVariant( (float)active + fileInfo.peers.size()/1000.0f ); -+ -+ } -+ -+ case COLUMN_SIZE: return QVariant((qlonglong) fileInfo.size); -+ -+ case COLUMN_ID: return QVariant(QString::fromStdString(fileInfo.hash.toStdString())); -+ -+ default: -+ return QVariant("[ TODO ]"); -+ } -+ else -+ { -+ uint32_t chunk_size = 1024*1024 ; -+ -+ switch(col) -+ { -+ default: -+ case COLUMN_SOURCES: -+ case COLUMN_COMPLETED: -+ case COLUMN_REMAINING: -+ case COLUMN_LASTDL: -+ case COLUMN_ID: -+ case COLUMN_PATH: -+ case COLUMN_DOWNLOADTIME: -+ case COLUMN_SIZE: return QVariant(); -+ case COLUMN_PROGRESS: return QVariant( (fileInfo.size>0)?((fileInfo.peers[source_id].transfered % chunk_size)*100.0/fileInfo.size):0.0) ; -+ case COLUMN_DLSPEED: -+ { -+ double peerDlspeed = 0; -+ if((uint32_t)fileInfo.peers[source_id].status == FT_STATE_DOWNLOADING && fileInfo.downloadStatus != FT_STATE_PAUSED && fileInfo.downloadStatus != FT_STATE_COMPLETE) -+ peerDlspeed = fileInfo.peers[source_id].tfRate * 1024.0; -+ -+ return QVariant((double)peerDlspeed) ; -+ } -+ case COLUMN_NAME: -+ { -+ QString iconName,tooltip; -+ return QVariant(TransfersDialog::getPeerName(fileInfo.peers[source_id].peerId, iconName, tooltip)); -+ } -+ -+ case COLUMN_PRIORITY: return QVariant((double)PRIORITY_NULL); -+ } -+ } -+ -+ return QVariant("[ERROR]"); -+ } -+ -+ virtual QVariant userRole(const FileInfo& fileInfo,int source_id,int col) const -+ { -+ if(source_id == -1) -+ switch(col) -+ { -+ case COLUMN_PROGRESS: -+ { -+ FileChunksInfo fcinfo; -+ if (!rsFiles->FileDownloadChunksDetails(fileInfo.hash, fcinfo)) -+ return -1; -+ -+ FileProgressInfo pinfo; -+ pinfo.cmap = fcinfo.chunks; -+ pinfo.type = FileProgressInfo::DOWNLOAD_LINE; -+ pinfo.progress = (fileInfo.size == 0) ? 0 : (fileInfo.transfered * 100.0 / fileInfo.size); -+ pinfo.nb_chunks = pinfo.cmap._map.empty() ? 0 : fcinfo.chunks.size(); -+ -+ for (uint32_t i = 0; i < fcinfo.chunks.size(); ++i) -+ switch(fcinfo.chunks[i]) -+ { -+ case FileChunksInfo::CHUNK_CHECKING: pinfo.chunks_in_checking.push_back(i); -+ break ; -+ case FileChunksInfo::CHUNK_ACTIVE: pinfo.chunks_in_progress.push_back(i); -+ break ; -+ case FileChunksInfo::CHUNK_DONE: -+ case FileChunksInfo::CHUNK_OUTSTANDING: -+ break ; -+ } -+ -+ return QVariant::fromValue(pinfo); -+ } -+ -+ case COLUMN_ID: return QVariant(QString::fromStdString(fileInfo.hash.toStdString())); -+ -+ -+ default: -+ return QVariant(); -+ } -+ else -+ switch(col) -+ { -+ case COLUMN_PROGRESS: -+ { -+ FileProgressInfo peerpinfo ; -+ -+ if(!rsFiles->FileUploadChunksDetails(fileInfo.hash, fileInfo.peers[source_id].peerId, peerpinfo.cmap) ) -+ return QVariant(); -+ -+ // Estimate the completion. We need something more accurate, meaning that we need to -+ // transmit the completion info. -+ // -+ uint32_t chunk_size = 1024*1024 ; -+ uint32_t nb_chunks = (uint32_t)((fileInfo.size + (uint64_t)chunk_size - 1) / (uint64_t)(chunk_size)) ; -+ -+ uint32_t filled_chunks = peerpinfo.cmap.filledChunks(nb_chunks) ; -+ peerpinfo.type = FileProgressInfo::UPLOAD_LINE ; -+ peerpinfo.nb_chunks = peerpinfo.cmap._map.empty()?0:nb_chunks ; -+ qlonglong completed ; -+ -+ if(filled_chunks > 0 && nb_chunks > 0) -+ { -+ completed = peerpinfo.cmap.computeProgress(fileInfo.size,chunk_size) ; -+ peerpinfo.progress = completed / (float)fileInfo.size * 100.0f ; -+ } -+ else -+ { -+ completed = fileInfo.peers[source_id].transfered % chunk_size ; // use the position with respect to last request. -+ peerpinfo.progress = (fileInfo.size>0)?((fileInfo.peers[source_id].transfered % chunk_size)*100.0/fileInfo.size):0 ; -+ } -+ -+ return QVariant::fromValue(peerpinfo); -+ } -+ -+ case COLUMN_ID: return QVariant(QString::fromStdString(fileInfo.hash.toStdString()) + QString::fromStdString(fileInfo.peers[source_id].peerId.toStdString())); -+ -+ default: -+ return QVariant(); -+ } -+ -+ } -+ -+ QVariant decorationRole(const FileInfo& fileInfo,int source_id,int col) const -+ { -+ if(col == COLUMN_NAME) -+ { -+ if(source_id == -1) -+ return QVariant(FilesDefs::getIconFromFilename(QString::fromUtf8(fileInfo.fname.c_str()))); -+ else -+ { -+ QString iconName,tooltip; -+ TransfersDialog::getPeerName(fileInfo.peers[source_id].peerId, iconName, tooltip); -+ -+ return QVariant(iconName); -+ } -+ } -+ else -+ return QVariant(); -+ } -+ -+ void update_transfers() -+ { -+// beginResetModel(); -+ -+ std::list<RsFileHash> downHashes; -+ rsFiles->FileDownloads(downHashes); -+ -+ size_t old_size = mDownloads.size(); -+ -+ mDownloads.resize(downHashes.size()) ; -+ -+ if(old_size < mDownloads.size()) -+ { -+ beginInsertRows(QModelIndex(), old_size, mDownloads.size()); -+ insertRows(old_size, mDownloads.size() - old_size); -+ endInsertRows(); -+ } -+ else if(mDownloads.size() < old_size) -+ { -+ beginRemoveRows(QModelIndex(), mDownloads.size(), old_size); -+ removeRows(old_size, old_size - mDownloads.size()); -+ endRemoveRows(); -+ } -+ -+ //std::cerr << "updating file list: found " << mDownloads.size() << " transfers." << std::endl; -+ -+ uint32_t i=0; -+ -+ for(auto it(downHashes.begin());it!=downHashes.end();++it,++i) -+ { -+ FileInfo& fileInfo(mDownloads[i]); -+ rsFiles->FileDetails(*it, RS_FILE_HINTS_DOWNLOAD, fileInfo); -+ } -+ -+// endResetModel(); -+ -+ QModelIndex topLeft = createIndex(0,0), bottomRight = createIndex(mDownloads.size(), COLUMN_COUNT-1); -+ emit dataChanged(topLeft, bottomRight); -+ -+ //shit code follow (rewrite this please) -+ // size_t old_size = neighs.size(), new_size = 0; -+ // std::list<RsPgpId> old_neighs = neighs; -+ // -+ // new_size = new_neighs.size(); -+ // //set model data to new cleaned up data -+ // neighs = new_neighs; -+ // neighs.sort(); -+ // neighs.unique(); //remove possible dups -+ // -+ // //reflect actual row count in model -+ // if(old_size < new_size) -+ // { -+ // beginInsertRows(QModelIndex(), old_size, new_size); -+ // insertRows(old_size, new_size - old_size); -+ // endInsertRows(); -+ // } -+ // else if(new_size < old_size) -+ // { -+ // beginRemoveRows(QModelIndex(), new_size, old_size); -+ // removeRows(old_size, old_size - new_size); -+ // endRemoveRows(); -+ // } -+ // //update data in ui, to avoid unnecessary redraw and ui updates, updating only changed elements -+ // //TODO: libretroshare should implement a way to obtain only changed elements via some signalling non-blocking api. -+ // { -+ // size_t ii1 = 0; -+ // for(auto i1 = neighs.begin(), end1 = neighs.end(), i2 = old_neighs.begin(), end2 = old_neighs.end(); i1 != end1; ++i1, ++i2, ii1++) -+ // { -+ // if(i2 == end2) -+ // break; -+ // if(*i1 != *i2) -+ // { -+ // QModelIndex topLeft = createIndex(ii1,0), bottomRight = createIndex(ii1, COLUMN_COUNT-1); -+ // emit dataChanged(topLeft, bottomRight); -+ // } -+ // } -+ // } -+ // if(new_size > old_size) -+ // { -+ // QModelIndex topLeft = createIndex(old_size ? old_size -1 : 0 ,0), bottomRight = createIndex(new_size -1, COLUMN_COUNT-1); -+ // emit dataChanged(topLeft, bottomRight); -+ // } -+ // //dirty solution for initial data fetch -+ // //TODO: do it properly! -+ // if(!old_size) -+ // { -+ // beginResetModel(); -+ // endResetModel(); -+ // } -+ -+ -+ } -+private: -+ static const uint32_t TRANSFERS_NB_DOWNLOADS_BITS_32BITS = 22 ; // Means 2^22 simultaneous transfers -+ static const uint32_t TRANSFERS_NB_DOWNLOADS_BIT_MASK_32BITS = 0x003fffff ; // actual bit mask corresponding to previous number of bits -+ static const uint32_t TRANSFERS_NB_SOURCES_BITS_32BITS = 10 ; // Means 2^10 simultaneous sources -+ -+ static bool convertTabEntryToRefPointer(uint32_t entry,int source_id,void *& ref) -+ { -+ if(source_id < -1) -+ { -+ std::cerr << "(EE) inconsistent source id = " << source_id << " in convertTabEntryToRefPointer()" << std::endl; -+ return false; -+ } -+ // the pointer is formed the following way: -+ // -+ // [ 10 bits | 22 bits ] -+ // -+ // This means that the whoel software has the following build-in limitation: -+ // * 1023 sources -+ // * 4M simultaenous file transfers -+ -+ if(uint32_t(source_id+1) >= (1u<<TRANSFERS_NB_SOURCES_BITS_32BITS) || (entry+1) >= (1u<< TRANSFERS_NB_DOWNLOADS_BITS_32BITS)) -+ { -+ std::cerr << "(EE) cannot convert download index " << entry << " and source " << source_id << " to pointer." << std::endl; -+ return false ; -+ } -+ -+ ref = reinterpret_cast<void*>( ( uint32_t(1+source_id) << TRANSFERS_NB_DOWNLOADS_BITS_32BITS ) + ( (entry+1) & TRANSFERS_NB_DOWNLOADS_BIT_MASK_32BITS)) ; -+ -+ return true; -+ } -+ -+ static bool convertRefPointerToTabEntry(void *ref,uint32_t& entry,int& source_id) -+ { -+ // we pack the couple (id of DL, id of source) into a single 32-bits pointer that is required by the AbstractItemModel class. -+ -+#pragma GCC diagnostic ignored "-Wstrict-aliasing" -+ uint32_t ntr = uint32_t( *reinterpret_cast<uint32_t*>(&ref) & TRANSFERS_NB_DOWNLOADS_BIT_MASK_32BITS ) ; -+ uint32_t src = ( *reinterpret_cast<uint32_t*>(&ref)) >> TRANSFERS_NB_DOWNLOADS_BITS_32BITS ; -+#pragma GCC diagnostic pop -+ -+ if(ntr == 0) -+ { -+ std::cerr << "ERROR! ntr=0!"<< std::endl; -+ return false ; -+ } -+ -+ source_id = int(src) - 1 ; -+ entry = ntr - 1 ; -+ -+ return true; -+ } -+ -+ std::vector<FileInfo> mDownloads ; // store the list of downloads, updated from rsFiles. -+}; -+ - class SortByNameItem : public QStandardItem - { - public: -@@ -170,21 +755,9 @@ TransfersDialog::TransfersDialog(QWidget *parent) - - connect( ui.downloadList, SIGNAL( customContextMenuRequested( QPoint ) ), this, SLOT( downloadListCustomPopupMenu( QPoint ) ) ); - -+ DLListModel = new RsDownloadListModel ; -+ - // Set Download list model -- DLListModel = new QStandardItemModel(0,COLUMN_COUNT); -- DLListModel->setHeaderData(COLUMN_NAME, Qt::Horizontal, tr("Name", "i.e: file name")); -- DLListModel->setHeaderData(COLUMN_SIZE, Qt::Horizontal, tr("Size", "i.e: file size")); -- DLListModel->setHeaderData(COLUMN_COMPLETED, Qt::Horizontal, tr("Completed", "")); -- DLListModel->setHeaderData(COLUMN_DLSPEED, Qt::Horizontal, tr("Speed", "i.e: Download speed")); -- DLListModel->setHeaderData(COLUMN_PROGRESS, Qt::Horizontal, tr("Progress / Availability", "i.e: % downloaded")); -- DLListModel->setHeaderData(COLUMN_SOURCES, Qt::Horizontal, tr("Sources", "i.e: Sources")); -- DLListModel->setHeaderData(COLUMN_STATUS, Qt::Horizontal, tr("Status")); -- DLListModel->setHeaderData(COLUMN_PRIORITY, Qt::Horizontal, tr("Speed / Queue position")); -- DLListModel->setHeaderData(COLUMN_REMAINING, Qt::Horizontal, tr("Remaining")); -- DLListModel->setHeaderData(COLUMN_DOWNLOADTIME, Qt::Horizontal, tr("Download time", "i.e: Estimated Time of Arrival / Time left")); -- DLListModel->setHeaderData(COLUMN_ID, Qt::Horizontal, tr("Hash")); -- DLListModel->setHeaderData(COLUMN_LASTDL, Qt::Horizontal, tr("Last Time Seen", "i.e: Last Time Receiced Data")); -- DLListModel->setHeaderData(COLUMN_PATH, Qt::Horizontal, tr("Path", "i.e: Where file is saved")); - - DLLFilterModel = new QSortFilterProxyModel(this); - DLLFilterModel->setSourceModel( DLListModel); -@@ -211,11 +784,9 @@ TransfersDialog::TransfersDialog(QWidget *parent) - selection = ui.downloadList->selectionModel(); - - ui.downloadList->setSelectionMode(QAbstractItemView::ExtendedSelection); -- - ui.downloadList->setRootIsDecorated(true); - -- -- /* Set header resize modes and initial section sizes Downloads TreeView*/ -+// /* Set header resize modes and initial section sizes Downloads TreeView*/ - QHeaderView * dlheader = ui.downloadList->header () ; - QHeaderView_setSectionResizeModeColumn(dlheader, COLUMN_NAME, QHeaderView::Interactive); - QHeaderView_setSectionResizeModeColumn(dlheader, COLUMN_SIZE, QHeaderView::Interactive); -@@ -231,20 +802,6 @@ TransfersDialog::TransfersDialog(QWidget *parent) - QHeaderView_setSectionResizeModeColumn(dlheader, COLUMN_LASTDL, QHeaderView::Interactive); - QHeaderView_setSectionResizeModeColumn(dlheader, COLUMN_PATH, QHeaderView::Interactive); - -- dlheader->resizeSection ( COLUMN_NAME, 170 ); -- dlheader->resizeSection ( COLUMN_SIZE, 70 ); -- dlheader->resizeSection ( COLUMN_COMPLETED, 75 ); -- dlheader->resizeSection ( COLUMN_DLSPEED, 75 ); -- dlheader->resizeSection ( COLUMN_PROGRESS, 170 ); -- dlheader->resizeSection ( COLUMN_SOURCES, 90 ); -- dlheader->resizeSection ( COLUMN_STATUS, 100 ); -- dlheader->resizeSection ( COLUMN_PRIORITY, 100 ); -- dlheader->resizeSection ( COLUMN_REMAINING, 100 ); -- dlheader->resizeSection ( COLUMN_DOWNLOADTIME, 100 ); -- dlheader->resizeSection ( COLUMN_ID, 100 ); -- dlheader->resizeSection ( COLUMN_LASTDL, 100 ); -- dlheader->resizeSection ( COLUMN_PATH, 100 ); -- - // set default column and sort order for download - ui.downloadList->sortByColumn(COLUMN_NAME, Qt::AscendingOrder); - -@@ -309,24 +866,12 @@ TransfersDialog::TransfersDialog(QWidget *parent) - - ui.tabWidget->addTab(localSharedFiles = new LocalSharedFilesDialog(), QIcon(IMAGE_MYFILES), tr("My files")) ; - -- //ui.tabWidget->addTab( new TurtleRouterStatistics(), tr("Router Statistics")) ; -- //ui.tabWidget->addTab( new TurtleRouterDialog(), tr("Router Requests")) ; -- - for(int i=0;i<rsPlugins->nbPlugins();++i) - if(rsPlugins->plugin(i) != NULL && rsPlugins->plugin(i)->qt_transfers_tab() != NULL) - ui.tabWidget->addTab( rsPlugins->plugin(i)->qt_transfers_tab(),QString::fromUtf8(rsPlugins->plugin(i)->qt_transfers_tab_name().c_str()) ) ; - - ui.tabWidget->setCurrentWidget(ui.uploadsTab); - --// TurtleRouterDialog *trdl = new TurtleRouterDialog(); --// ui.tunnelInfoWidget->setWidget(trdl); --// ui.tunnelInfoWidget->setWidgetResizable(true); --// ui.tunnelInfoWidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); --// ui.tunnelInfoWidget->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn); --// ui.tunnelInfoWidget->viewport()->setBackgroundRole(QPalette::NoRole); --// ui.tunnelInfoWidget->setFrameStyle(QFrame::NoFrame); --// ui.tunnelInfoWidget->setFocusPolicy(Qt::NoFocus); -- - /** Setup the actions for the context menu */ - - // Actions. Only need to be defined once. -@@ -336,14 +881,8 @@ TransfersDialog::TransfersDialog(QWidget *parent) - resumeAct = new QAction(QIcon(IMAGE_RESUME), tr("Resume"), this); - connect(resumeAct, SIGNAL(triggered()), this, SLOT(resumeFileTransfer())); - --//#ifdef USE_NEW_CHUNK_CHECKING_CODE -- // *********WARNING********** -- // csoler: this has been suspended because it needs the file transfer to consider a file as complete only if all chunks are -- // verified by hash. As users are goign to slowly switch to new checking code, this will not be readily available. -- // - forceCheckAct = new QAction(QIcon(IMAGE_CANCEL), tr( "Force Check" ), this ); - connect( forceCheckAct , SIGNAL( triggered() ), this, SLOT( forceCheck() ) ); --//#endif - - cancelAct = new QAction(QIcon(IMAGE_CANCEL), tr( "Cancel" ), this ); - connect( cancelAct , SIGNAL( triggered() ), this, SLOT( cancel() ) ); -@@ -564,18 +1103,6 @@ void TransfersDialog::processSettings(bool bLoad) - m_bProcessSettings = false; - } - --// replaced by shortcut --//void TransfersDialog::keyPressEvent(QKeyEvent *e) --//{ --// if(e->key() == Qt::Key_Delete) --// { --// cancel() ; --// e->accept() ; --// } --// else --// RsAutoUpdatePage::keyPressEvent(e) ; --//} -- - void TransfersDialog::downloadListCustomPopupMenu( QPoint /*point*/ ) - { - std::set<RsFileHash> items ; -@@ -867,6 +1394,7 @@ void TransfersDialog::setDestinationDirectory() - } - } - -+/* - int TransfersDialog::addDLItem(int row, const FileInfo &fileInfo) - { - QString fileHash = QString::fromStdString(fileInfo.hash.toStdString()); -@@ -915,7 +1443,7 @@ int TransfersDialog::addDLItem(int row, const FileInfo &fileInfo) - else - file = QFileInfo(QString::fromUtf8(rsFiles->getPartialsDirectory().c_str()), QString::fromUtf8(fileInfo.hash.toStdString().c_str())); - -- /*Get Last Access on File */ -+ //Get Last Access on File - if (file.exists()) - qi64LastDL = file.lastModified().toTime_t(); - } -@@ -987,8 +1515,7 @@ int TransfersDialog::addDLItem(int row, const FileInfo &fileInfo) - int active = 0; - - if (fileInfo.downloadStatus != FT_STATE_COMPLETE) { -- for (std::list<TransferInfo>::const_iterator pit = fileInfo.peers.begin() -- ; pit != fileInfo.peers.end(); ++pit) -+ for (std::vector<TransferInfo>::const_iterator pit = fileInfo.peers.begin() ; pit != fileInfo.peers.end(); ++pit) - { - const TransferInfo &transferInfo = *pit; - -@@ -1009,7 +1536,7 @@ int TransfersDialog::addDLItem(int row, const FileInfo &fileInfo) - - used_rows.insert(row_id); - -- /* get the sources (number of online peers) */ -+ // get the sources (number of online peers) - if (transferInfo.tfRate > 0 && fileInfo.downloadStatus == FT_STATE_DOWNLOADING) - ++active; - } -@@ -1144,6 +1671,7 @@ int TransfersDialog::addPeerToDLItem(QStandardItem *dlItem, const RsPeerId& peer - - return childRow; - } -+*/ - - int TransfersDialog::addULItem(int row, const FileInfo &fileInfo) - { -@@ -1185,8 +1713,7 @@ int TransfersDialog::addULItem(int row, const FileInfo &fileInfo) - double peerULSpeedTotal = 0; - bool bOnlyOne = ( fileInfo.peers.size() == 1 ); - -- for(std::list<TransferInfo>::const_iterator pit = fileInfo.peers.begin() -- ; pit != fileInfo.peers.end(); ++pit) -+ for(std::vector<TransferInfo>::const_iterator pit = fileInfo.peers.begin() ; pit != fileInfo.peers.end(); ++pit) - { - const TransferInfo &transferInfo = *pit; - -@@ -1329,80 +1856,57 @@ void TransfersDialog::updateDisplay() - - void TransfersDialog::insertTransfers() - { -- /* disable for performance issues, enable after insert all transfers */ -- ui.downloadList->setSortingEnabled(false); -+ // Since downloads use an AstractItemModel, we just need to update it, while saving the selected and expanded items. - -- /* get the download lists */ -- std::list<RsFileHash> downHashes; -- rsFiles->FileDownloads(downHashes); -+ std::set<QString> expanded_hashes ; -+ std::set<QString> selected_hashes ; - -- /* build set for quick search */ -- std::set<RsFileHash> hashs; -+// ui.downloadList->setSortingEnabled(false); -+// ui.downloadList->blockSignals(true) ; - -- for (std::list<RsFileHash>::iterator it = downHashes.begin(); it != downHashes.end(); ++it) { -- hashs.insert(*it); -- } -- -- /* add downloads, first iterate all rows in list */ -- -- int rowCount = DLListModel->rowCount(); -- -- for (int row = 0; row < rowCount; ) { -- RsFileHash hash ( DLListModel->item(row, COLUMN_ID)->data(Qt::UserRole).toString().toStdString()); -- -- std::set<RsFileHash>::iterator hashIt = hashs.find(hash); -- if (hashIt == hashs.end()) { -- // remove not existing downloads -- DLListModel->removeRow(row); -- rowCount = DLListModel->rowCount(); -- continue; -- } -+ std::cerr << "Updating transfers..." << std::endl; - -- FileInfo fileInfo; -- if (!rsFiles->FileDetails(hash, RS_FILE_HINTS_DOWNLOAD, fileInfo)) { -- DLListModel->removeRow(row); -- rowCount = DLListModel->rowCount(); -- continue; -- } -+/* QAbstractItemModel *model = ui.downloadList->model(); - -- hashs.erase(hashIt); -+ for(int row = 0; row < model->rowCount(); ++row) -+ { -+ QModelIndex index = model->index(row,0,QModelIndex()); - -- if (addDLItem(row, fileInfo) < 0) { -- DLListModel->removeRow(row); -- rowCount = DLListModel->rowCount(); -- continue; -- } -+ if(ui.downloadList->isExpanded(index)) -+ expanded_hashes.insert(model->index(row,COLUMN_ID).data(Qt::DisplayRole).toString()); - -- ++row; -- } -+ if(ui.downloadList->selectionModel()->selection().contains(index)) -+ selected_hashes.insert(model->index(row,COLUMN_ID).data(Qt::DisplayRole).toString()); -+ } */ - -- /* then add new downloads to the list */ -+ DLListModel->update_transfers(); - -- for (std::set<RsFileHash>::iterator hashIt = hashs.begin() -- ; hashIt != hashs.end(); ++hashIt) -+/* for(int row = 0; row < model->rowCount(); ++row) //shitcode, even worse than mine ) - { -- FileInfo fileInfo; -- if (!rsFiles->FileDetails(*hashIt, RS_FILE_HINTS_DOWNLOAD, fileInfo)) { -- continue; -- } -+ QModelIndex index = model->index(row,0,QModelIndex()); - -- addDLItem(-1, fileInfo); -- } -+ if(expanded_hashes.end() != expanded_hashes.find(model->index(row,COLUMN_ID).data(Qt::DisplayRole).toString())) -+ ui.downloadList->setExpanded(index,true); -+ -+ if(selected_hashes.end() != selected_hashes.find(model->index(row,COLUMN_ID).data(Qt::DisplayRole).toString())) -+ ui.downloadList->selectionModel()->select(index, QItemSelectionModel::Select | QItemSelectionModel::Rows); -+ } */ - -- ui.downloadList->setSortingEnabled(true); -+// ui.downloadList->setSortingEnabled(true); -+// ui.downloadList->blockSignals(false) ; - -- // Now show upload hashes -+ // Now show upload hashes. Here we use the "old" way, since the number of uploads is generally not so large. - // - - /* disable for performance issues, enable after insert all transfers */ -- ui.uploadsList->setSortingEnabled(false); -+ ui.uploadsList->setSortingEnabled(false); - - /* get the upload lists */ - std::list<RsFileHash> upHashes; - rsFiles->FileUploads(upHashes); - - /* build set for quick search */ -- hashs.clear(); -+ std::set<RsFileHash> hashs; - - for(std::list<RsFileHash>::iterator it = upHashes.begin(); it != upHashes.end(); ++it) { - hashs.insert(*it); -@@ -1410,7 +1914,7 @@ void TransfersDialog::insertTransfers() - - /* add uploads, first iterate all rows in list */ - -- rowCount = ULListModel->rowCount(); -+ int rowCount = ULListModel->rowCount(); - - for (int row = 0; row < rowCount; ) { - RsFileHash hash ( ULListModel->item(row, COLUMN_UHASH)->data(Qt::UserRole).toString().toStdString()); -@@ -1464,7 +1968,7 @@ void TransfersDialog::insertTransfers() - - } - --QString TransfersDialog::getPeerName(const RsPeerId& id, QString &iconName, QString &tooltip) const -+QString TransfersDialog::getPeerName(const RsPeerId& id, QString &iconName, QString &tooltip) - { - QString res = QString::fromUtf8(rsPeers->getPeerName(id).c_str()) ; - -diff --git a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h -index 30efe212d..51bc205d3 100644 ---- a/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h -+++ b/retroshare-gui/src/gui/FileTransfer/TransfersDialog.h -@@ -44,6 +44,7 @@ class FileProgressInfo; - class SearchDialog;
- class LocalSharedFilesDialog;
- class RemoteSharedFilesDialog;
-+class RsDownloadListModel;
-
- class TransfersDialog : public RsAutoUpdatePage
- {
-@@ -78,6 +79,7 @@ public: - LocalSharedFilesDialog *localSharedFiles ;
- RemoteSharedFilesDialog *remoteSharedFiles ;
-
-+ static QString getPeerName(const RsPeerId &peer_id, QString &iconName, QString &tooltip) ;
- public slots:
- void insertTransfers();
-
-@@ -164,9 +166,8 @@ signals: - void playFiles(QStringList files);
-
- private:
-- QString getPeerName(const RsPeerId &peer_id, QString &iconName, QString &tooltip) const ;
-
-- QStandardItemModel *DLListModel;
-+ RsDownloadListModel *DLListModel;
- QSortFilterProxyModel *DLLFilterModel;
- QStandardItemModel *ULListModel;
- QItemSelectionModel *selection;
-@@ -260,8 +261,8 @@ private: -
- public slots:
- // these four functions add entries to the transfers dialog, and return the row id of the entry modified/added
-- int addDLItem(int row, const FileInfo &fileInfo);
-- int addPeerToDLItem(QStandardItem* dlItem, const RsPeerId &peer_ID, const QString &coreID, double dlspeed, uint32_t status, const FileProgressInfo &peerInfo);
-+// int addDLItem(int row, const FileInfo &fileInfo);
-+// int addPeerToDLItem(QStandardItem* dlItem, const RsPeerId &peer_ID, const QString &coreID, double dlspeed, uint32_t status, const FileProgressInfo &peerInfo);
- int addULItem(int row, const FileInfo &fileInfo);
- int addPeerToULItem(QStandardItem* ulItem, const RsPeerId &peer_ID, const QString &coreID, qlonglong completed, double ulspeed, const FileProgressInfo &peerInfo);
-
-diff --git a/retroshare-gui/src/gui/RetroShareLink.cpp b/retroshare-gui/src/gui/RetroShareLink.cpp -index 266970a54..f4af64017 100644 ---- a/retroshare-gui/src/gui/RetroShareLink.cpp -+++ b/retroshare-gui/src/gui/RetroShareLink.cpp -@@ -1572,7 +1572,7 @@ static void processList(const QStringList &list, const QString &textSingular, co - FileInfo finfo ; - rsFiles->FileDetails(RsFileHash(link.hash().toStdString()), RS_FILE_HINTS_REMOTE, finfo) ; - -- for(std::list<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) -+ for(std::vector<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) - { - #ifdef DEBUG_RSLINK - std::cerr << " adding peerid " << (*it).peerId << std::endl ; -diff --git a/retroshare-gui/src/gui/feeds/SubFileItem.cpp b/retroshare-gui/src/gui/feeds/SubFileItem.cpp -index 250d85cad..0e3350127 100644 ---- a/retroshare-gui/src/gui/feeds/SubFileItem.cpp -+++ b/retroshare-gui/src/gui/feeds/SubFileItem.cpp -@@ -630,7 +630,7 @@ void SubFileItem::download() - FileInfo finfo ; - rsFiles->FileDetails(mFileHash,RS_FILE_HINTS_REMOTE,finfo) ; - -- for(std::list<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) -+ for(std::vector<TransferInfo>::const_iterator it(finfo.peers.begin());it!=finfo.peers.end();++it) - sources.push_back((*it).peerId) ; - - // TEMP -diff --git a/retroshare-gui/src/gui/gxschannels/GxsChannelFilesStatusWidget.cpp b/retroshare-gui/src/gui/gxschannels/GxsChannelFilesStatusWidget.cpp -index b9b84b894..b3170efa4 100644 ---- a/retroshare-gui/src/gui/gxschannels/GxsChannelFilesStatusWidget.cpp -+++ b/retroshare-gui/src/gui/gxschannels/GxsChannelFilesStatusWidget.cpp -@@ -248,7 +248,7 @@ void GxsChannelFilesStatusWidget::download() - FileInfo fileInfo;
- rsFiles->FileDetails(mFile.mHash, RS_FILE_HINTS_REMOTE, fileInfo);
-
-- for(std::list<TransferInfo>::const_iterator it = fileInfo.peers.begin(); it != fileInfo.peers.end(); ++it) {
-+ for(std::vector<TransferInfo>::const_iterator it = fileInfo.peers.begin(); it != fileInfo.peers.end(); ++it) {
- sources.push_back((*it).peerId);
- }
-
-diff --git a/retroshare-gui/src/gui/msgs/MessageWidget.cpp b/retroshare-gui/src/gui/msgs/MessageWidget.cpp -index 2f00bcded..38319bafc 100644 ---- a/retroshare-gui/src/gui/msgs/MessageWidget.cpp -+++ b/retroshare-gui/src/gui/msgs/MessageWidget.cpp -@@ -323,7 +323,7 @@ void MessageWidget::getcurrentrecommended() - fi.fname = it->data().toString().toUtf8().constData(); - break ; - case COLUMN_FILE_SIZE: -- fi.size = it->data().toULongLong() ; -+ fi.size = it->data(Qt::UserRole).toULongLong() ; - break ; - case COLUMN_FILE_HASH: - fi.hash = RsFileHash(it->data().toString().toStdString()) ; -@@ -502,6 +502,7 @@ void MessageWidget::fill(const std::string &msgId) - QTreeWidgetItem *item = new QTreeWidgetItem; - item->setText(COLUMN_FILE_NAME, QString::fromUtf8(it->fname.c_str())); - item->setText(COLUMN_FILE_SIZE, misc::friendlyUnit(it->size)); -+ item->setData(COLUMN_FILE_SIZE, Qt::UserRole, QVariant(qulonglong(it->size)) ); - item->setText(COLUMN_FILE_HASH, QString::fromStdString(it->hash.toStdString())); - item->setTextAlignment( COLUMN_FILE_SIZE, Qt::AlignRight ); - diff --git a/net-p2p/retroshare/retroshare-scm.ebuild b/net-p2p/retroshare/retroshare-scm.ebuild index 4d28ff9..ac96b7b 100644 --- a/net-p2p/retroshare/retroshare-scm.ebuild +++ b/net-p2p/retroshare/retroshare-scm.ebuild @@ -83,7 +83,6 @@ PATCHES=( "${FILESDIR}/hidden_service.patch" "${FILESDIR}/cflags.patch" "${FILESDIR}/disable_key_array_redraw.patch" - "${FILESDIR}/rs-ft-1169.diff" ) |