Fixed context menu "Cancel" and "Copy RetroShare Links" in TransfersDialog when a peer is selected.

Fixed DetailsDialog when a peer is selected.
Sort peers by name ascending in the download list.

git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@4018 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
thunder2 2011-02-08 00:41:13 +00:00
parent dbe0890974
commit 9d76a44890
4 changed files with 205 additions and 132 deletions

View File

@ -71,10 +71,48 @@ Q_DECLARE_METATYPE(FileProgressInfo)
DetailsDialog *TransfersDialog::detailsdlg = NULL; DetailsDialog *TransfersDialog::detailsdlg = NULL;
class ProgressItem : public QStandardItem class SortByNameItem : public QStandardItem
{ {
public: public:
ProgressItem() : QStandardItem() {} SortByNameItem(QHeaderView *header) : QStandardItem()
{
this->header = header;
}
virtual bool operator<(const QStandardItem &other) const
{
QStandardItemModel *m = model();
if (m == NULL) {
return QStandardItem::operator<(other);
}
QStandardItem *myParent = parent();
QStandardItem *otherParent = other.parent();
if (myParent == NULL || otherParent == NULL) {
return QStandardItem::operator<(other);
}
QStandardItem *myName = myParent->child(index().row(), NAME);
QStandardItem *otherName = otherParent->child(other.index().row(), NAME);
if (header == NULL || header->sortIndicatorOrder() == Qt::AscendingOrder) {
/* Ascending */
return *myName < *otherName;
}
/* Descending, sort peers in ascending order */
return !(*myName < *otherName);
}
private:
QHeaderView *header;
};
class ProgressItem : public SortByNameItem
{
public:
ProgressItem(QHeaderView *header) : SortByNameItem(header) {}
virtual bool operator<(const QStandardItem &other) const virtual bool operator<(const QStandardItem &other) const
{ {
@ -83,7 +121,14 @@ public:
FileProgressInfo l = data(role).value<FileProgressInfo>(); FileProgressInfo l = data(role).value<FileProgressInfo>();
FileProgressInfo r = other.data(role).value<FileProgressInfo>(); FileProgressInfo r = other.data(role).value<FileProgressInfo>();
return l < r; if (l < r) {
return true;
}
if (l > r) {
return false;
}
return SortByNameItem::operator<(other);
} }
}; };
@ -350,9 +395,9 @@ void TransfersDialog::processSettings(bool bLoad)
void TransfersDialog::downloadListCostumPopupMenu( QPoint point ) void TransfersDialog::downloadListCostumPopupMenu( QPoint point )
{ {
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
bool single = (items.size() == 1) ; bool single = (items.size() == 1) ;
@ -364,7 +409,7 @@ void TransfersDialog::downloadListCostumPopupMenu( QPoint point )
FileInfo info; FileInfo info;
for (it = items.begin(); it != items.end(); it ++) { for (it = items.begin(); it != items.end(); it ++) {
if (!rsFiles->FileDetails((*it)->data(Qt::DisplayRole).toString().toStdString(), RS_FILE_HINTS_DOWNLOAD, info)) continue; if (!rsFiles->FileDetails(*it, RS_FILE_HINTS_DOWNLOAD, info)) continue;
break; break;
} }
@ -501,7 +546,7 @@ int TransfersDialog::addItem(const QString&, const QString& name, const QString&
int rowCount = DLListModel->rowCount(); int rowCount = DLListModel->rowCount();
int row ; int row ;
for(row=0;row<rowCount;++row) for(row=0;row<rowCount;++row)
if(DLListModel->item(row,ID)->data(Qt::EditRole).toString() == coreID) if(DLListModel->item(row,ID)->data(Qt::DisplayRole).toString() == coreID)
break ; break ;
if(row >= rowCount ) if(row >= rowCount )
@ -510,7 +555,7 @@ int TransfersDialog::addItem(const QString&, const QString& name, const QString&
DLListModel->insertRow(row); DLListModel->insertRow(row);
// change progress column to own class for sorting // change progress column to own class for sorting
DLListModel->setItem(row, PROGRESS, new ProgressItem); DLListModel->setItem(row, PROGRESS, new ProgressItem (NULL));
} }
DLListModel->setData(DLListModel->index(row, NAME), QVariant(name)); DLListModel->setData(DLListModel->index(row, NAME), QVariant(name));
@ -588,17 +633,19 @@ int TransfersDialog::addPeerToItem(int row, const QString& name, const QString&
//set this false if you want to expand on double click //set this false if you want to expand on double click
dlItem->setEditable(false); dlItem->setEditable(false);
QHeaderView *header = ui.downloadList->header ();
QStandardItem *i1 = new QStandardItem(); QStandardItem *i1 = new QStandardItem();
QStandardItem *i2 = new QStandardItem(); QStandardItem *i2 = new SortByNameItem(header);
QStandardItem *i3 = new QStandardItem(); QStandardItem *i3 = new SortByNameItem(header);
QStandardItem *i4 = new QStandardItem(); QStandardItem *i4 = new SortByNameItem(header);
QStandardItem *i5 = new ProgressItem(); QStandardItem *i5 = new ProgressItem(header);
QStandardItem *i6 = new QStandardItem(); QStandardItem *i6 = new SortByNameItem(header);
QStandardItem *i7 = new QStandardItem(); QStandardItem *i7 = new SortByNameItem(header);
QStandardItem *i8 = new QStandardItem(); QStandardItem *i8 = new SortByNameItem(header);
QStandardItem *i9 = new QStandardItem(); QStandardItem *i9 = new SortByNameItem(header);
QStandardItem *i10 = new QStandardItem(); QStandardItem *i10 = new SortByNameItem(header);
QStandardItem *i11 = new QStandardItem(); QStandardItem *i11 = new SortByNameItem(header);
si1 = i1 ; si1 = i1 ;
si7 = i7 ; si7 = i7 ;
@ -692,7 +739,7 @@ int TransfersDialog::addUploadItem( const QString&, const QString& name, const Q
ULListModel->insertRow(row); ULListModel->insertRow(row);
// change progress column to own class for sorting // change progress column to own class for sorting
ULListModel->setItem(row, UPROGRESS, new ProgressItem); ULListModel->setItem(row, UPROGRESS, new ProgressItem(NULL));
} }
ULListModel->setData(ULListModel->index(row, UNAME), QVariant((QString)" "+name), Qt::DisplayRole); ULListModel->setData(ULListModel->index(row, UNAME), QVariant((QString)" "+name), Qt::DisplayRole);
@ -712,15 +759,15 @@ int TransfersDialog::addUploadItem( const QString&, const QString& name, const Q
} }
void TransfersDialog::delItem(int row) //void TransfersDialog::delItem(int row)
{ //{
DLListModel->removeRow(row, QModelIndex()); // DLListModel->removeRow(row, QModelIndex());
} //}
void TransfersDialog::delUploadItem(int row) //void TransfersDialog::delUploadItem(int row)
{ //{
ULListModel->removeRow(row, QModelIndex()); // ULListModel->removeRow(row, QModelIndex());
} //}
/* get the list of Transfers from the RsIface. **/ /* get the list of Transfers from the RsIface. **/
void TransfersDialog::updateDisplay() void TransfersDialog::updateDisplay()
@ -871,13 +918,14 @@ void TransfersDialog::insertTransfers()
if(used_rows.find(r) == used_rows.end()) if(used_rows.find(r) == used_rows.end())
QListDelete (dlItem->takeRow(r)) ; QListDelete (dlItem->takeRow(r)) ;
} }
// remove hashes that where not shown // remove hashes that where not shown
//first clean the model in case some files are not download anymore //first clean the model in case some files are not download anymore
//remove items that are not fiends anymore //remove items that are not fiends anymore
int removeIndex = 0; int removeIndex = 0;
while (removeIndex < DLListModel->rowCount()) while (removeIndex < DLListModel->rowCount())
{ {
std::string hash = DLListModel->item(removeIndex, ID)->data(Qt::EditRole).toString().toStdString(); std::string hash = DLListModel->item(removeIndex, ID)->data(Qt::DisplayRole).toString().toStdString();
if(used_hashes.find(hash) == used_hashes.end()) if(used_hashes.find(hash) == used_hashes.end())
QListDelete (DLListModel->takeRow(removeIndex)); QListDelete (DLListModel->takeRow(removeIndex));
@ -1001,11 +1049,15 @@ void TransfersDialog::forceCheck()
if (!controlTransferFile(RS_FILE_CTRL_FORCE_CHECK)) if (!controlTransferFile(RS_FILE_CTRL_FORCE_CHECK))
std::cerr << "resumeFileTransfer(): can't force check file transfer" << std::endl; std::cerr << "resumeFileTransfer(): can't force check file transfer" << std::endl;
} }
void TransfersDialog::cancel() void TransfersDialog::cancel()
{ {
bool first = true; bool first = true;
for(int i = 0; i < DLListModel->rowCount(); i++) {
if(selection->isRowSelected(i, QModelIndex())) { std::set<std::string> items;
std::set<std::string>::iterator it;
getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) {
if (first) { if (first) {
first = false; first = false;
QString queryWrn2; QString queryWrn2;
@ -1017,10 +1069,7 @@ void TransfersDialog::cancel()
} }
} }
std::string id = getID(i, DLListModel).toStdString(); rsFiles->FileCancel(*it);
rsFiles->FileCancel(id); /* hash */
}
} }
} }
@ -1050,20 +1099,22 @@ void TransfersDialog::cancel()
void TransfersDialog::copyLink () void TransfersDialog::copyLink ()
{ {
QModelIndexList lst = ui.downloadList->selectionModel ()->selectedIndexes ();
std::vector<RetroShareLink> links ; std::vector<RetroShareLink> links ;
for (int i = 0; i < lst.count (); i++) std::set<std::string> items;
if ( lst[i].column() == 0 ) std::set<std::string>::iterator it;
{ getSelectedItems(&items, NULL);
QModelIndex & ind = lst[i];
QString fhash= ind.model ()->data (ind.model ()->index (ind.row (), ID )).toString() ;
qulonglong fsize= ind.model ()->data (ind.model ()->index (ind.row (), SIZE)).toULongLong() ;
QString fname= ind.model ()->data (ind.model ()->index (ind.row (), NAME)).toString() ;
RetroShareLink link(fname, uint64_t(fsize), fhash); for (it = items.begin(); it != items.end(); it ++) {
FileInfo info;
if (!rsFiles->FileDetails(*it, RS_FILE_HINTS_DOWNLOAD, info)) {
continue;
}
RetroShareLink link(QString::fromStdString(info.fname), info.size, QString::fromStdString(info.hash));
links.push_back(link) ; links.push_back(link) ;
} }
RSLinkClipboard::copyLinks(links) ; RSLinkClipboard::copyLinks(links) ;
} }
@ -1085,8 +1136,6 @@ void TransfersDialog::updateDetailsDialog()
return; return;
} }
QModelIndexList lst = ui.downloadList->selectionModel ()->selectedIndexes ();
std::string file_hash ; std::string file_hash ;
QString fhash; QString fhash;
QString fsize; QString fsize;
@ -1102,24 +1151,26 @@ void TransfersDialog::updateDetailsDialog()
qulonglong fdownloadtime = 0; qulonglong fdownloadtime = 0;
for (int i = 0; i < lst.count (); i++) std::set<int> rows;
{ std::set<int>::iterator it;
if (lst[i].column () == 0) getSelectedItems(NULL, &rows);
{
QModelIndex& ind = lst[i];
fhash = ind.model ()->data (ind.model ()->index (ind.row (), ID )).toString() ;
fsize = ind.model ()->data (ind.model ()->index (ind.row (), SIZE)).toString() ;
fname = ind.model ()->data (ind.model ()->index (ind.row (), NAME)).toString() ;
fstatus = ind.model ()->data (ind.model ()->index (ind.row (), STATUS)).toString() ;
fpriority = ind.model ()->data (ind.model ()->index (ind.row (), PRIORITY)).toString() ;
fsources= ind.model ()->data (ind.model ()->index (ind.row (), SOURCES)).toString() ;
filesize = ind.model ()->data (ind.model ()->index (ind.row (), SIZE)).toULongLong() ; if (rows.size()) {
fdatarate = ind.model ()->data (ind.model ()->index (ind.row (), DLSPEED)).toDouble() ; int row = *rows.begin();
fcompleted = ind.model ()->data (ind.model ()->index (ind.row (), COMPLETED)).toULongLong() ;
fremaining = ind.model ()->data (ind.model ()->index (ind.row (), REMAINING)).toULongLong() ;
fdownloadtime = ind.model ()->data (ind.model ()->index (ind.row (), DOWNLOADTIME)).toULongLong() ; fhash = getID(row, DLListModel);
fsize = getFileSize(row, DLListModel);
fname = getFileName(row, DLListModel);
fstatus = getStatus(row, DLListModel);
fpriority = getPriority(row, DLListModel);
fsources = getSources(row, DLListModel);
filesize = getFileSize(row, DLListModel);
fdatarate = getSpeed(row, DLListModel);
fcompleted = getTransfered(row, DLListModel);
fremaining = getRemainingTime(row, DLListModel);
fdownloadtime = getDownloadTime(row, DLListModel);
// maybe show all links in retroshare link(s) Tab // maybe show all links in retroshare link(s) Tab
// int nb_select = 0 ; // int nb_select = 0 ;
@ -1131,10 +1182,7 @@ void TransfersDialog::updateDetailsDialog()
// ++nb_select ; // ++nb_select ;
// } // }
file_hash = getID(ind.row(), DLListModel).toStdString(); file_hash = getID(row, DLListModel).toStdString();
break;
}
} }
detailsdlg->setFileHash(file_hash); detailsdlg->setFileHash(file_hash);
@ -1191,9 +1239,14 @@ void TransfersDialog::pasteLink()
RSLinkClipboard::process(RetroShareLink::TYPE_FILE, RSLINK_PROCESS_NOTIFY_ERROR); RSLinkClipboard::process(RetroShareLink::TYPE_FILE, RSLINK_PROCESS_NOTIFY_ERROR);
} }
void TransfersDialog::getIdOfSelectedItems(std::set<QStandardItem *>& items) void TransfersDialog::getSelectedItems(std::set<std::string> *ids, std::set<int> *rows)
{ {
items.clear(); if (ids == NULL && rows == NULL) {
return;
}
if (ids) ids->clear();
if (rows) rows->clear();
int i, imax = DLListModel->rowCount(); int i, imax = DLListModel->rowCount();
for (i = 0; i < imax; i++) { for (i = 0; i < imax; i++) {
@ -1219,8 +1272,13 @@ void TransfersDialog::getIdOfSelectedItems(std::set<QStandardItem *>& items)
/* if transfered file or it's peers are selected control it*/ /* if transfered file or it's peers are selected control it*/
if (isParentSelected || isChildSelected) { if (isParentSelected || isChildSelected) {
if (ids) {
QStandardItem *id = DLListModel->item(i, ID); QStandardItem *id = DLListModel->item(i, ID);
items.insert(id); ids->insert(id->data(Qt::DisplayRole).toString().toStdString());
}
if (rows) {
rows->insert(i);
}
} }
} }
} }
@ -1229,11 +1287,11 @@ bool TransfersDialog::controlTransferFile(uint32_t flags)
{ {
bool result = true; bool result = true;
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) { for (it = items.begin(); it != items.end(); it ++) {
result &= rsFiles->FileControl((*it)->data(Qt::DisplayRole).toString().toStdString(), flags); result &= rsFiles->FileControl(*it, flags);
} }
return result; return result;
@ -1259,11 +1317,11 @@ void TransfersDialog::openFolderTransfer()
{ {
FileInfo info; FileInfo info;
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) { for (it = items.begin(); it != items.end(); it ++) {
if (!rsFiles->FileDetails((*it)->data(Qt::DisplayRole).toString().toStdString(), RS_FILE_HINTS_DOWNLOAD, info)) continue; if (!rsFiles->FileDetails(*it, RS_FILE_HINTS_DOWNLOAD, info)) continue;
break; break;
} }
@ -1289,11 +1347,11 @@ void TransfersDialog::previewTransfer()
{ {
FileInfo info; FileInfo info;
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) { for (it = items.begin(); it != items.end(); it ++) {
if (!rsFiles->FileDetails((*it)->data(Qt::DisplayRole).toString().toStdString(), RS_FILE_HINTS_DOWNLOAD, info)) continue; if (!rsFiles->FileDetails(*it, RS_FILE_HINTS_DOWNLOAD, info)) continue;
break; break;
} }
@ -1350,11 +1408,11 @@ void TransfersDialog::openTransfer()
{ {
FileInfo info; FileInfo info;
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) { for (it = items.begin(); it != items.end(); it ++) {
if (!rsFiles->FileDetails((*it)->data(Qt::DisplayRole).toString().toStdString(), RS_FILE_HINTS_DOWNLOAD, info)) continue; if (!rsFiles->FileDetails(*it, RS_FILE_HINTS_DOWNLOAD, info)) continue;
break; break;
} }
@ -1383,7 +1441,7 @@ void TransfersDialog::openTransfer()
//{ //{
// std::set<QStandardItem *> items; // std::set<QStandardItem *> items;
// std::set<QStandardItem *>::iterator it; // std::set<QStandardItem *>::iterator it;
// getIdOfSelectedItems(items); // getSelectedItems(&items, NULL);
// //
// for (it = items.begin(); it != items.end(); it ++) { // for (it = items.begin(); it != items.end(); it ++) {
// std::string hash = (*it)->data(Qt::DisplayRole).toString().toStdString(); // std::string hash = (*it)->data(Qt::DisplayRole).toString().toStdString();
@ -1405,13 +1463,12 @@ void TransfersDialog::chunkRandom()
} }
void TransfersDialog::setChunkStrategy(FileChunksInfo::ChunkStrategy s) void TransfersDialog::setChunkStrategy(FileChunksInfo::ChunkStrategy s)
{ {
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) { for (it = items.begin(); it != items.end(); it ++) {
std::string hash = (*it)->data(Qt::DisplayRole).toString().toStdString(); rsFiles->setChunkStrategy(*it, s);
rsFiles->setChunkStrategy(hash, s);
} }
} }
/* modify download priority actions */ /* modify download priority actions */
@ -1447,14 +1504,13 @@ void TransfersDialog::priorityQueueBottom()
void TransfersDialog::changeSpeed(int speed) void TransfersDialog::changeSpeed(int speed)
{ {
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) for (it = items.begin(); it != items.end(); it ++)
{ {
std::string hash = (*it)->data(Qt::DisplayRole).toString().toStdString(); rsFiles->changeDownloadSpeed(*it, speed);
rsFiles->changeDownloadSpeed(hash, speed);
} }
} }
@ -1462,14 +1518,13 @@ void TransfersDialog::changeSpeed(int speed)
void TransfersDialog::changeQueuePosition(QueueMove mv) void TransfersDialog::changeQueuePosition(QueueMove mv)
{ {
std::cerr << "In changeQueuePosition (gui)"<< std::endl ; std::cerr << "In changeQueuePosition (gui)"<< std::endl ;
std::set<QStandardItem *> items; std::set<std::string> items;
std::set<QStandardItem *>::iterator it; std::set<std::string>::iterator it;
getIdOfSelectedItems(items); getSelectedItems(&items, NULL);
for (it = items.begin(); it != items.end(); it ++) for (it = items.begin(); it != items.end(); it ++)
{ {
std::string hash = (*it)->data(Qt::DisplayRole).toString().toStdString(); rsFiles->changeQueuePosition(*it, mv);
rsFiles->changeQueuePosition(hash, mv);
} }
} }
@ -1552,3 +1607,13 @@ qlonglong TransfersDialog::getRemainingTime(int row, QStandardItemModel *model)
bool ok = false; bool ok = false;
return model->data(model->index(row, REMAINING), Qt::DisplayRole).toULongLong(&ok); return model->data(model->index(row, REMAINING), Qt::DisplayRole).toULongLong(&ok);
} }
qlonglong TransfersDialog::getDownloadTime(int row, QStandardItemModel *model)
{
return model->data(model->index(row, DOWNLOADTIME), Qt::DisplayRole).toULongLong();
}
QString TransfersDialog::getSources(int row, QStandardItemModel *model)
{
return model->data(model->index(row, SOURCES), Qt::DisplayRole).toString();
}

View File

@ -151,7 +151,7 @@ private:
bool m_bProcessSettings; bool m_bProcessSettings;
void processSettings(bool bLoad); void processSettings(bool bLoad);
void getIdOfSelectedItems(std::set<QStandardItem *>& items); void getSelectedItems(std::set<std::string> *ids, std::set<int> *rows);
bool controlTransferFile(uint32_t flags); bool controlTransferFile(uint32_t flags);
void changePriority(int priority); void changePriority(int priority);
void setChunkStrategy(FileChunksInfo::ChunkStrategy s) ; void setChunkStrategy(FileChunksInfo::ChunkStrategy s) ;
@ -169,10 +169,10 @@ public slots:
// //
int addItem(const QString& symbol, const QString& name, const QString& coreID, qlonglong size, const FileProgressInfo& pinfo, double dlspeed, const QString& sources, const QString& status, const QString& priority, qlonglong completed, qlonglong remaining, qlonglong downloadtime); int addItem(const QString& symbol, const QString& name, const QString& coreID, qlonglong size, const FileProgressInfo& pinfo, double dlspeed, const QString& sources, const QString& status, const QString& priority, qlonglong completed, qlonglong remaining, qlonglong downloadtime);
int addPeerToItem(int row, const QString& name, const QString& coreID, double dlspeed, uint32_t status, const FileProgressInfo& peerInfo); int addPeerToItem(int row, const QString& name, const QString& coreID, double dlspeed, uint32_t status, const FileProgressInfo& peerInfo);
void delItem(int row); // void delItem(int row);
int addUploadItem(const QString& symbol, const QString& name, const QString& coreID, qlonglong size, const FileProgressInfo& pinfo, double dlspeed, const QString& sources,const QString& source_id, const QString& status, qlonglong completed, qlonglong remaining); int addUploadItem(const QString& symbol, const QString& name, const QString& coreID, qlonglong size, const FileProgressInfo& pinfo, double dlspeed, const QString& sources,const QString& source_id, const QString& status, qlonglong completed, qlonglong remaining);
void delUploadItem(int row); // void delUploadItem(int row);
void showFileDetails() ; void showFileDetails() ;
@ -185,6 +185,8 @@ public slots:
qlonglong getFileSize(int row, QStandardItemModel *model); qlonglong getFileSize(int row, QStandardItemModel *model);
qlonglong getTransfered(int row, QStandardItemModel *model); qlonglong getTransfered(int row, QStandardItemModel *model);
qlonglong getRemainingTime(int row, QStandardItemModel *model); qlonglong getRemainingTime(int row, QStandardItemModel *model);
qlonglong getDownloadTime(int row, QStandardItemModel *model);
QString getSources(int row, QStandardItemModel *model);
}; };
#endif #endif

View File

@ -33,6 +33,11 @@ bool FileProgressInfo::operator<(const FileProgressInfo &other) const
return progress < other.progress; return progress < other.progress;
} }
bool FileProgressInfo::operator>(const FileProgressInfo &other) const
{
return progress > other.progress;
}
xProgressBar::xProgressBar(const FileProgressInfo& pinfo,QRect rect, QPainter *painter, int schemaIndex) xProgressBar::xProgressBar(const FileProgressInfo& pinfo,QRect rect, QPainter *painter, int schemaIndex)
: _pinfo(pinfo) : _pinfo(pinfo)
{ {

View File

@ -49,6 +49,7 @@ class FileProgressInfo
std::vector<uint32_t> chunks_in_progress ; std::vector<uint32_t> chunks_in_progress ;
bool operator<(const FileProgressInfo &other) const; bool operator<(const FileProgressInfo &other) const;
bool operator>(const FileProgressInfo &other) const;
}; };
// //
class xProgressBar : public QObject class xProgressBar : public QObject