mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 04:54:18 +00:00
Merge pull request #10365 from thalieht/adv-label-links
Add documentation links to some advanced settings
This commit is contained in:
commit
05b6865618
@ -287,7 +287,6 @@ Session::Session(QObject *parent)
|
|||||||
, m_announceIP(BITTORRENT_SESSION_KEY("AnnounceIP"))
|
, m_announceIP(BITTORRENT_SESSION_KEY("AnnounceIP"))
|
||||||
, m_isSuperSeedingEnabled(BITTORRENT_SESSION_KEY("SuperSeedingEnabled"), false)
|
, m_isSuperSeedingEnabled(BITTORRENT_SESSION_KEY("SuperSeedingEnabled"), false)
|
||||||
, m_maxConnections(BITTORRENT_SESSION_KEY("MaxConnections"), 500, lowerLimited(0, -1))
|
, m_maxConnections(BITTORRENT_SESSION_KEY("MaxConnections"), 500, lowerLimited(0, -1))
|
||||||
, m_maxHalfOpenConnections(BITTORRENT_SESSION_KEY("MaxHalfOpenConnections"), 20, lowerLimited(0, -1))
|
|
||||||
, m_maxUploads(BITTORRENT_SESSION_KEY("MaxUploads"), -1, lowerLimited(0, -1))
|
, m_maxUploads(BITTORRENT_SESSION_KEY("MaxUploads"), -1, lowerLimited(0, -1))
|
||||||
, m_maxConnectionsPerTorrent(BITTORRENT_SESSION_KEY("MaxConnectionsPerTorrent"), 100, lowerLimited(0, -1))
|
, m_maxConnectionsPerTorrent(BITTORRENT_SESSION_KEY("MaxConnectionsPerTorrent"), 100, lowerLimited(0, -1))
|
||||||
, m_maxUploadsPerTorrent(BITTORRENT_SESSION_KEY("MaxUploadsPerTorrent"), -1, lowerLimited(0, -1))
|
, m_maxUploadsPerTorrent(BITTORRENT_SESSION_KEY("MaxUploadsPerTorrent"), -1, lowerLimited(0, -1))
|
||||||
@ -3113,20 +3112,6 @@ void Session::setMaxConnections(int max)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int Session::maxHalfOpenConnections() const
|
|
||||||
{
|
|
||||||
return m_maxHalfOpenConnections;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Session::setMaxHalfOpenConnections(int max)
|
|
||||||
{
|
|
||||||
max = (max > 0) ? max : -1;
|
|
||||||
if (max != m_maxHalfOpenConnections) {
|
|
||||||
m_maxHalfOpenConnections = max;
|
|
||||||
configureDeferred();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int Session::maxUploads() const
|
int Session::maxUploads() const
|
||||||
{
|
{
|
||||||
return m_maxUploads;
|
return m_maxUploads;
|
||||||
|
@ -413,8 +413,6 @@ namespace BitTorrent
|
|||||||
void setSuperSeedingEnabled(bool enabled);
|
void setSuperSeedingEnabled(bool enabled);
|
||||||
int maxConnections() const;
|
int maxConnections() const;
|
||||||
void setMaxConnections(int max);
|
void setMaxConnections(int max);
|
||||||
int maxHalfOpenConnections() const;
|
|
||||||
void setMaxHalfOpenConnections(int max);
|
|
||||||
int maxConnectionsPerTorrent() const;
|
int maxConnectionsPerTorrent() const;
|
||||||
void setMaxConnectionsPerTorrent(int max);
|
void setMaxConnectionsPerTorrent(int max);
|
||||||
int maxUploads() const;
|
int maxUploads() const;
|
||||||
@ -660,7 +658,6 @@ namespace BitTorrent
|
|||||||
CachedSettingValue<QString> m_announceIP;
|
CachedSettingValue<QString> m_announceIP;
|
||||||
CachedSettingValue<bool> m_isSuperSeedingEnabled;
|
CachedSettingValue<bool> m_isSuperSeedingEnabled;
|
||||||
CachedSettingValue<int> m_maxConnections;
|
CachedSettingValue<int> m_maxConnections;
|
||||||
CachedSettingValue<int> m_maxHalfOpenConnections;
|
|
||||||
CachedSettingValue<int> m_maxUploads;
|
CachedSettingValue<int> m_maxUploads;
|
||||||
CachedSettingValue<int> m_maxConnectionsPerTorrent;
|
CachedSettingValue<int> m_maxConnectionsPerTorrent;
|
||||||
CachedSettingValue<int> m_maxUploadsPerTorrent;
|
CachedSettingValue<int> m_maxUploadsPerTorrent;
|
||||||
|
@ -43,6 +43,14 @@
|
|||||||
#include "gui/addnewtorrentdialog.h"
|
#include "gui/addnewtorrentdialog.h"
|
||||||
#include "gui/mainwindow.h"
|
#include "gui/mainwindow.h"
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
QString makeLink(const QString &url, const QString &linkLabel)
|
||||||
|
{
|
||||||
|
return QStringLiteral("<a href=\"%1\">%2</a>").arg(url, linkLabel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
enum AdvSettingsCols
|
enum AdvSettingsCols
|
||||||
{
|
{
|
||||||
PROPERTY,
|
PROPERTY,
|
||||||
@ -94,7 +102,6 @@ enum AdvSettingsRows
|
|||||||
SEND_BUF_LOW_WATERMARK,
|
SEND_BUF_LOW_WATERMARK,
|
||||||
SEND_BUF_WATERMARK_FACTOR,
|
SEND_BUF_WATERMARK_FACTOR,
|
||||||
// ports
|
// ports
|
||||||
MAX_HALF_OPEN,
|
|
||||||
OUTGOING_PORT_MIN,
|
OUTGOING_PORT_MIN,
|
||||||
OUTGOING_PORT_MAX,
|
OUTGOING_PORT_MAX,
|
||||||
UTP_MIX_MODE,
|
UTP_MIX_MODE,
|
||||||
@ -181,8 +188,6 @@ void AdvancedSettings::saveAdvancedSettings()
|
|||||||
// Peer resolution
|
// Peer resolution
|
||||||
pref->resolvePeerCountries(checkBoxResolveCountries.isChecked());
|
pref->resolvePeerCountries(checkBoxResolveCountries.isChecked());
|
||||||
pref->resolvePeerHostNames(checkBoxResolveHosts.isChecked());
|
pref->resolvePeerHostNames(checkBoxResolveHosts.isChecked());
|
||||||
// Max Half-Open connections
|
|
||||||
session->setMaxHalfOpenConnections(spinBoxMaxHalfOpen.value());
|
|
||||||
// Super seeding
|
// Super seeding
|
||||||
session->setSuperSeedingEnabled(checkBoxSuperSeeding.isChecked());
|
session->setSuperSeedingEnabled(checkBoxSuperSeeding.isChecked());
|
||||||
// Network interface
|
// Network interface
|
||||||
@ -303,20 +308,23 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
const BitTorrent::Session *const session = BitTorrent::Session::instance();
|
const BitTorrent::Session *const session = BitTorrent::Session::instance();
|
||||||
|
|
||||||
// add section headers
|
// add section headers
|
||||||
labelQbtLink.setText(QString("<a href=\"%1\">%2</a>")
|
labelQbtLink.setText(makeLink("https://github.com/qbittorrent/qBittorrent/wiki/Explanation-of-Options-in-qBittorrent#Advanced"
|
||||||
.arg("https://github.com/qbittorrent/qBittorrent/wiki/Explanation-of-Options-in-qBittorrent#Advanced", tr("Open documentation")));
|
, tr("Open documentation")));
|
||||||
labelQbtLink.setOpenExternalLinks(true);
|
labelQbtLink.setOpenExternalLinks(true);
|
||||||
addRow(QBITTORRENT_HEADER, QString("<b>%1</b>").arg(tr("qBittorrent Section")), &labelQbtLink);
|
addRow(QBITTORRENT_HEADER, QString("<b>%1</b>").arg(tr("qBittorrent Section")), &labelQbtLink);
|
||||||
|
static_cast<QLabel *>(cellWidget(QBITTORRENT_HEADER, PROPERTY))->setAlignment(Qt::AlignCenter | Qt::AlignVCenter);
|
||||||
|
|
||||||
labelLibtorrentLink.setText(QString("<a href=\"%1\">%2</a>").arg("https://www.libtorrent.org/reference.html", tr("Open documentation")));
|
labelLibtorrentLink.setText(makeLink("https://www.libtorrent.org/reference.html", tr("Open documentation")));
|
||||||
labelLibtorrentLink.setOpenExternalLinks(true);
|
labelLibtorrentLink.setOpenExternalLinks(true);
|
||||||
addRow(LIBTORRENT_HEADER, QString("<b>%1</b>").arg(tr("libtorrent Section")), &labelLibtorrentLink);
|
addRow(LIBTORRENT_HEADER, QString("<b>%1</b>").arg(tr("libtorrent Section")), &labelLibtorrentLink);
|
||||||
|
static_cast<QLabel *>(cellWidget(LIBTORRENT_HEADER, PROPERTY))->setAlignment(Qt::AlignCenter | Qt::AlignVCenter);
|
||||||
|
|
||||||
// Async IO threads
|
// Async IO threads
|
||||||
spinBoxAsyncIOThreads.setMinimum(1);
|
spinBoxAsyncIOThreads.setMinimum(1);
|
||||||
spinBoxAsyncIOThreads.setMaximum(1024);
|
spinBoxAsyncIOThreads.setMaximum(1024);
|
||||||
spinBoxAsyncIOThreads.setValue(session->asyncIOThreads());
|
spinBoxAsyncIOThreads.setValue(session->asyncIOThreads());
|
||||||
addRow(ASYNC_IO_THREADS, tr("Asynchronous I/O threads"), &spinBoxAsyncIOThreads);
|
addRow(ASYNC_IO_THREADS, (tr("Asynchronous I/O threads") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#aio_threads", "(?)"))
|
||||||
|
, &spinBoxAsyncIOThreads);
|
||||||
|
|
||||||
// Checking Memory Usage
|
// Checking Memory Usage
|
||||||
spinBoxCheckingMemUsage.setMinimum(1);
|
spinBoxCheckingMemUsage.setMinimum(1);
|
||||||
@ -329,7 +337,8 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
#endif
|
#endif
|
||||||
spinBoxCheckingMemUsage.setValue(session->checkingMemUsage());
|
spinBoxCheckingMemUsage.setValue(session->checkingMemUsage());
|
||||||
spinBoxCheckingMemUsage.setSuffix(tr(" MiB"));
|
spinBoxCheckingMemUsage.setSuffix(tr(" MiB"));
|
||||||
addRow(CHECKING_MEM_USAGE, tr("Outstanding memory when checking torrents"), &spinBoxCheckingMemUsage);
|
addRow(CHECKING_MEM_USAGE, (tr("Outstanding memory when checking torrents") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#checking_mem_usage", "(?)"))
|
||||||
|
, &spinBoxCheckingMemUsage);
|
||||||
|
|
||||||
// Disk write cache
|
// Disk write cache
|
||||||
spinBoxCache.setMinimum(-1);
|
spinBoxCache.setMinimum(-1);
|
||||||
@ -343,41 +352,50 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
#endif
|
#endif
|
||||||
spinBoxCache.setValue(session->diskCacheSize());
|
spinBoxCache.setValue(session->diskCacheSize());
|
||||||
updateCacheSpinSuffix(spinBoxCache.value());
|
updateCacheSpinSuffix(spinBoxCache.value());
|
||||||
addRow(DISK_CACHE, tr("Disk cache"), &spinBoxCache);
|
addRow(DISK_CACHE, (tr("Disk cache") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#cache_size", "(?)"))
|
||||||
|
, &spinBoxCache);
|
||||||
// Disk cache expiry
|
// Disk cache expiry
|
||||||
spinBoxCacheTTL.setMinimum(15);
|
spinBoxCacheTTL.setMinimum(15);
|
||||||
spinBoxCacheTTL.setMaximum(600);
|
spinBoxCacheTTL.setMaximum(600);
|
||||||
spinBoxCacheTTL.setValue(session->diskCacheTTL());
|
spinBoxCacheTTL.setValue(session->diskCacheTTL());
|
||||||
spinBoxCacheTTL.setSuffix(tr(" s", " seconds"));
|
spinBoxCacheTTL.setSuffix(tr(" s", " seconds"));
|
||||||
addRow(DISK_CACHE_TTL, tr("Disk cache expiry interval"), &spinBoxCacheTTL);
|
addRow(DISK_CACHE_TTL, (tr("Disk cache expiry interval") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#cache_expiry", "(?)"))
|
||||||
|
, &spinBoxCacheTTL);
|
||||||
// Enable OS cache
|
// Enable OS cache
|
||||||
checkBoxOsCache.setChecked(session->useOSCache());
|
checkBoxOsCache.setChecked(session->useOSCache());
|
||||||
addRow(OS_CACHE, tr("Enable OS cache"), &checkBoxOsCache);
|
addRow(OS_CACHE, (tr("Enable OS cache") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#disk_io_write_mode", "(?)"))
|
||||||
|
, &checkBoxOsCache);
|
||||||
// Guided read cache
|
// Guided read cache
|
||||||
checkBoxGuidedReadCache.setChecked(session->isGuidedReadCacheEnabled());
|
checkBoxGuidedReadCache.setChecked(session->isGuidedReadCacheEnabled());
|
||||||
addRow(GUIDED_READ_CACHE, tr("Guided read cache"), &checkBoxGuidedReadCache);
|
addRow(GUIDED_READ_CACHE, (tr("Guided read cache") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#guided_read_cache", "(?)"))
|
||||||
|
, &checkBoxGuidedReadCache);
|
||||||
// Coalesce reads & writes
|
// Coalesce reads & writes
|
||||||
checkBoxCoalesceRW.setChecked(session->isCoalesceReadWriteEnabled());
|
checkBoxCoalesceRW.setChecked(session->isCoalesceReadWriteEnabled());
|
||||||
addRow(COALESCE_RW, tr("Coalesce reads & writes"), &checkBoxCoalesceRW);
|
addRow(COALESCE_RW, (tr("Coalesce reads & writes") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#coalesce_reads", "(?)"))
|
||||||
|
, &checkBoxCoalesceRW);
|
||||||
// Suggest mode
|
// Suggest mode
|
||||||
checkBoxSuggestMode.setChecked(session->isSuggestModeEnabled());
|
checkBoxSuggestMode.setChecked(session->isSuggestModeEnabled());
|
||||||
addRow(SUGGEST_MODE, tr("Send upload piece suggestions"), &checkBoxSuggestMode);
|
addRow(SUGGEST_MODE, (tr("Send upload piece suggestions") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#suggest_mode", "(?)"))
|
||||||
|
, &checkBoxSuggestMode);
|
||||||
// Send buffer watermark
|
// Send buffer watermark
|
||||||
spinBoxSendBufferWatermark.setMinimum(1);
|
spinBoxSendBufferWatermark.setMinimum(1);
|
||||||
spinBoxSendBufferWatermark.setMaximum(INT_MAX);
|
spinBoxSendBufferWatermark.setMaximum(INT_MAX);
|
||||||
spinBoxSendBufferWatermark.setSuffix(tr(" KiB"));
|
spinBoxSendBufferWatermark.setSuffix(tr(" KiB"));
|
||||||
spinBoxSendBufferWatermark.setValue(session->sendBufferWatermark());
|
spinBoxSendBufferWatermark.setValue(session->sendBufferWatermark());
|
||||||
addRow(SEND_BUF_WATERMARK, tr("Send buffer watermark"), &spinBoxSendBufferWatermark);
|
addRow(SEND_BUF_WATERMARK, (tr("Send buffer watermark") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#send_buffer_watermark", "(?)"))
|
||||||
|
, &spinBoxSendBufferWatermark);
|
||||||
spinBoxSendBufferLowWatermark.setMinimum(1);
|
spinBoxSendBufferLowWatermark.setMinimum(1);
|
||||||
spinBoxSendBufferLowWatermark.setMaximum(INT_MAX);
|
spinBoxSendBufferLowWatermark.setMaximum(INT_MAX);
|
||||||
spinBoxSendBufferLowWatermark.setSuffix(tr(" KiB"));
|
spinBoxSendBufferLowWatermark.setSuffix(tr(" KiB"));
|
||||||
spinBoxSendBufferLowWatermark.setValue(session->sendBufferLowWatermark());
|
spinBoxSendBufferLowWatermark.setValue(session->sendBufferLowWatermark());
|
||||||
addRow(SEND_BUF_LOW_WATERMARK, tr("Send buffer low watermark"), &spinBoxSendBufferLowWatermark);
|
addRow(SEND_BUF_LOW_WATERMARK, (tr("Send buffer low watermark") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#send_buffer_low_watermark", "(?)"))
|
||||||
|
, &spinBoxSendBufferLowWatermark);
|
||||||
spinBoxSendBufferWatermarkFactor.setMinimum(1);
|
spinBoxSendBufferWatermarkFactor.setMinimum(1);
|
||||||
spinBoxSendBufferWatermarkFactor.setMaximum(INT_MAX);
|
spinBoxSendBufferWatermarkFactor.setMaximum(INT_MAX);
|
||||||
spinBoxSendBufferWatermarkFactor.setSuffix(" %");
|
spinBoxSendBufferWatermarkFactor.setSuffix(" %");
|
||||||
spinBoxSendBufferWatermarkFactor.setValue(session->sendBufferWatermarkFactor());
|
spinBoxSendBufferWatermarkFactor.setValue(session->sendBufferWatermarkFactor());
|
||||||
addRow(SEND_BUF_WATERMARK_FACTOR, tr("Send buffer watermark factor"), &spinBoxSendBufferWatermarkFactor);
|
addRow(SEND_BUF_WATERMARK_FACTOR, (tr("Send buffer watermark factor") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#send_buffer_watermark_factor", "(?)"))
|
||||||
|
, &spinBoxSendBufferWatermarkFactor);
|
||||||
// Save resume data interval
|
// Save resume data interval
|
||||||
spinBoxSaveResumeDataInterval.setMinimum(0);
|
spinBoxSaveResumeDataInterval.setMinimum(0);
|
||||||
spinBoxSaveResumeDataInterval.setMaximum(std::numeric_limits<int>::max());
|
spinBoxSaveResumeDataInterval.setMaximum(std::numeric_limits<int>::max());
|
||||||
@ -397,7 +415,9 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
// uTP-TCP mixed mode
|
// uTP-TCP mixed mode
|
||||||
comboBoxUtpMixedMode.addItems({tr("Prefer TCP"), tr("Peer proportional (throttles TCP)")});
|
comboBoxUtpMixedMode.addItems({tr("Prefer TCP"), tr("Peer proportional (throttles TCP)")});
|
||||||
comboBoxUtpMixedMode.setCurrentIndex(static_cast<int>(session->utpMixedMode()));
|
comboBoxUtpMixedMode.setCurrentIndex(static_cast<int>(session->utpMixedMode()));
|
||||||
addRow(UTP_MIX_MODE, tr("%1-TCP mixed mode algorithm", "uTP-TCP mixed mode algorithm").arg(C_UTP), &comboBoxUtpMixedMode);
|
addRow(UTP_MIX_MODE, (tr("%1-TCP mixed mode algorithm", "uTP-TCP mixed mode algorithm").arg(C_UTP)
|
||||||
|
+ ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#mixed_mode_algorithm", "(?)"))
|
||||||
|
, &comboBoxUtpMixedMode);
|
||||||
// multiple connections per IP
|
// multiple connections per IP
|
||||||
checkBoxMultiConnectionsPerIp.setChecked(session->multiConnectionsPerIpEnabled());
|
checkBoxMultiConnectionsPerIp.setChecked(session->multiConnectionsPerIpEnabled());
|
||||||
addRow(MULTI_CONNECTIONS_PER_IP, tr("Allow multiple connections from the same IP address"), &checkBoxMultiConnectionsPerIp);
|
addRow(MULTI_CONNECTIONS_PER_IP, tr("Allow multiple connections from the same IP address"), &checkBoxMultiConnectionsPerIp);
|
||||||
@ -416,14 +436,10 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
// Resolve peer hosts
|
// Resolve peer hosts
|
||||||
checkBoxResolveHosts.setChecked(pref->resolvePeerHostNames());
|
checkBoxResolveHosts.setChecked(pref->resolvePeerHostNames());
|
||||||
addRow(RESOLVE_HOSTS, tr("Resolve peer host names"), &checkBoxResolveHosts);
|
addRow(RESOLVE_HOSTS, tr("Resolve peer host names"), &checkBoxResolveHosts);
|
||||||
// Max Half Open connections
|
|
||||||
spinBoxMaxHalfOpen.setMinimum(0);
|
|
||||||
spinBoxMaxHalfOpen.setMaximum(99999);
|
|
||||||
spinBoxMaxHalfOpen.setValue(session->maxHalfOpenConnections());
|
|
||||||
addRow(MAX_HALF_OPEN, tr("Maximum number of half-open connections [0: Unlimited]"), &spinBoxMaxHalfOpen);
|
|
||||||
// Super seeding
|
// Super seeding
|
||||||
checkBoxSuperSeeding.setChecked(session->isSuperSeedingEnabled());
|
checkBoxSuperSeeding.setChecked(session->isSuperSeedingEnabled());
|
||||||
addRow(SUPER_SEEDING, tr("Strict super seeding"), &checkBoxSuperSeeding);
|
addRow(SUPER_SEEDING, (tr("Strict super seeding") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#strict_super_seeding", "(?)"))
|
||||||
|
, &checkBoxSuperSeeding);
|
||||||
// Network interface
|
// Network interface
|
||||||
comboBoxInterface.addItem(tr("Any interface", "i.e. Any network interface"));
|
comboBoxInterface.addItem(tr("Any interface", "i.e. Any network interface"));
|
||||||
const QString currentInterface = session->networkInterface();
|
const QString currentInterface = session->networkInterface();
|
||||||
@ -487,11 +503,13 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
// Choking algorithm
|
// Choking algorithm
|
||||||
comboBoxChokingAlgorithm.addItems({tr("Fixed slots"), tr("Upload rate based")});
|
comboBoxChokingAlgorithm.addItems({tr("Fixed slots"), tr("Upload rate based")});
|
||||||
comboBoxChokingAlgorithm.setCurrentIndex(static_cast<int>(session->chokingAlgorithm()));
|
comboBoxChokingAlgorithm.setCurrentIndex(static_cast<int>(session->chokingAlgorithm()));
|
||||||
addRow(CHOKING_ALGORITHM, tr("Upload slots behavior"), &comboBoxChokingAlgorithm);
|
addRow(CHOKING_ALGORITHM, (tr("Upload slots behavior") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#choking_algorithm", "(?)"))
|
||||||
|
, &comboBoxChokingAlgorithm);
|
||||||
// Seed choking algorithm
|
// Seed choking algorithm
|
||||||
comboBoxSeedChokingAlgorithm.addItems({tr("Round-robin"), tr("Fastest upload"), tr("Anti-leech")});
|
comboBoxSeedChokingAlgorithm.addItems({tr("Round-robin"), tr("Fastest upload"), tr("Anti-leech")});
|
||||||
comboBoxSeedChokingAlgorithm.setCurrentIndex(static_cast<int>(session->seedChokingAlgorithm()));
|
comboBoxSeedChokingAlgorithm.setCurrentIndex(static_cast<int>(session->seedChokingAlgorithm()));
|
||||||
addRow(SEED_CHOKING_ALGORITHM, tr("Upload choking algorithm"), &comboBoxSeedChokingAlgorithm);
|
addRow(SEED_CHOKING_ALGORITHM, (tr("Upload choking algorithm") + ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#seed_choking_algorithm", "(?)"))
|
||||||
|
, &comboBoxSeedChokingAlgorithm);
|
||||||
|
|
||||||
#if defined(Q_OS_WIN) || defined(Q_OS_MAC)
|
#if defined(Q_OS_WIN) || defined(Q_OS_MAC)
|
||||||
checkBoxUpdateCheck.setChecked(pref->isUpdateCheckEnabled());
|
checkBoxUpdateCheck.setChecked(pref->isUpdateCheckEnabled());
|
||||||
|
@ -59,7 +59,7 @@ private:
|
|||||||
template <typename T> void addRow(int row, const QString &text, T *widget);
|
template <typename T> void addRow(int row, const QString &text, T *widget);
|
||||||
|
|
||||||
QLabel labelQbtLink, labelLibtorrentLink;
|
QLabel labelQbtLink, labelLibtorrentLink;
|
||||||
QSpinBox spinBoxAsyncIOThreads, spinBoxCheckingMemUsage, spinBoxCache, spinBoxSaveResumeDataInterval, spinBoxOutgoingPortsMin, spinBoxOutgoingPortsMax, spinBoxListRefresh, spinBoxMaxHalfOpen,
|
QSpinBox spinBoxAsyncIOThreads, spinBoxCheckingMemUsage, spinBoxCache, spinBoxSaveResumeDataInterval, spinBoxOutgoingPortsMin, spinBoxOutgoingPortsMax, spinBoxListRefresh,
|
||||||
spinBoxTrackerPort, spinBoxCacheTTL, spinBoxSendBufferWatermark, spinBoxSendBufferLowWatermark,
|
spinBoxTrackerPort, spinBoxCacheTTL, spinBoxSendBufferWatermark, spinBoxSendBufferLowWatermark,
|
||||||
spinBoxSendBufferWatermarkFactor, spinBoxSavePathHistoryLength;
|
spinBoxSendBufferWatermarkFactor, spinBoxSavePathHistoryLength;
|
||||||
QCheckBox checkBoxOsCache, checkBoxRecheckCompleted, checkBoxResolveCountries, checkBoxResolveHosts, checkBoxSuperSeeding,
|
QCheckBox checkBoxOsCache, checkBoxRecheckCompleted, checkBoxResolveCountries, checkBoxResolveHosts, checkBoxSuperSeeding,
|
||||||
|
@ -582,7 +582,7 @@ void TrackerListWidget::saveSettings() const
|
|||||||
QStringList TrackerListWidget::headerLabels()
|
QStringList TrackerListWidget::headerLabels()
|
||||||
{
|
{
|
||||||
static const QStringList header {
|
static const QStringList header {
|
||||||
"#"
|
tr("Tier")
|
||||||
, tr("URL")
|
, tr("URL")
|
||||||
, tr("Status")
|
, tr("Status")
|
||||||
, tr("Peers")
|
, tr("Peers")
|
||||||
|
@ -1572,7 +1572,7 @@ var TorrentTrackersTable = new Class({
|
|||||||
Extends: DynamicTable,
|
Extends: DynamicTable,
|
||||||
|
|
||||||
initColumns: function() {
|
initColumns: function() {
|
||||||
this.newColumn('tier', '', 'QBT_TR(#)QBT_TR[CONTEXT=TrackerListWidget]', 35, true);
|
this.newColumn('tier', '', 'QBT_TR(Tier)QBT_TR[CONTEXT=TrackerListWidget]', 35, true);
|
||||||
this.newColumn('url', '', 'QBT_TR(URL)QBT_TR[CONTEXT=TrackerListWidget]', 250, true);
|
this.newColumn('url', '', 'QBT_TR(URL)QBT_TR[CONTEXT=TrackerListWidget]', 250, true);
|
||||||
this.newColumn('status', '', 'QBT_TR(Status)QBT_TR[CONTEXT=TrackerListWidget]', 125, true);
|
this.newColumn('status', '', 'QBT_TR(Status)QBT_TR[CONTEXT=TrackerListWidget]', 125, true);
|
||||||
this.newColumn('peers', '', 'QBT_TR(Peers)QBT_TR[CONTEXT=TrackerListWidget]', 75, true);
|
this.newColumn('peers', '', 'QBT_TR(Peers)QBT_TR[CONTEXT=TrackerListWidget]', 75, true);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user