mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-10 14:57:52 +00:00
Merge msvc compilation fixes from stable branch
This commit is contained in:
parent
656beed82b
commit
682377ff66
@ -1345,6 +1345,7 @@ void Bittorrent::enableLSD(bool b) {
|
|||||||
|
|
||||||
void Bittorrent::loadSessionState() {
|
void Bittorrent::loadSessionState() {
|
||||||
const QString state_path = misc::cacheLocation()+QDir::separator()+QString::fromUtf8("ses_state");
|
const QString state_path = misc::cacheLocation()+QDir::separator()+QString::fromUtf8("ses_state");
|
||||||
|
if(!QFile::exists(state_path)) return;
|
||||||
#ifdef LIBTORRENT_0_15
|
#ifdef LIBTORRENT_0_15
|
||||||
std::vector<char> in;
|
std::vector<char> in;
|
||||||
if (load_file(state_path.toLocal8Bit().constData(), in) == 0)
|
if (load_file(state_path.toLocal8Bit().constData(), in) == 0)
|
||||||
@ -1865,12 +1866,12 @@ void Bittorrent::addConsoleMessage(QString msg, QString) {
|
|||||||
}
|
}
|
||||||
// We need this for urllib in search engine plugins
|
// We need this for urllib in search engine plugins
|
||||||
#ifdef Q_WS_WIN
|
#ifdef Q_WS_WIN
|
||||||
char proxystr[512];
|
QString proxyStr;
|
||||||
if(proxySettings.type == proxy_settings::socks5 || proxySettings.type == proxy_settings::socks5_pw)
|
if(proxySettings.type == proxy_settings::socks5 || proxySettings.type == proxy_settings::socks5_pw)
|
||||||
snprintf(proxystr, 512, "sock_proxy=%s", proxy_str.toLocal8Bit().constData());
|
proxyStr = "sock_proxy=" + proxy_str;
|
||||||
else
|
else
|
||||||
snprintf(proxystr, 512, "http_proxy=%s", proxy_str.toLocal8Bit().constData());
|
proxyStr = "http_proxy=" + proxy_str;
|
||||||
putenv(proxystr);
|
putenv(proxyStr.toLocal8Bit().constData());
|
||||||
#else
|
#else
|
||||||
qDebug("HTTP communications proxy string: %s", qPrintable(proxy_str));
|
qDebug("HTTP communications proxy string: %s", qPrintable(proxy_str));
|
||||||
if(proxySettings.type == proxy_settings::socks5 || proxySettings.type == proxy_settings::socks5_pw)
|
if(proxySettings.type == proxy_settings::socks5 || proxySettings.type == proxy_settings::socks5_pw)
|
||||||
|
@ -125,18 +125,17 @@ void engineSelectDlg::toggleEngineState(QTreeWidgetItem *item, int) {
|
|||||||
|
|
||||||
void engineSelectDlg::displayContextMenu(const QPoint&) {
|
void engineSelectDlg::displayContextMenu(const QPoint&) {
|
||||||
QMenu myContextMenu(this);
|
QMenu myContextMenu(this);
|
||||||
QModelIndex index;
|
|
||||||
// Enable/disable pause/start action given the DL state
|
// Enable/disable pause/start action given the DL state
|
||||||
QList<QTreeWidgetItem *> items = pluginsTree->selectedItems();
|
QList<QTreeWidgetItem *> items = pluginsTree->selectedItems();
|
||||||
bool has_enable = false, has_disable = false;
|
bool has_enable = false, has_disable = false;
|
||||||
QTreeWidgetItem *item;
|
QTreeWidgetItem *item;
|
||||||
foreach(item, items) {
|
foreach(item, items) {
|
||||||
QString id = item->text(ENGINE_ID);
|
QString id = item->text(ENGINE_ID);
|
||||||
if(supported_engines->value(id)->isEnabled() and !has_disable) {
|
if(supported_engines->value(id)->isEnabled() && !has_disable) {
|
||||||
myContextMenu.addAction(actionDisable);
|
myContextMenu.addAction(actionDisable);
|
||||||
has_disable = true;
|
has_disable = true;
|
||||||
}
|
}
|
||||||
if(!supported_engines->value(id)->isEnabled() and !has_enable) {
|
if(!supported_engines->value(id)->isEnabled() && !has_enable) {
|
||||||
myContextMenu.addAction(actionEnable);
|
myContextMenu.addAction(actionEnable);
|
||||||
has_enable = true;
|
has_enable = true;
|
||||||
}
|
}
|
||||||
|
@ -297,7 +297,7 @@ protected slots:
|
|||||||
default_path = QDir::homePath();
|
default_path = QDir::homePath();
|
||||||
}
|
}
|
||||||
QString dir = QFileDialog::getExistingDirectory(this, tr("Choose save path"), QDir::homePath());
|
QString dir = QFileDialog::getExistingDirectory(this, tr("Choose save path"), QDir::homePath());
|
||||||
if(!dir.isNull() and QDir(dir).exists()) {
|
if(!dir.isNull() && QDir(dir).exists()) {
|
||||||
savepath_line->setText(dir);
|
savepath_line->setText(dir);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -370,8 +370,6 @@ QString misc::cacheLocation() {
|
|||||||
return location;
|
return location;
|
||||||
}
|
}
|
||||||
|
|
||||||
long long misc::freeDiskSpaceOnPath(QString path);
|
|
||||||
|
|
||||||
// return best userfriendly storage unit (B, KiB, MiB, GiB, TiB)
|
// return best userfriendly storage unit (B, KiB, MiB, GiB, TiB)
|
||||||
// use Binary prefix standards from IEC 60027-2
|
// use Binary prefix standards from IEC 60027-2
|
||||||
// see http://en.wikipedia.org/wiki/Kilobyte
|
// see http://en.wikipedia.org/wiki/Kilobyte
|
||||||
|
@ -44,6 +44,8 @@
|
|||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
Q_DECLARE_METATYPE(QList<int>)
|
||||||
|
|
||||||
PeerListWidget::PeerListWidget(PropertiesWidget *parent): properties(parent), display_flags(false) {
|
PeerListWidget::PeerListWidget(PropertiesWidget *parent): properties(parent), display_flags(false) {
|
||||||
// Visual settings
|
// Visual settings
|
||||||
setRootIsDecorated(false);
|
setRootIsDecorated(false);
|
||||||
@ -244,10 +246,10 @@ void PeerListWidget::clear() {
|
|||||||
|
|
||||||
void PeerListWidget::loadSettings() {
|
void PeerListWidget::loadSettings() {
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
QVariantList contentColsWidths = settings.value(QString::fromUtf8("TorrentProperties/Peers/peersColsWidth"), QVariantList()).toList();
|
QList<int> contentColsWidths = settings.value(QString::fromUtf8("TorrentProperties/Peers/peersColsWidth"), QVariantList()).value<QList<int> >();
|
||||||
if(!contentColsWidths.empty()) {
|
if(!contentColsWidths.empty()) {
|
||||||
for(int i=0; i<contentColsWidths.size(); ++i) {
|
for(int i=0; i<contentColsWidths.size(); ++i) {
|
||||||
setColumnWidth(i, contentColsWidths.at(i).toInt());
|
setColumnWidth(i, contentColsWidths.at(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Load sorted column
|
// Load sorted column
|
||||||
@ -266,11 +268,11 @@ void PeerListWidget::loadSettings() {
|
|||||||
|
|
||||||
void PeerListWidget::saveSettings() const {
|
void PeerListWidget::saveSettings() const {
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
QVariantList contentColsWidths;
|
QList<int> contentColsWidths;
|
||||||
for(int i=0; i<listModel->columnCount(); ++i) {
|
for(int i=0; i<listModel->columnCount(); ++i) {
|
||||||
contentColsWidths.append(columnWidth(i));
|
contentColsWidths.append(columnWidth(i));
|
||||||
}
|
}
|
||||||
settings.setValue(QString::fromUtf8("TorrentProperties/Peers/peersColsWidth"), contentColsWidths);
|
settings.setValue(QString::fromUtf8("TorrentProperties/Peers/peersColsWidth"), QVariant::fromValue<QList<int> >(contentColsWidths));
|
||||||
// Save sorted column
|
// Save sorted column
|
||||||
Qt::SortOrder sortOrder = header()->sortIndicatorOrder();
|
Qt::SortOrder sortOrder = header()->sortIndicatorOrder();
|
||||||
QString sortOrderLetter;
|
QString sortOrderLetter;
|
||||||
|
@ -52,6 +52,8 @@
|
|||||||
#include "downloadedpiecesbar.h"
|
#include "downloadedpiecesbar.h"
|
||||||
#include "pieceavailabilitybar.h"
|
#include "pieceavailabilitybar.h"
|
||||||
|
|
||||||
|
Q_DECLARE_METATYPE(QList<int>)
|
||||||
|
|
||||||
#ifdef Q_WS_MAC
|
#ifdef Q_WS_MAC
|
||||||
#define DEFAULT_BUTTON_CSS "QPushButton {border: 1px solid rgb(85, 81, 91);border-radius: 3px;padding: 2px; margin-left: 8px; margin-right: 8px;}"
|
#define DEFAULT_BUTTON_CSS "QPushButton {border: 1px solid rgb(85, 81, 91);border-radius: 3px;padding: 2px; margin-left: 8px; margin-right: 8px;}"
|
||||||
#define SELECTED_BUTTON_CSS "QPushButton {border: 1px solid rgb(85, 81, 91);border-radius: 3px;padding: 2px;background-color: rgb(255, 208, 105); margin-left: 8px; margin-right: 8px;}"
|
#define SELECTED_BUTTON_CSS "QPushButton {border: 1px solid rgb(85, 81, 91);border-radius: 3px;padding: 2px;background-color: rgb(255, 208, 105); margin-left: 8px; margin-right: 8px;}"
|
||||||
@ -265,12 +267,12 @@ void PropertiesWidget::loadTorrentInfos(QTorrentHandle &_h) {
|
|||||||
|
|
||||||
void PropertiesWidget::readSettings() {
|
void PropertiesWidget::readSettings() {
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
QVariantList contentColsWidths = settings.value(QString::fromUtf8("TorrentProperties/filesColsWidth"), QVariantList()).toList();
|
QList<int> contentColsWidths = settings.value(QString::fromUtf8("TorrentProperties/filesColsWidth"), QVariantList()).value<QList<int> >();
|
||||||
if(contentColsWidths.empty()) {
|
if(contentColsWidths.empty()) {
|
||||||
filesList->header()->resizeSection(0, 300);
|
filesList->header()->resizeSection(0, 300);
|
||||||
} else {
|
} else {
|
||||||
for(int i=0; i<contentColsWidths.size(); ++i) {
|
for(int i=0; i<contentColsWidths.size(); ++i) {
|
||||||
filesList->setColumnWidth(i, contentColsWidths.at(i).toInt());
|
filesList->setColumnWidth(i, contentColsWidths.at(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Restore splitter sizes
|
// Restore splitter sizes
|
||||||
@ -292,11 +294,11 @@ void PropertiesWidget::readSettings() {
|
|||||||
void PropertiesWidget::saveSettings() {
|
void PropertiesWidget::saveSettings() {
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
settings.setValue("TorrentProperties/Visible", state==VISIBLE);
|
settings.setValue("TorrentProperties/Visible", state==VISIBLE);
|
||||||
QVariantList contentColsWidths;
|
QList<int> contentColsWidths;
|
||||||
for(int i=0; i<PropListModel->columnCount(); ++i) {
|
for(int i=0; i<PropListModel->columnCount(); ++i) {
|
||||||
contentColsWidths.append(filesList->columnWidth(i));
|
contentColsWidths.append(filesList->columnWidth(i));
|
||||||
}
|
}
|
||||||
settings.setValue(QString::fromUtf8("TorrentProperties/filesColsWidth"), contentColsWidths);
|
settings.setValue(QString::fromUtf8("TorrentProperties/filesColsWidth"), QVariant::fromValue<QList<int> >(contentColsWidths));
|
||||||
// Splitter sizes
|
// Splitter sizes
|
||||||
QSplitter *hSplitter = static_cast<QSplitter*>(parentWidget());
|
QSplitter *hSplitter = static_cast<QSplitter*>(parentWidget());
|
||||||
QList<int> sizes;
|
QList<int> sizes;
|
||||||
|
63
src/src.pro
63
src/src.pro
@ -22,14 +22,22 @@ DEFINES += VERSION_BUGFIX=0
|
|||||||
|
|
||||||
win32 {
|
win32 {
|
||||||
# Adapt these paths on Windows
|
# Adapt these paths on Windows
|
||||||
INCLUDEPATH += $$quote(C:/qbittorrent/boost_1_42_0)
|
INCLUDEPATH += $$quote(C:/qbittorrent/msvc/boost_1_42_0)
|
||||||
INCLUDEPATH += $$quote(C:/qbittorrent/libtorrent-rasterbar-0.14.10/include)
|
#INCLUDEPATH += $$quote(C:/qbittorrent/msvc/libtorrent-rasterbar-0.14.10/include)
|
||||||
INCLUDEPATH += $$quote(C:/qbittorrent/libtorrent-rasterbar-0.14.10/zlib)
|
#INCLUDEPATH += $$quote(C:/qbittorrent/msvc/libtorrent-rasterbar-0.14.10/zlib)
|
||||||
LIBS += -LC:/OpenSSL/
|
INCLUDEPATH += $$quote(C:/qbittorrent/msvc/RC_0_15/include)
|
||||||
|
INCLUDEPATH += $$quote(C:/qbittorrent/msvc/RC_0_15/zlib)
|
||||||
|
#DEFINES += LIBTORRENT_0_15
|
||||||
|
|
||||||
|
LIBS += -LC:/OpenSSL/lib/VC
|
||||||
|
LIBS += -LC:/qbittorrent/msvc/boost_1_42_0/stage/lib
|
||||||
|
|
||||||
DEFINES += _WIN32_WINNT=0x0601
|
DEFINES += _WIN32_WINNT=0x0601
|
||||||
DEFINES += _WIN32_IE=0x0400
|
DEFINES += _WIN32_IE=0x0400
|
||||||
DEFINES += _WIN32_WINDOWS
|
DEFINES += _WIN32_WINDOWS
|
||||||
|
|
||||||
|
QMAKE_CXXFLAGS_STL_ON = -EHa
|
||||||
|
QMAKE_CXXFLAGS_EXCEPTIONS_ON = -EHa
|
||||||
}
|
}
|
||||||
|
|
||||||
# NORMAL,ALPHA,BETA,RELEASE_CANDIDATE,DEVEL
|
# NORMAL,ALPHA,BETA,RELEASE_CANDIDATE,DEVEL
|
||||||
@ -136,13 +144,25 @@ DEFINES += QT_USE_FAST_CONCATENATION QT_USE_FAST_OPERATOR_PLUS
|
|||||||
win32 {
|
win32 {
|
||||||
RC_FILE = qbittorrent.rc
|
RC_FILE = qbittorrent.rc
|
||||||
|
|
||||||
|
LIBS += "/nodefaultlib:"msvcrt.lib"
|
||||||
|
LIBS += "/nodefaultlib:"msvcrtd.lib"
|
||||||
|
contains(DEBUG_MODE, 1) {
|
||||||
|
LIBS += "/nodefaultlib:"libcmt.lib"
|
||||||
|
}
|
||||||
|
|
||||||
# Adapt these paths on Windows
|
# Adapt these paths on Windows
|
||||||
LIBS += C:/qbittorrent/libs/libtorrent.lib \
|
contains(DEBUG_MODE, 1) {
|
||||||
C:/qbittorrent/libs/libboost_system-mgw44-mt-s.lib \
|
LIBS += C:/qbittorrent/msvc/libs/libtorrent-0.15d.lib
|
||||||
C:/qbittorrent/libs/libboost_filesystem-mgw44-mt-s.lib \
|
} else {
|
||||||
C:/qbittorrent/libs/libboost_thread-mgw44-mt-s.lib \
|
LIBS += C:/qbittorrent/msvc/libs/libtorrent.lib
|
||||||
C:/Qt/2010.02.1/mingw/lib/libwsock32.a \
|
}
|
||||||
C:/Qt/2010.02.1/mingw/lib/libws2_32.a #\
|
#LIBS += C:/qbittorrent/msvc/libs/libtorrent.lib #\
|
||||||
|
#C:/qbittorrent/msvc/libs/libboost_system-vc90-mt-s.lib \
|
||||||
|
#C:/qbittorrent/msvc/libs/libboost_filesystem-vc90-mt-s.lib \
|
||||||
|
#C:/qbittorrent/msvc/libs/libboost_thread-vc90-mt-s.lib \
|
||||||
|
#C:/qbittorrent/msvc/libs/libboost_date_time-vc90-mt-s.lib \
|
||||||
|
#C:/Qt/2010.02.1/mingw/lib/libwsock32.a \
|
||||||
|
#C:/Qt/2010.02.1/mingw/lib/libws2_32.a \
|
||||||
# C:/OpenSSL/lib/MinGW/ssleay32.a \
|
# C:/OpenSSL/lib/MinGW/ssleay32.a \
|
||||||
# C:/OpenSSL/lib/MinGW/libeay32.a \
|
# C:/OpenSSL/lib/MinGW/libeay32.a \
|
||||||
# -LC:/Qt/2010.02.1/mingw/lib/
|
# -LC:/Qt/2010.02.1/mingw/lib/
|
||||||
@ -151,12 +171,18 @@ win32 {
|
|||||||
# C:/Qt/2010.02.1/mingw/lib/libgdi32.a \
|
# C:/Qt/2010.02.1/mingw/lib/libgdi32.a \
|
||||||
|
|
||||||
# Dynamic linking against SSL since QtNetwork requires it at runtime anyway
|
# Dynamic linking against SSL since QtNetwork requires it at runtime anyway
|
||||||
LIBS += -lssleay32 \
|
#LIBS += -lws2_32 \
|
||||||
-leay32 #\
|
# -lwsock32 \
|
||||||
# -lws2_32 \
|
# -ladvapi32 \
|
||||||
# -lwsock32 \
|
# -lwinmm \
|
||||||
# -ladvapi32 \
|
# -lssleay32MT \
|
||||||
# -lwinmm
|
# -llibeay32MT
|
||||||
|
# -lshell32 \
|
||||||
|
|
||||||
|
#LIBS += gdi32.lib comdlg32.lib oleaut32.lib imm32.lib winmm.lib winspool.lib ws2_32.lib ole32.lib user32.lib advapi32.lib shell32.lib kernel32.lib uuid.lib
|
||||||
|
LIBS += advapi32.lib shell32.lib
|
||||||
|
LIBS += libeay32MT.lib ssleay32MT.lib
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
os2:LIBS += -ltorrent-rasterbar \
|
os2:LIBS += -ltorrent-rasterbar \
|
||||||
@ -336,11 +362,12 @@ SOURCES += main.cpp \
|
|||||||
engineselectdlg.cpp \
|
engineselectdlg.cpp \
|
||||||
searchtab.cpp \
|
searchtab.cpp \
|
||||||
ico.cpp \
|
ico.cpp \
|
||||||
rss.cpp \
|
rss.cpp \
|
||||||
transferlistwidget.cpp \
|
transferlistwidget.cpp \
|
||||||
propertieswidget.cpp \
|
propertieswidget.cpp \
|
||||||
peerlistwidget.cpp \
|
peerlistwidget.cpp \
|
||||||
cookiesdlg.cpp
|
cookiesdlg.cpp \
|
||||||
|
trackerlist.cpp
|
||||||
|
|
||||||
DESTDIR = .
|
DESTDIR = .
|
||||||
|
|
||||||
|
@ -75,8 +75,8 @@ public:
|
|||||||
url = engine_elem.elementsByTagName("url").at(0).toElement().text();
|
url = engine_elem.elementsByTagName("url").at(0).toElement().text();
|
||||||
supported_categories = engine_elem.elementsByTagName("categories").at(0).toElement().text().split(" ");
|
supported_categories = engine_elem.elementsByTagName("categories").at(0).toElement().text().split(" ");
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
QVariantList disabled_engines = settings.value(QString::fromUtf8("SearchEngines/disabledEngines"), QVariantList()).toList();
|
QStringList disabled_engines = settings.value(QString::fromUtf8("SearchEngines/disabledEngines"), QStringList()).toStringList();
|
||||||
enabled = !disabled_engines.contains(QVariant(name));
|
enabled = !disabled_engines.contains(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString getName() const { return name; }
|
QString getName() const { return name; }
|
||||||
@ -88,11 +88,11 @@ public:
|
|||||||
enabled = _enabled;
|
enabled = _enabled;
|
||||||
// Save to Hard disk
|
// Save to Hard disk
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
QVariantList disabled_engines = settings.value(QString::fromUtf8("SearchEngines/disabledEngines"), QVariantList()).toList();
|
QStringList disabled_engines = settings.value(QString::fromUtf8("SearchEngines/disabledEngines"), QStringList()).toStringList();
|
||||||
if(enabled) {
|
if(enabled) {
|
||||||
disabled_engines.removeAll(QVariant(name));
|
disabled_engines.removeAll(name);
|
||||||
} else {
|
} else {
|
||||||
disabled_engines.append(QVariant(name));
|
disabled_engines.append(name);
|
||||||
}
|
}
|
||||||
settings.setValue("SearchEngines/disabledEngines", disabled_engines);
|
settings.setValue("SearchEngines/disabledEngines", disabled_engines);
|
||||||
}
|
}
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
#include "transferlistwidget.h"
|
#include "transferlistwidget.h"
|
||||||
|
|
||||||
using namespace libtorrent;
|
using namespace libtorrent;
|
||||||
|
Q_DECLARE_METATYPE(QList<int>)
|
||||||
|
|
||||||
class torrentAdditionDialog : public QDialog, private Ui_addTorrentDialog{
|
class torrentAdditionDialog : public QDialog, private Ui_addTorrentDialog{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -125,12 +126,12 @@ public:
|
|||||||
resize(settings.value(QString::fromUtf8("TorrentAdditionDlg/size"), size()).toSize());
|
resize(settings.value(QString::fromUtf8("TorrentAdditionDlg/size"), size()).toSize());
|
||||||
move(settings.value(QString::fromUtf8("TorrentAdditionDlg/pos"), misc::screenCenter(this)).toPoint());
|
move(settings.value(QString::fromUtf8("TorrentAdditionDlg/pos"), misc::screenCenter(this)).toPoint());
|
||||||
// Restore column width
|
// Restore column width
|
||||||
const QVariantList &contentColsWidths = settings.value(QString::fromUtf8("TorrentAdditionDlg/filesColsWidth"), QVariantList()).toList();
|
const QList<int> &contentColsWidths = settings.value(QString::fromUtf8("TorrentAdditionDlg/filesColsWidth")).value<QList<int> >();
|
||||||
if(contentColsWidths.empty()) {
|
if(contentColsWidths.empty()) {
|
||||||
torrentContentList->header()->resizeSection(0, 200);
|
torrentContentList->header()->resizeSection(0, 200);
|
||||||
} else {
|
} else {
|
||||||
for(int i=0; i<contentColsWidths.size(); ++i) {
|
for(int i=0; i<contentColsWidths.size(); ++i) {
|
||||||
torrentContentList->setColumnWidth(i, contentColsWidths.at(i).toInt());
|
torrentContentList->setColumnWidth(i, contentColsWidths.at(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -138,12 +139,12 @@ public:
|
|||||||
void saveSettings() {
|
void saveSettings() {
|
||||||
if(is_magnet) return;
|
if(is_magnet) return;
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
QVariantList contentColsWidths;
|
QList<int> contentColsWidths;
|
||||||
// -1 because we hid PROGRESS column
|
// -1 because we hid PROGRESS column
|
||||||
for(int i=0; i<PropListModel->columnCount()-1; ++i) {
|
for(int i=0; i<PropListModel->columnCount()-1; ++i) {
|
||||||
contentColsWidths.append(torrentContentList->columnWidth(i));
|
contentColsWidths.append(torrentContentList->columnWidth(i));
|
||||||
}
|
}
|
||||||
settings.setValue(QString::fromUtf8("TorrentAdditionDlg/filesColsWidth"), contentColsWidths);
|
settings.setValue(QString::fromUtf8("TorrentAdditionDlg/filesColsWidth"), QVariant::fromValue<QList<int> >(contentColsWidths));
|
||||||
settings.setValue("TorrentAdditionDlg/size", size());
|
settings.setValue("TorrentAdditionDlg/size", size());
|
||||||
settings.setValue("TorrentAdditionDlg/pos", pos());
|
settings.setValue("TorrentAdditionDlg/pos", pos());
|
||||||
}
|
}
|
||||||
|
383
src/trackerlist.cpp
Normal file
383
src/trackerlist.cpp
Normal file
@ -0,0 +1,383 @@
|
|||||||
|
/*
|
||||||
|
* Bittorrent Client using Qt4 and libtorrent.
|
||||||
|
* Copyright (C) 2006 Christophe Dumez
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* In addition, as a special exception, the copyright holders give permission to
|
||||||
|
* link this program with the OpenSSL project's "OpenSSL" library (or with
|
||||||
|
* modified versions of it that use the same license as the "OpenSSL" library),
|
||||||
|
* and distribute the linked executables. You must obey the GNU General Public
|
||||||
|
* License in all respects for all of the code used other than "OpenSSL". If you
|
||||||
|
* modify file(s), you may extend this exception to your version of the file(s),
|
||||||
|
* but you are not obligated to do so. If you do not wish to do so, delete this
|
||||||
|
* exception statement from your version.
|
||||||
|
*
|
||||||
|
* Contact : chris@qbittorrent.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <QTreeWidgetItem>
|
||||||
|
#include <QStringList>
|
||||||
|
#include <QMenu>
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QHash>
|
||||||
|
#include <QAction>
|
||||||
|
#include <QColor>
|
||||||
|
|
||||||
|
#include "trackerlist.h"
|
||||||
|
#include "propertieswidget.h"
|
||||||
|
#include "trackersadditiondlg.h"
|
||||||
|
#include "misc.h"
|
||||||
|
#include "bittorrent.h"
|
||||||
|
|
||||||
|
Q_DECLARE_METATYPE(QList<int>)
|
||||||
|
|
||||||
|
TrackerList::TrackerList(PropertiesWidget *properties): QTreeWidget(), properties(properties) {
|
||||||
|
// Graphical settings
|
||||||
|
setRootIsDecorated(false);
|
||||||
|
setAllColumnsShowFocus(true);
|
||||||
|
setItemsExpandable(false);
|
||||||
|
setSelectionMode(QAbstractItemView::ExtendedSelection);
|
||||||
|
// Context menu
|
||||||
|
setContextMenuPolicy(Qt::CustomContextMenu);
|
||||||
|
connect(this, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(showTrackerListMenu(QPoint)));
|
||||||
|
// Set header
|
||||||
|
QStringList header;
|
||||||
|
header << tr("URL");
|
||||||
|
header << tr("Status");
|
||||||
|
header << tr("Peers");
|
||||||
|
header << tr("Message");
|
||||||
|
setHeaderItem(new QTreeWidgetItem(header));
|
||||||
|
dht_item = new QTreeWidgetItem(QStringList("** "+tr("[DHT]")+" **"));
|
||||||
|
insertTopLevelItem(0, dht_item);
|
||||||
|
setRowColor(0, QColor("grey"));
|
||||||
|
pex_item = new QTreeWidgetItem(QStringList("** "+tr("[PeX]")+" **"));
|
||||||
|
insertTopLevelItem(1, pex_item);
|
||||||
|
setRowColor(1, QColor("grey"));
|
||||||
|
lsd_item = new QTreeWidgetItem(QStringList("** "+tr("[LSD]")+" **"));
|
||||||
|
insertTopLevelItem(2, lsd_item);
|
||||||
|
setRowColor(2, QColor("grey"));
|
||||||
|
loadSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
TrackerList::~TrackerList() {
|
||||||
|
saveSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<QTreeWidgetItem*> TrackerList::getSelectedTrackerItems() const {
|
||||||
|
QList<QTreeWidgetItem*> selected_items = selectedItems();
|
||||||
|
QList<QTreeWidgetItem*> selected_trackers;
|
||||||
|
foreach(QTreeWidgetItem *item, selectedItems()) {
|
||||||
|
if(indexOfTopLevelItem(item) >= NB_STICKY_ITEM) { // Ignore STICKY ITEMS
|
||||||
|
selected_trackers << item;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return selected_trackers;
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::setRowColor(int row, QColor color) {
|
||||||
|
unsigned int nbColumns = columnCount();
|
||||||
|
QTreeWidgetItem *item = topLevelItem(row);
|
||||||
|
for(unsigned int i=0; i<nbColumns; ++i) {
|
||||||
|
item->setData(i, Qt::ForegroundRole, color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef LIBTORRENT_0_15
|
||||||
|
void TrackerList::moveSelectionUp() {
|
||||||
|
QTorrentHandle h = properties->getCurrentTorrent();
|
||||||
|
if(!h.is_valid()) {
|
||||||
|
clear();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
QList<QTreeWidgetItem *> selected_items = getSelectedTrackerItems();
|
||||||
|
if(selected_items.isEmpty()) return;
|
||||||
|
bool change = false;
|
||||||
|
foreach(QTreeWidgetItem *item, selected_items){
|
||||||
|
int index = indexOfTopLevelItem(item);
|
||||||
|
if(index > NB_STICKY_ITEM) {
|
||||||
|
insertTopLevelItem(index-1, takeTopLevelItem(index));
|
||||||
|
change = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!change) return;
|
||||||
|
// Restore selection
|
||||||
|
QItemSelectionModel *selection = selectionModel();
|
||||||
|
foreach(QTreeWidgetItem *item, selected_items) {
|
||||||
|
selection->select(indexFromItem(item), QItemSelectionModel::Rows|QItemSelectionModel::Select);
|
||||||
|
}
|
||||||
|
setSelectionModel(selection);
|
||||||
|
// Update torrent trackers
|
||||||
|
std::vector<announce_entry> trackers;
|
||||||
|
for(int i=NB_STICKY_ITEM; i<topLevelItemCount(); ++i) {
|
||||||
|
QString tracker_url = topLevelItem(i)->data(COL_URL, Qt::DisplayRole).toString();
|
||||||
|
announce_entry e(tracker_url.toStdString());
|
||||||
|
e.tier = i-NB_STICKY_ITEM;
|
||||||
|
trackers.push_back(e);
|
||||||
|
}
|
||||||
|
h.replace_trackers(trackers);
|
||||||
|
// Reannounce
|
||||||
|
h.force_reannounce();
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::moveSelectionDown() {
|
||||||
|
QTorrentHandle h = properties->getCurrentTorrent();
|
||||||
|
if(!h.is_valid()) {
|
||||||
|
clear();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
QList<QTreeWidgetItem *> selected_items = getSelectedTrackerItems();
|
||||||
|
if(selected_items.isEmpty()) return;
|
||||||
|
bool change = false;
|
||||||
|
for(int i=selectedItems().size()-1; i>= 0; --i) {
|
||||||
|
int index = indexOfTopLevelItem(selected_items.at(i));
|
||||||
|
if(index < topLevelItemCount()-1) {
|
||||||
|
insertTopLevelItem(index+1, takeTopLevelItem(index));
|
||||||
|
change = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!change) return;
|
||||||
|
// Restore selection
|
||||||
|
QItemSelectionModel *selection = selectionModel();
|
||||||
|
foreach(QTreeWidgetItem *item, selected_items) {
|
||||||
|
selection->select(indexFromItem(item), QItemSelectionModel::Rows|QItemSelectionModel::Select);
|
||||||
|
}
|
||||||
|
setSelectionModel(selection);
|
||||||
|
// Update torrent trackers
|
||||||
|
std::vector<announce_entry> trackers;
|
||||||
|
for(int i=NB_STICKY_ITEM; i<topLevelItemCount(); ++i) {
|
||||||
|
QString tracker_url = topLevelItem(i)->data(COL_URL, Qt::DisplayRole).toString();
|
||||||
|
announce_entry e(tracker_url.toStdString());
|
||||||
|
e.tier = i-NB_STICKY_ITEM;
|
||||||
|
trackers.push_back(e);
|
||||||
|
}
|
||||||
|
h.replace_trackers(trackers);
|
||||||
|
// Reannounce
|
||||||
|
h.force_reannounce();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void TrackerList::clear() {
|
||||||
|
qDeleteAll(tracker_items.values());
|
||||||
|
tracker_items.clear();
|
||||||
|
dht_item->setText(COL_PEERS, "");
|
||||||
|
dht_item->setText(COL_STATUS, "");
|
||||||
|
dht_item->setText(COL_MSG, "");
|
||||||
|
pex_item->setText(COL_PEERS, "");
|
||||||
|
pex_item->setText(COL_STATUS, "");
|
||||||
|
pex_item->setText(COL_MSG, "");
|
||||||
|
lsd_item->setText(COL_PEERS, "");
|
||||||
|
lsd_item->setText(COL_STATUS, "");
|
||||||
|
lsd_item->setText(COL_MSG, "");
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::loadStickyItems(const QTorrentHandle &h) {
|
||||||
|
// XXX: libtorrent should provide this info...
|
||||||
|
// Count peers from DHT, LSD, PeX
|
||||||
|
uint nb_dht=0, nb_lsd=0, nb_pex=0;
|
||||||
|
std::vector<peer_info> peers;
|
||||||
|
h.get_peer_info(peers);
|
||||||
|
std::vector<peer_info>::iterator it;
|
||||||
|
for(it=peers.begin(); it!=peers.end(); it++) {
|
||||||
|
if(it->source & peer_info::dht)
|
||||||
|
++nb_dht;
|
||||||
|
if(it->source & peer_info::lsd)
|
||||||
|
++nb_lsd;
|
||||||
|
if(it->source & peer_info::pex)
|
||||||
|
++nb_pex;
|
||||||
|
}
|
||||||
|
// load DHT information
|
||||||
|
if(properties->getBTSession()->isDHTEnabled() && h.has_metadata() && !h.priv()) {
|
||||||
|
dht_item->setText(COL_STATUS, tr("Working"));
|
||||||
|
} else {
|
||||||
|
dht_item->setText(COL_STATUS, tr("Disabled"));
|
||||||
|
}
|
||||||
|
dht_item->setText(COL_PEERS, QString::number(nb_dht));
|
||||||
|
if(h.has_metadata() && h.priv()) {
|
||||||
|
dht_item->setText(COL_MSG, tr("This torrent is private"));
|
||||||
|
}
|
||||||
|
// Load PeX Information
|
||||||
|
pex_item->setText(COL_STATUS, tr("Working"));
|
||||||
|
pex_item->setText(COL_PEERS, QString::number(nb_pex));
|
||||||
|
// Load LSD Information
|
||||||
|
if(properties->getBTSession()->isLSDEnabled())
|
||||||
|
lsd_item->setText(COL_STATUS, tr("Working"));
|
||||||
|
else
|
||||||
|
lsd_item->setText(COL_STATUS, tr("Disabled"));
|
||||||
|
lsd_item->setText(COL_PEERS, QString::number(nb_lsd));
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::loadTrackers() {
|
||||||
|
// Load trackers from torrent handle
|
||||||
|
QTorrentHandle h = properties->getCurrentTorrent();
|
||||||
|
if(!h.is_valid()) return;
|
||||||
|
loadStickyItems(h);
|
||||||
|
// Load actual trackers information
|
||||||
|
QHash<QString, TrackerInfos> trackers_data = properties->getBTSession()->getTrackersInfo(h.hash());
|
||||||
|
QStringList old_trackers_urls = tracker_items.keys();
|
||||||
|
std::vector<announce_entry> trackers = h.trackers();
|
||||||
|
std::vector<announce_entry>::iterator it;
|
||||||
|
for(it = trackers.begin(); it != trackers.end(); it++) {
|
||||||
|
QStringList item_list;
|
||||||
|
QString tracker_url = misc::toQString(it->url);
|
||||||
|
QTreeWidgetItem *item = tracker_items.value(tracker_url, 0);
|
||||||
|
if(!item) {
|
||||||
|
item = new QTreeWidgetItem();
|
||||||
|
item->setText(COL_URL, tracker_url);
|
||||||
|
addTopLevelItem(item);
|
||||||
|
tracker_items[tracker_url] = item;
|
||||||
|
} else {
|
||||||
|
old_trackers_urls.removeOne(tracker_url);
|
||||||
|
}
|
||||||
|
TrackerInfos data = trackers_data.value(tracker_url, TrackerInfos(tracker_url));
|
||||||
|
QString error_message = data.last_message.trimmed();
|
||||||
|
#ifdef LIBTORRENT_0_15
|
||||||
|
if(it->verified) {
|
||||||
|
item->setText(COL_STATUS, tr("Working"));
|
||||||
|
item->setText(COL_MSG, "");
|
||||||
|
} else {
|
||||||
|
if(it->updating && it->fails == 0) {
|
||||||
|
item->setText(COL_STATUS, tr("Updating..."));
|
||||||
|
item->setText(COL_MSG, "");
|
||||||
|
} else {
|
||||||
|
if(it->fails > 0) {
|
||||||
|
item->setText(COL_STATUS, tr("Not working"));
|
||||||
|
item->setText(COL_MSG, error_message);
|
||||||
|
} else {
|
||||||
|
item->setText(COL_STATUS, tr("Not contacted yet"));
|
||||||
|
item->setText(COL_MSG, "");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
if(data.verified) {
|
||||||
|
item->setText(COL_STATUS, tr("Working"));
|
||||||
|
item->setText(COL_MSG, "");
|
||||||
|
} else {
|
||||||
|
if(data.fail_count > 0) {
|
||||||
|
item->setText(COL_STATUS, tr("Not working"));
|
||||||
|
item->setText(COL_MSG, error_message);
|
||||||
|
} else {
|
||||||
|
item->setText(COL_STATUS, tr("Not contacted yet"));
|
||||||
|
item->setText(COL_MSG, "");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
item->setText(COL_PEERS, QString::number(trackers_data.value(tracker_url, TrackerInfos(tracker_url)).num_peers));
|
||||||
|
}
|
||||||
|
// Remove old trackers
|
||||||
|
foreach(const QString &tracker, old_trackers_urls) {
|
||||||
|
delete tracker_items.take(tracker);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ask the user for new trackers and add them to the torrent
|
||||||
|
void TrackerList::askForTrackers(){
|
||||||
|
QTorrentHandle h = properties->getCurrentTorrent();
|
||||||
|
if(!h.is_valid()) return;
|
||||||
|
QStringList trackers = TrackersAdditionDlg::askForTrackers(h);
|
||||||
|
if(!trackers.empty()) {
|
||||||
|
foreach(const QString& tracker, trackers) {
|
||||||
|
announce_entry url(tracker.toStdString());
|
||||||
|
url.tier = 0;
|
||||||
|
h.add_tracker(url);
|
||||||
|
}
|
||||||
|
// Reannounce to new trackers
|
||||||
|
h.force_reannounce();
|
||||||
|
// Reload tracker list
|
||||||
|
loadTrackers();
|
||||||
|
// XXX: I don't think this is necessary now
|
||||||
|
//BTSession->saveTrackerFile(h.hash());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::deleteSelectedTrackers(){
|
||||||
|
QTorrentHandle h = properties->getCurrentTorrent();
|
||||||
|
if(!h.is_valid()) {
|
||||||
|
clear();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
QList<QTreeWidgetItem *> selected_items = getSelectedTrackerItems();
|
||||||
|
if(selected_items.isEmpty()) return;
|
||||||
|
QStringList urls_to_remove;
|
||||||
|
foreach(QTreeWidgetItem *item, selected_items){
|
||||||
|
QString tracker_url = item->data(COL_URL, Qt::DisplayRole).toString();
|
||||||
|
urls_to_remove << tracker_url;
|
||||||
|
tracker_items.remove(tracker_url);
|
||||||
|
delete item;
|
||||||
|
}
|
||||||
|
// Iterate of trackers and remove selected ones
|
||||||
|
std::vector<announce_entry> trackers = h.trackers();
|
||||||
|
std::vector<announce_entry>::iterator it = trackers.begin();
|
||||||
|
while(it != trackers.end()) {
|
||||||
|
int index = urls_to_remove.indexOf(misc::toQString((*it).url));
|
||||||
|
if(index >= 0) {
|
||||||
|
trackers.erase(it);
|
||||||
|
urls_to_remove.removeAt(index);
|
||||||
|
} else {
|
||||||
|
it++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
h.replace_trackers(trackers);
|
||||||
|
h.force_reannounce();
|
||||||
|
// Reload Trackers
|
||||||
|
loadTrackers();
|
||||||
|
//XXX: I don't think this is necessary
|
||||||
|
//BTSession->saveTrackerFile(h.hash());
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::showTrackerListMenu(QPoint) {
|
||||||
|
QTorrentHandle h = properties->getCurrentTorrent();
|
||||||
|
if(!h.is_valid() || !h.has_metadata()) return;
|
||||||
|
QList<QTreeWidgetItem*> selected_items = getSelectedTrackerItems();
|
||||||
|
QMenu menu;
|
||||||
|
// Add actions
|
||||||
|
QAction *addAct = menu.addAction(QIcon(":/Icons/oxygen/list-add.png"), tr("Add a new tracker"));
|
||||||
|
QAction *delAct = 0;
|
||||||
|
if(!getSelectedTrackerItems().isEmpty()) {
|
||||||
|
delAct = menu.addAction(QIcon(":/Icons/oxygen/list-remove.png"), "Remove tracker");
|
||||||
|
}
|
||||||
|
QAction *act = menu.exec(QCursor::pos());
|
||||||
|
if(act == 0) return;
|
||||||
|
if(act == addAct) {
|
||||||
|
askForTrackers();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(act == delAct) {
|
||||||
|
deleteSelectedTrackers();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::loadSettings() {
|
||||||
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
|
QList<int> contentColsWidths = settings.value(QString::fromUtf8("TorrentProperties/Trackers/trackersColsWidth")).value<QList<int> >();
|
||||||
|
if(!contentColsWidths.empty()) {
|
||||||
|
for(int i=0; i<contentColsWidths.size(); ++i) {
|
||||||
|
setColumnWidth(i, contentColsWidths.at(i));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
setColumnWidth(0, 300);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrackerList::saveSettings() const {
|
||||||
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
|
QList<int> contentColsWidths;
|
||||||
|
for(int i=0; i<columnCount(); ++i) {
|
||||||
|
contentColsWidths.append(columnWidth(i));
|
||||||
|
}
|
||||||
|
settings.setValue(QString::fromUtf8("TorrentProperties/Trackers/trackersColsWidth"), QVariant::fromValue<QList<int> >(contentColsWidths));
|
||||||
|
}
|
@ -32,21 +32,16 @@
|
|||||||
#define TRACKERLIST_H
|
#define TRACKERLIST_H
|
||||||
|
|
||||||
#include <QTreeWidget>
|
#include <QTreeWidget>
|
||||||
#include <QTreeWidgetItem>
|
#include <QList>
|
||||||
#include <QStringList>
|
|
||||||
#include <QMenu>
|
#include "qtorrenthandle.h"
|
||||||
#include <QSettings>
|
|
||||||
#include <QHash>
|
|
||||||
#include <QAction>
|
|
||||||
#include <QColor>
|
|
||||||
#include "propertieswidget.h"
|
|
||||||
#include "trackersadditiondlg.h"
|
|
||||||
#include "misc.h"
|
|
||||||
#include "bittorrent.h"
|
|
||||||
|
|
||||||
enum TrackerListColumn {COL_URL, COL_STATUS, COL_PEERS, COL_MSG};
|
enum TrackerListColumn {COL_URL, COL_STATUS, COL_PEERS, COL_MSG};
|
||||||
#define NB_STICKY_ITEM 3
|
#define NB_STICKY_ITEM 3
|
||||||
|
|
||||||
|
struct QTreeWidgetItem;
|
||||||
|
struct PropertiesWidget;
|
||||||
|
|
||||||
class TrackerList: public QTreeWidget {
|
class TrackerList: public QTreeWidget {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
@ -58,346 +53,28 @@ private:
|
|||||||
QTreeWidgetItem* lsd_item;
|
QTreeWidgetItem* lsd_item;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
TrackerList(PropertiesWidget *properties): QTreeWidget(), properties(properties) {
|
TrackerList(PropertiesWidget *properties);
|
||||||
// Graphical settings
|
~TrackerList();
|
||||||
setRootIsDecorated(false);
|
|
||||||
setAllColumnsShowFocus(true);
|
|
||||||
setItemsExpandable(false);
|
|
||||||
setSelectionMode(QAbstractItemView::ExtendedSelection);
|
|
||||||
// Context menu
|
|
||||||
setContextMenuPolicy(Qt::CustomContextMenu);
|
|
||||||
connect(this, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(showTrackerListMenu(QPoint)));
|
|
||||||
// Set header
|
|
||||||
QStringList header;
|
|
||||||
header << tr("URL");
|
|
||||||
header << tr("Status");
|
|
||||||
header << tr("Peers");
|
|
||||||
header << tr("Message");
|
|
||||||
setHeaderItem(new QTreeWidgetItem(header));
|
|
||||||
dht_item = new QTreeWidgetItem(QStringList("** "+tr("[DHT]")+" **"));
|
|
||||||
insertTopLevelItem(0, dht_item);
|
|
||||||
setRowColor(0, QColor("grey"));
|
|
||||||
pex_item = new QTreeWidgetItem(QStringList("** "+tr("[PeX]")+" **"));
|
|
||||||
insertTopLevelItem(1, pex_item);
|
|
||||||
setRowColor(1, QColor("grey"));
|
|
||||||
lsd_item = new QTreeWidgetItem(QStringList("** "+tr("[LSD]")+" **"));
|
|
||||||
insertTopLevelItem(2, lsd_item);
|
|
||||||
setRowColor(2, QColor("grey"));
|
|
||||||
loadSettings();
|
|
||||||
}
|
|
||||||
|
|
||||||
~TrackerList() {
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
QList<QTreeWidgetItem*> getSelectedTrackerItems() const {
|
QList<QTreeWidgetItem*> getSelectedTrackerItems() const;
|
||||||
QList<QTreeWidgetItem*> selected_items = selectedItems();
|
|
||||||
QList<QTreeWidgetItem*> selected_trackers;
|
|
||||||
foreach(QTreeWidgetItem *item, selectedItems()) {
|
|
||||||
if(indexOfTopLevelItem(item) >= NB_STICKY_ITEM) { // Ignore STICKY ITEMS
|
|
||||||
selected_trackers << item;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return selected_trackers;
|
|
||||||
}
|
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
void setRowColor(int row, QColor color);
|
||||||
void setRowColor(int row, QColor color) {
|
|
||||||
unsigned int nbColumns = columnCount();
|
|
||||||
QTreeWidgetItem *item = topLevelItem(row);
|
|
||||||
for(unsigned int i=0; i<nbColumns; ++i) {
|
|
||||||
item->setData(i, Qt::ForegroundRole, color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef LIBTORRENT_0_15
|
#ifndef LIBTORRENT_0_15
|
||||||
void moveSelectionUp() {
|
void moveSelectionUp();
|
||||||
QTorrentHandle h = properties->getCurrentTorrent();
|
void moveSelectionDown();
|
||||||
if(!h.is_valid()) {
|
|
||||||
clear();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
QList<QTreeWidgetItem *> selected_items = getSelectedTrackerItems();
|
|
||||||
if(selected_items.isEmpty()) return;
|
|
||||||
bool change = false;
|
|
||||||
foreach(QTreeWidgetItem *item, selected_items){
|
|
||||||
int index = indexOfTopLevelItem(item);
|
|
||||||
if(index > NB_STICKY_ITEM) {
|
|
||||||
insertTopLevelItem(index-1, takeTopLevelItem(index));
|
|
||||||
change = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(!change) return;
|
|
||||||
// Restore selection
|
|
||||||
QItemSelectionModel *selection = selectionModel();
|
|
||||||
foreach(QTreeWidgetItem *item, selected_items) {
|
|
||||||
selection->select(indexFromItem(item), QItemSelectionModel::Rows|QItemSelectionModel::Select);
|
|
||||||
}
|
|
||||||
setSelectionModel(selection);
|
|
||||||
// Update torrent trackers
|
|
||||||
std::vector<announce_entry> trackers;
|
|
||||||
for(int i=NB_STICKY_ITEM; i<topLevelItemCount(); ++i) {
|
|
||||||
QString tracker_url = topLevelItem(i)->data(COL_URL, Qt::DisplayRole).toString();
|
|
||||||
announce_entry e(tracker_url.toStdString());
|
|
||||||
e.tier = i-NB_STICKY_ITEM;
|
|
||||||
trackers.push_back(e);
|
|
||||||
}
|
|
||||||
h.replace_trackers(trackers);
|
|
||||||
// Reannounce
|
|
||||||
h.force_reannounce();
|
|
||||||
}
|
|
||||||
|
|
||||||
void moveSelectionDown() {
|
|
||||||
QTorrentHandle h = properties->getCurrentTorrent();
|
|
||||||
if(!h.is_valid()) {
|
|
||||||
clear();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
QList<QTreeWidgetItem *> selected_items = getSelectedTrackerItems();
|
|
||||||
if(selected_items.isEmpty()) return;
|
|
||||||
bool change = false;
|
|
||||||
for(int i=selectedItems().size()-1; i>= 0; --i) {
|
|
||||||
int index = indexOfTopLevelItem(selected_items.at(i));
|
|
||||||
if(index < topLevelItemCount()-1) {
|
|
||||||
insertTopLevelItem(index+1, takeTopLevelItem(index));
|
|
||||||
change = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(!change) return;
|
|
||||||
// Restore selection
|
|
||||||
QItemSelectionModel *selection = selectionModel();
|
|
||||||
foreach(QTreeWidgetItem *item, selected_items) {
|
|
||||||
selection->select(indexFromItem(item), QItemSelectionModel::Rows|QItemSelectionModel::Select);
|
|
||||||
}
|
|
||||||
setSelectionModel(selection);
|
|
||||||
// Update torrent trackers
|
|
||||||
std::vector<announce_entry> trackers;
|
|
||||||
for(int i=NB_STICKY_ITEM; i<topLevelItemCount(); ++i) {
|
|
||||||
QString tracker_url = topLevelItem(i)->data(COL_URL, Qt::DisplayRole).toString();
|
|
||||||
announce_entry e(tracker_url.toStdString());
|
|
||||||
e.tier = i-NB_STICKY_ITEM;
|
|
||||||
trackers.push_back(e);
|
|
||||||
}
|
|
||||||
h.replace_trackers(trackers);
|
|
||||||
// Reannounce
|
|
||||||
h.force_reannounce();
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void clear() {
|
void clear();
|
||||||
qDeleteAll(tracker_items.values());
|
void loadStickyItems(const QTorrentHandle &h);
|
||||||
tracker_items.clear();
|
void loadTrackers();
|
||||||
dht_item->setText(COL_PEERS, "");
|
void askForTrackers();
|
||||||
dht_item->setText(COL_STATUS, "");
|
void deleteSelectedTrackers();
|
||||||
dht_item->setText(COL_MSG, "");
|
void showTrackerListMenu(QPoint);
|
||||||
pex_item->setText(COL_PEERS, "");
|
void loadSettings();
|
||||||
pex_item->setText(COL_STATUS, "");
|
void saveSettings() const;
|
||||||
pex_item->setText(COL_MSG, "");
|
|
||||||
lsd_item->setText(COL_PEERS, "");
|
|
||||||
lsd_item->setText(COL_STATUS, "");
|
|
||||||
lsd_item->setText(COL_MSG, "");
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadStickyItems(const QTorrentHandle &h) {
|
|
||||||
// XXX: libtorrent should provide this info...
|
|
||||||
// Count peers from DHT, LSD, PeX
|
|
||||||
uint nb_dht=0, nb_lsd=0, nb_pex=0;
|
|
||||||
std::vector<peer_info> peers;
|
|
||||||
h.get_peer_info(peers);
|
|
||||||
std::vector<peer_info>::iterator it;
|
|
||||||
for(it=peers.begin(); it!=peers.end(); it++) {
|
|
||||||
if(it->source & peer_info::dht)
|
|
||||||
++nb_dht;
|
|
||||||
if(it->source & peer_info::lsd)
|
|
||||||
++nb_lsd;
|
|
||||||
if(it->source & peer_info::pex)
|
|
||||||
++nb_pex;
|
|
||||||
}
|
|
||||||
// load DHT information
|
|
||||||
if(properties->getBTSession()->isDHTEnabled() && h.has_metadata() && !h.priv()) {
|
|
||||||
dht_item->setText(COL_STATUS, tr("Working"));
|
|
||||||
} else {
|
|
||||||
dht_item->setText(COL_STATUS, tr("Disabled"));
|
|
||||||
}
|
|
||||||
dht_item->setText(COL_PEERS, QString::number(nb_dht));
|
|
||||||
if(h.has_metadata() && h.priv()) {
|
|
||||||
dht_item->setText(COL_MSG, tr("This torrent is private"));
|
|
||||||
}
|
|
||||||
// Load PeX Information
|
|
||||||
pex_item->setText(COL_STATUS, tr("Working"));
|
|
||||||
pex_item->setText(COL_PEERS, QString::number(nb_pex));
|
|
||||||
// Load LSD Information
|
|
||||||
if(properties->getBTSession()->isLSDEnabled())
|
|
||||||
lsd_item->setText(COL_STATUS, tr("Working"));
|
|
||||||
else
|
|
||||||
lsd_item->setText(COL_STATUS, tr("Disabled"));
|
|
||||||
lsd_item->setText(COL_PEERS, QString::number(nb_lsd));
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadTrackers() {
|
|
||||||
// Load trackers from torrent handle
|
|
||||||
QTorrentHandle h = properties->getCurrentTorrent();
|
|
||||||
if(!h.is_valid()) return;
|
|
||||||
loadStickyItems(h);
|
|
||||||
// Load actual trackers information
|
|
||||||
QHash<QString, TrackerInfos> trackers_data = properties->getBTSession()->getTrackersInfo(h.hash());
|
|
||||||
QStringList old_trackers_urls = tracker_items.keys();
|
|
||||||
std::vector<announce_entry> trackers = h.trackers();
|
|
||||||
std::vector<announce_entry>::iterator it;
|
|
||||||
for(it = trackers.begin(); it != trackers.end(); it++) {
|
|
||||||
QStringList item_list;
|
|
||||||
QString tracker_url = misc::toQString(it->url);
|
|
||||||
QTreeWidgetItem *item = tracker_items.value(tracker_url, 0);
|
|
||||||
if(!item) {
|
|
||||||
item = new QTreeWidgetItem();
|
|
||||||
item->setText(COL_URL, tracker_url);
|
|
||||||
addTopLevelItem(item);
|
|
||||||
tracker_items[tracker_url] = item;
|
|
||||||
} else {
|
|
||||||
old_trackers_urls.removeOne(tracker_url);
|
|
||||||
}
|
|
||||||
TrackerInfos data = trackers_data.value(tracker_url, TrackerInfos(tracker_url));
|
|
||||||
QString error_message = data.last_message.trimmed();
|
|
||||||
#ifdef LIBTORRENT_0_15
|
|
||||||
if(it->verified) {
|
|
||||||
item->setText(COL_STATUS, tr("Working"));
|
|
||||||
item->setText(COL_MSG, "");
|
|
||||||
} else {
|
|
||||||
if(it->updating && it->fails == 0) {
|
|
||||||
item->setText(COL_STATUS, tr("Updating..."));
|
|
||||||
item->setText(COL_MSG, "");
|
|
||||||
} else {
|
|
||||||
if(it->fails > 0) {
|
|
||||||
item->setText(COL_STATUS, tr("Not working"));
|
|
||||||
item->setText(COL_MSG, error_message);
|
|
||||||
} else {
|
|
||||||
item->setText(COL_STATUS, tr("Not contacted yet"));
|
|
||||||
item->setText(COL_MSG, "");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
if(data.verified) {
|
|
||||||
item->setText(COL_STATUS, tr("Working"));
|
|
||||||
item->setText(COL_MSG, "");
|
|
||||||
} else {
|
|
||||||
if(data.fail_count > 0) {
|
|
||||||
item->setText(COL_STATUS, tr("Not working"));
|
|
||||||
item->setText(COL_MSG, error_message);
|
|
||||||
} else {
|
|
||||||
item->setText(COL_STATUS, tr("Not contacted yet"));
|
|
||||||
item->setText(COL_MSG, "");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
item->setText(COL_PEERS, QString::number(trackers_data.value(tracker_url, TrackerInfos(tracker_url)).num_peers));
|
|
||||||
}
|
|
||||||
// Remove old trackers
|
|
||||||
foreach(const QString &tracker, old_trackers_urls) {
|
|
||||||
delete tracker_items.take(tracker);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Ask the user for new trackers and add them to the torrent
|
|
||||||
void askForTrackers(){
|
|
||||||
QTorrentHandle h = properties->getCurrentTorrent();
|
|
||||||
if(!h.is_valid()) return;
|
|
||||||
QStringList trackers = TrackersAdditionDlg::askForTrackers(h);
|
|
||||||
if(!trackers.empty()) {
|
|
||||||
foreach(const QString& tracker, trackers) {
|
|
||||||
announce_entry url(tracker.toStdString());
|
|
||||||
url.tier = 0;
|
|
||||||
h.add_tracker(url);
|
|
||||||
}
|
|
||||||
// Reannounce to new trackers
|
|
||||||
h.force_reannounce();
|
|
||||||
// Reload tracker list
|
|
||||||
loadTrackers();
|
|
||||||
// XXX: I don't think this is necessary now
|
|
||||||
//BTSession->saveTrackerFile(h.hash());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void deleteSelectedTrackers(){
|
|
||||||
QTorrentHandle h = properties->getCurrentTorrent();
|
|
||||||
if(!h.is_valid()) {
|
|
||||||
clear();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
QList<QTreeWidgetItem *> selected_items = getSelectedTrackerItems();
|
|
||||||
if(selected_items.isEmpty()) return;
|
|
||||||
QStringList urls_to_remove;
|
|
||||||
foreach(QTreeWidgetItem *item, selected_items){
|
|
||||||
QString tracker_url = item->data(COL_URL, Qt::DisplayRole).toString();
|
|
||||||
urls_to_remove << tracker_url;
|
|
||||||
tracker_items.remove(tracker_url);
|
|
||||||
delete item;
|
|
||||||
}
|
|
||||||
// Iterate of trackers and remove selected ones
|
|
||||||
std::vector<announce_entry> trackers = h.trackers();
|
|
||||||
std::vector<announce_entry>::iterator it = trackers.begin();
|
|
||||||
while(it != trackers.end()) {
|
|
||||||
int index = urls_to_remove.indexOf(misc::toQString((*it).url));
|
|
||||||
if(index >= 0) {
|
|
||||||
trackers.erase(it);
|
|
||||||
urls_to_remove.removeAt(index);
|
|
||||||
} else {
|
|
||||||
it++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
h.replace_trackers(trackers);
|
|
||||||
h.force_reannounce();
|
|
||||||
// Reload Trackers
|
|
||||||
loadTrackers();
|
|
||||||
//XXX: I don't think this is necessary
|
|
||||||
//BTSession->saveTrackerFile(h.hash());
|
|
||||||
}
|
|
||||||
|
|
||||||
void showTrackerListMenu(QPoint) {
|
|
||||||
QTorrentHandle h = properties->getCurrentTorrent();
|
|
||||||
if(!h.is_valid() || !h.has_metadata()) return;
|
|
||||||
QList<QTreeWidgetItem*> selected_items = getSelectedTrackerItems();
|
|
||||||
QMenu menu;
|
|
||||||
// Add actions
|
|
||||||
QAction *addAct = menu.addAction(QIcon(":/Icons/oxygen/list-add.png"), tr("Add a new tracker"));
|
|
||||||
QAction *delAct = 0;
|
|
||||||
if(!getSelectedTrackerItems().isEmpty()) {
|
|
||||||
delAct = menu.addAction(QIcon(":/Icons/oxygen/list-remove.png"), "Remove tracker");
|
|
||||||
}
|
|
||||||
QAction *act = menu.exec(QCursor::pos());
|
|
||||||
if(act == 0) return;
|
|
||||||
if(act == addAct) {
|
|
||||||
askForTrackers();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if(act == delAct) {
|
|
||||||
deleteSelectedTrackers();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadSettings() {
|
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
|
||||||
QVariantList contentColsWidths = settings.value(QString::fromUtf8("TorrentProperties/Trackers/trackersColsWidth"), QVariantList()).toList();
|
|
||||||
if(!contentColsWidths.empty()) {
|
|
||||||
for(int i=0; i<contentColsWidths.size(); ++i) {
|
|
||||||
setColumnWidth(i, contentColsWidths.at(i).toInt());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
setColumnWidth(0, 300);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void saveSettings() const {
|
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
|
||||||
QVariantList contentColsWidths;
|
|
||||||
for(int i=0; i<columnCount(); ++i) {
|
|
||||||
contentColsWidths.append(columnWidth(i));
|
|
||||||
}
|
|
||||||
settings.setValue(QString::fromUtf8("TorrentProperties/Trackers/trackersColsWidth"), contentColsWidths);
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -52,6 +52,8 @@
|
|||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
Q_DECLARE_METATYPE(QList<int>)
|
||||||
|
|
||||||
TransferListWidget::TransferListWidget(QWidget *parent, GUI *main_window, Bittorrent *_BTSession):
|
TransferListWidget::TransferListWidget(QWidget *parent, GUI *main_window, Bittorrent *_BTSession):
|
||||||
QTreeView(parent), BTSession(_BTSession), main_window(main_window) {
|
QTreeView(parent), BTSession(_BTSession), main_window(main_window) {
|
||||||
QSettings settings("qBittorrent", "qBittorrent");
|
QSettings settings("qBittorrent", "qBittorrent");
|
||||||
@ -1242,6 +1244,7 @@ void TransferListWidget::saveColWidthList() {
|
|||||||
QStringList width_list;
|
QStringList width_list;
|
||||||
QStringList new_width_list;
|
QStringList new_width_list;
|
||||||
const short nbColumns = listModel->columnCount()-1; // HASH is hidden
|
const short nbColumns = listModel->columnCount()-1; // HASH is hidden
|
||||||
|
if(nbColumns <= 0) return;
|
||||||
const QString &line = settings.value("TransferListColsWidth", QString()).toString();
|
const QString &line = settings.value("TransferListColsWidth", QString()).toString();
|
||||||
if(!line.isEmpty()) {
|
if(!line.isEmpty()) {
|
||||||
width_list = line.split(' ');
|
width_list = line.split(' ');
|
||||||
@ -1260,11 +1263,11 @@ void TransferListWidget::saveColWidthList() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
settings.setValue(QString::fromUtf8("TransferListColsWidth"), new_width_list.join(QString::fromUtf8(" ")));
|
settings.setValue(QString::fromUtf8("TransferListColsWidth"), new_width_list.join(QString::fromUtf8(" ")));
|
||||||
QVariantList visualIndexes;
|
QList<int> visualIndexes;
|
||||||
for(int i=0; i<nbColumns; ++i) {
|
for(int i=0; i<nbColumns; ++i) {
|
||||||
visualIndexes.append(header()->visualIndex(i));
|
visualIndexes.append(header()->visualIndex(i));
|
||||||
}
|
}
|
||||||
settings.setValue(QString::fromUtf8("TransferListVisualIndexes"), visualIndexes);
|
settings.setValue(QString::fromUtf8("TransferListVisualIndexes"), QVariant::fromValue< QList<int> >(visualIndexes));
|
||||||
qDebug("Download list columns width saved");
|
qDebug("Download list columns width saved");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1272,10 +1275,10 @@ void TransferListWidget::saveColWidthList() {
|
|||||||
bool TransferListWidget::loadColWidthList() {
|
bool TransferListWidget::loadColWidthList() {
|
||||||
qDebug("Loading columns width for download list");
|
qDebug("Loading columns width for download list");
|
||||||
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
QSettings settings(QString::fromUtf8("qBittorrent"), QString::fromUtf8("qBittorrent"));
|
||||||
const QString &line = settings.value(QString::fromUtf8("TransferListColsWidth"), QString()).toString();
|
QString line = settings.value(QString::fromUtf8("TransferListColsWidth"), QString()).toString();
|
||||||
if(line.isEmpty())
|
if(line.isEmpty())
|
||||||
return false;
|
return false;
|
||||||
const QStringList &width_list = line.split(QString::fromUtf8(" "));
|
const QStringList width_list = line.split(" ");
|
||||||
if(width_list.size() != listModel->columnCount()-1) {
|
if(width_list.size() != listModel->columnCount()-1) {
|
||||||
qDebug("Corrupted values for transfer list columns sizes");
|
qDebug("Corrupted values for transfer list columns sizes");
|
||||||
return false;
|
return false;
|
||||||
@ -1284,7 +1287,7 @@ bool TransferListWidget::loadColWidthList() {
|
|||||||
for(unsigned int i=0; i<listSize; ++i) {
|
for(unsigned int i=0; i<listSize; ++i) {
|
||||||
header()->resizeSection(i, width_list.at(i).toInt());
|
header()->resizeSection(i, width_list.at(i).toInt());
|
||||||
}
|
}
|
||||||
const QVariantList& visualIndexes = settings.value(QString::fromUtf8("TransferListVisualIndexes"), QVariantList()).toList();
|
const QList<int> visualIndexes = settings.value(QString::fromUtf8("TransferListVisualIndexes")).value<QList<int> >();
|
||||||
if(visualIndexes.size() != listModel->columnCount()-1) {
|
if(visualIndexes.size() != listModel->columnCount()-1) {
|
||||||
qDebug("Corrupted values for transfer list columns indexes");
|
qDebug("Corrupted values for transfer list columns indexes");
|
||||||
return false;
|
return false;
|
||||||
@ -1293,7 +1296,7 @@ bool TransferListWidget::loadColWidthList() {
|
|||||||
do {
|
do {
|
||||||
change = false;
|
change = false;
|
||||||
for(int i=0;i<visualIndexes.size(); ++i) {
|
for(int i=0;i<visualIndexes.size(); ++i) {
|
||||||
const int new_visual_index = visualIndexes.at(header()->logicalIndex(i)).toInt();
|
const int new_visual_index = visualIndexes.at(header()->logicalIndex(i));
|
||||||
if(i != new_visual_index) {
|
if(i != new_visual_index) {
|
||||||
qDebug("Moving column from %d to %d", header()->logicalIndex(i), new_visual_index);
|
qDebug("Moving column from %d to %d", header()->logicalIndex(i), new_visual_index);
|
||||||
header()->moveSection(i, new_visual_index);
|
header()->moveSection(i, new_visual_index);
|
||||||
|
Loading…
Reference in New Issue
Block a user