1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-22 12:34:19 +00:00

- Keep on working on trackers edition

This commit is contained in:
Christophe Dumez 2007-03-25 13:45:20 +00:00
parent ab18594e00
commit 1f6948d260
2 changed files with 35 additions and 12 deletions

View File

@ -25,7 +25,7 @@
#include <QInputDialog>
// Constructor
properties::properties(QWidget *parent, torrent_handle h, QStringList trackerErrors): QDialog(parent), h(h){
properties::properties(QWidget *parent, torrent_handle &h, QStringList trackerErrors): QDialog(parent), h(h){
setupUi(this);
// set icons
unselect->setIcon(QIcon(QString::fromUtf8(":/Icons/button_cancel.png")));
@ -46,6 +46,7 @@ properties::properties(QWidget *parent, torrent_handle h, QStringList trackerErr
filesList->setItemDelegate(PropDelegate);
connect(filesList, SIGNAL(doubleClicked(const QModelIndex&)), this, SLOT(toggleSelectedState(const QModelIndex&)));
connect(addTracker_button, SIGNAL(clicked()), this, SLOT(askForTracker()));
connect(removeTracker_button, SIGNAL(clicked()), this, SLOT(deleteSelectedTrackers()));
// get Infos from torrent handle
fileHash = QString(misc::toString(h.info_hash()).c_str());
torrent_status torrentStatus = h.status();
@ -148,14 +149,13 @@ void properties::loadFilteredFiles(){
}
void properties::loadTrackers(){
torrent_status torrentStatus = h.status();
torrent_info torrentInfo = h.get_torrent_info();
//Trackers
std::vector<announce_entry> trackers = torrentInfo.trackers();
std::vector<announce_entry> trackers = h.trackers();
trackersURLS->clear();
for(unsigned int i=0; i<trackers.size(); ++i){
trackersURLS->addItem(QString(trackers[i].url.c_str()));
}
torrent_status torrentStatus = h.status();
QString tracker = QString(torrentStatus.current_tracker.c_str()).trimmed();
if(!tracker.isEmpty()){
trackerURL->setText(tracker);
@ -174,13 +174,35 @@ void properties::askForTracker(){
tr("New tracker url:"), QLineEdit::Normal,
"http://www.", &ok);
if(!ok) return;
// Checking if it already exists in the list
torrent_info torrentInfo = h.get_torrent_info();
// std::vector<announce_entry> trackers = torrentInfo.trackers();
// for(unsigned int i=0; i<trackers.size(); ++i){
// if(QString(trackers[i].url.c_str())
// }
torrentInfo.add_tracker(trackerUrl.toStdString(), trackersURLS->count());
// Add the tracker to the list
std::vector<announce_entry> trackers = h.trackers();
announce_entry new_tracker(trackerUrl.toStdString());
new_tracker.tier = trackersURLS->count();
trackers.push_back(new_tracker);
h.replace_trackers(trackers);
h.force_reannounce();
// Reload Trackers
loadTrackers();
}
void properties::deleteSelectedTrackers(){
std::vector<announce_entry> trackers = h.trackers();
QList<QListWidgetItem *> selectedItems;
selectedItems = trackersURLS->selectedItems();
QListWidgetItem *item;
foreach(item, selectedItems){
QString url = item->text();
bool found = false;
for(unsigned int i=0; i<trackers.size(); ++i){
if(QString(trackers.at(i).url.c_str()) == url){
trackers.erase(trackers.begin()+i);
found = true;
break;
}
}
qDebug("Found: %d", found);
}
h.replace_trackers(trackers);
h.force_reannounce();
// Reload Trackers
loadTrackers();

View File

@ -55,13 +55,14 @@ class properties : public QDialog, private Ui::properties{
void setAllPiecesState(bool selected);
void askForTracker();
void loadTrackers();
void deleteSelectedTrackers();
signals:
void changedFilteredFiles(torrent_handle h, bool compact_mode);
public:
// Constructor
properties(QWidget *parent, torrent_handle h, QStringList trackerErrors = QStringList());
properties(QWidget *parent, torrent_handle &h, QStringList trackerErrors = QStringList());
~properties();
};