You've already forked qBittorrent
mirror of
https://github.com/qbittorrent/qBittorrent
synced 2025-10-12 03:12:18 +02:00
Compare commits
39 Commits
release-2.
...
release-1.
Author | SHA1 | Date | |
---|---|---|---|
![]() |
f043cd3cc5 | ||
![]() |
28626f51ad | ||
![]() |
25233295ba | ||
![]() |
bd6684405b | ||
![]() |
a8235dc413 | ||
![]() |
c2838d9b0c | ||
![]() |
d6d7797064 | ||
![]() |
685216505c | ||
![]() |
c28c55280d | ||
![]() |
f1032c4619 | ||
![]() |
d34bfd13b3 | ||
![]() |
cfd6a9d734 | ||
![]() |
c2f22d292a | ||
![]() |
9778112b3b | ||
![]() |
1708361bd5 | ||
![]() |
cc04f7eec2 | ||
![]() |
395805f9e8 | ||
![]() |
ba5daee92f | ||
![]() |
bfef2b5cc0 | ||
![]() |
af2431afbd | ||
![]() |
7a1b92e467 | ||
![]() |
dc399e9ed9 | ||
![]() |
dad79d2cc8 | ||
![]() |
b5d30d5154 | ||
![]() |
72df85749b | ||
![]() |
6c84288b09 | ||
![]() |
78239d6956 | ||
![]() |
41be514dcf | ||
![]() |
855b539843 | ||
![]() |
2e72ab4973 | ||
![]() |
ae2ad8e747 | ||
![]() |
42fa5ef8f3 | ||
![]() |
9395f7316d | ||
![]() |
fa1c4050ed | ||
![]() |
565b98a94a | ||
![]() |
f58efdfefc | ||
![]() |
a806c27f70 | ||
![]() |
a8f82d9e12 | ||
![]() |
fe6054307e |
14
Changelog
14
Changelog
@@ -1,4 +1,15 @@
|
|||||||
* Unknown - Christophe Dumez <chris@qbittorrent.org> - v1.1.0
|
* Tue Aug 26 2008 - Christophe Dumez <chris@qbittorrent.org> - v1.1.3
|
||||||
|
- BUGFIX: Fixed ratio saving for seeding torrents
|
||||||
|
- I18N: Added czech and traditional chinese translations
|
||||||
|
|
||||||
|
* Sun Aug 17 2008 - Christophe Dumez <chris@qbittorrent.org> - v1.1.2
|
||||||
|
- BUGFIX: Fixed progress calculation
|
||||||
|
- BUGFIX: Fixed finished torrent detection
|
||||||
|
|
||||||
|
* Fri Aug 01 2008 - Christophe Dumez <chris@qbittorrent.org> - v1.1.1
|
||||||
|
- BUGFIX: Fixed bad resource file for icons
|
||||||
|
|
||||||
|
* Fri Aug 01 2008 - Christophe Dumez <chris@qbittorrent.org> - v1.1.0
|
||||||
- FEATURE: Web interface to control qbittorrent (Ishan Arora)
|
- FEATURE: Web interface to control qbittorrent (Ishan Arora)
|
||||||
- FEATURE: Can spoof Azureus peer id to avoid ban
|
- FEATURE: Can spoof Azureus peer id to avoid ban
|
||||||
- FEATURE: Allow to hide/show some columns in download and seeding lists
|
- FEATURE: Allow to hide/show some columns in download and seeding lists
|
||||||
@@ -27,6 +38,7 @@
|
|||||||
- COSMETIC: Display "unpaused/total_torrent" in download/upload tabs
|
- COSMETIC: Display "unpaused/total_torrent" in download/upload tabs
|
||||||
- COSMETIC: Allow to resize RSS column
|
- COSMETIC: Allow to resize RSS column
|
||||||
- COSMETIC: Global UP/DL speeds and ratio are displayed above tabs
|
- COSMETIC: Global UP/DL speeds and ratio are displayed above tabs
|
||||||
|
- COSMETIC: Use infinity symbol for ETA when time is infinite
|
||||||
|
|
||||||
* Fri Apr 11 2008 - Christophe Dumez <chris@qbittorrent.org> - v1.0.0
|
* Fri Apr 11 2008 - Christophe Dumez <chris@qbittorrent.org> - v1.0.0
|
||||||
- FEATURE: Based on new libtorrent v0.13
|
- FEATURE: Based on new libtorrent v0.13
|
||||||
|
1
INSTALL
1
INSTALL
@@ -18,7 +18,6 @@ Dependencies:
|
|||||||
Qt >= 4.4.0 is advised
|
Qt >= 4.4.0 is advised
|
||||||
|
|
||||||
- libtorrent-rasterbar by Arvid Norberg (>= v0.13.1 REQUIRED)
|
- libtorrent-rasterbar by Arvid Norberg (>= v0.13.1 REQUIRED)
|
||||||
-> http://www.qbittorrent.org/download.php (advised)
|
|
||||||
-> http://www.libtorrent.net
|
-> http://www.libtorrent.net
|
||||||
Be careful: another library (the one used by rTorrent) uses a similar name.
|
Be careful: another library (the one used by rTorrent) uses a similar name.
|
||||||
|
|
||||||
|
51
TODO
51
TODO
@@ -1,41 +1,6 @@
|
|||||||
// Easy
|
See https://blueprints.launchpad.net/qbittorrent/
|
||||||
- Translations into as many languages as possible
|
|
||||||
- Use Launchpad/Rosetta for translations once it supports TS files
|
|
||||||
|
|
||||||
// Intermediate
|
Translations updated in v1.1.0:
|
||||||
- Port on MacOS, Windows (and create an installer for Windows) - Slow progress
|
|
||||||
- Add some transparency (menus,...), improve look / usabilty
|
|
||||||
- Skins support? (contact Mateusz)
|
|
||||||
|
|
||||||
// Harder
|
|
||||||
- Torrent scheduler ala µtorrent/Bitcomet
|
|
||||||
|
|
||||||
// Waiting for libtorrent
|
|
||||||
- Allow to prioritize torrents (may code this in qBittorrent?)
|
|
||||||
|
|
||||||
// Unsure
|
|
||||||
- Display the peers we are connected to for each torrent with infos (like flag, dl/up speeds, ...)
|
|
||||||
- Azureus spoofing to prevent ban from trackers?
|
|
||||||
- Option to shutdown computer when downloads are finished
|
|
||||||
- NAT checker/Tester
|
|
||||||
- Display hard drive space left?
|
|
||||||
- Make use of dbus on Linux for the single instance instead of socket communication?
|
|
||||||
(http://techbase.kde.org/Development/Tutorials/D-Bus/Accessing_Interfaces)
|
|
||||||
- When favicon can't be downloaded, try to parse the webpage for:
|
|
||||||
<link rel="icon" href="http://example.com/favicon.ico" type="image/vnd.microsoft.icon">
|
|
||||||
* Be careful, the link can be relative
|
|
||||||
- Improve search plugin install (choose in a list taken from plugins.qbittorrent.org)
|
|
||||||
- support zipped torrents? (useful?)
|
|
||||||
- Allow to limit the number of downloading torrents simultaneously (other are paused until a download finishes)
|
|
||||||
|
|
||||||
// in v1.2.0
|
|
||||||
- Allow user to organize the downloads into categories/folders?
|
|
||||||
|
|
||||||
// in v1.1.0
|
|
||||||
- Stop calculating ETAs when ETA column is hidden
|
|
||||||
-> See https://blueprints.launchpad.net/qbittorrent
|
|
||||||
|
|
||||||
Translations updated:
|
|
||||||
- French
|
- French
|
||||||
- Chinese
|
- Chinese
|
||||||
- Polish
|
- Polish
|
||||||
@@ -43,3 +8,15 @@ Translations updated:
|
|||||||
- Brazilian
|
- Brazilian
|
||||||
- Slovak
|
- Slovak
|
||||||
- Swedish
|
- Swedish
|
||||||
|
- Romanian
|
||||||
|
- Finnish
|
||||||
|
- Italian
|
||||||
|
- Turkish
|
||||||
|
- Korean
|
||||||
|
- Hungarian
|
||||||
|
- German
|
||||||
|
- Spanish
|
||||||
|
- Russian
|
||||||
|
- Dutch
|
||||||
|
- Bulgarian
|
||||||
|
- Greek
|
||||||
|
@@ -247,7 +247,7 @@ void FinishedTorrents::updateFinishedList(){
|
|||||||
if (reponse == QMessageBox::Yes) {
|
if (reponse == QMessageBox::Yes) {
|
||||||
qDebug("Info: a torrent was moved from finished to download tab");
|
qDebug("Info: a torrent was moved from finished to download tab");
|
||||||
deleteTorrent(hash);
|
deleteTorrent(hash);
|
||||||
BTSession->setFinishedTorrent(hash);
|
BTSession->setUnfinishedTorrent(hash);
|
||||||
emit torrentMovedFromFinishedList(hash);
|
emit torrentMovedFromFinishedList(hash);
|
||||||
}
|
}
|
||||||
else if (reponse == QMessageBox::No) {
|
else if (reponse == QMessageBox::No) {
|
||||||
@@ -394,7 +394,7 @@ void FinishedTorrents::displayFinishedListMenu(const QPoint& pos){
|
|||||||
|
|
||||||
// Call menu
|
// Call menu
|
||||||
// XXX: why mapToGlobal() is not enough?
|
// XXX: why mapToGlobal() is not enough?
|
||||||
myFinishedListMenu.exec(mapToGlobal(pos)+QPoint(10,55));
|
myFinishedListMenu.exec(mapToGlobal(pos)+QPoint(10,59));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -410,7 +410,7 @@ void FinishedTorrents::displayFinishedHoSMenu(const QPoint& pos){
|
|||||||
hideshowColumn.addAction(getActionHoSCol(i));
|
hideshowColumn.addAction(getActionHoSCol(i));
|
||||||
}
|
}
|
||||||
// Call menu
|
// Call menu
|
||||||
hideshowColumn.exec(mapToGlobal(pos)+QPoint(10,55));
|
hideshowColumn.exec(mapToGlobal(pos)+QPoint(10,32));
|
||||||
}
|
}
|
||||||
|
|
||||||
// toggle hide/show a column
|
// toggle hide/show a column
|
||||||
|
BIN
src/Icons/flags/czech.png
Normal file
BIN
src/Icons/flags/czech.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 455 B |
BIN
src/Icons/flags/taiwan.png
Normal file
BIN
src/Icons/flags/taiwan.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 333 B |
@@ -1,7 +1,7 @@
|
|||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
Categories=Qt;Application;Network;P2P
|
Categories=Qt;Network;P2P
|
||||||
Comment=V1.1.0
|
Comment=V1.1.1
|
||||||
Exec=qbittorrent
|
Exec=qbittorrent %f
|
||||||
GenericName=Bittorrent client
|
GenericName=Bittorrent client
|
||||||
GenericName[bg]=Торент клиент
|
GenericName[bg]=Торент клиент
|
||||||
GenericName[de]=Bittorren Client
|
GenericName[de]=Bittorren Client
|
||||||
@@ -19,7 +19,7 @@ GenericName[tr]=Bittorrent istemcisi
|
|||||||
GenericName[uk]=Bittorrent-клієнт
|
GenericName[uk]=Bittorrent-клієнт
|
||||||
GenericName[zh]=Bittorrent之用户
|
GenericName[zh]=Bittorrent之用户
|
||||||
Icon=qbittorrent
|
Icon=qbittorrent
|
||||||
MimeType=application/x-bittorrent
|
MimeType=application/x-bittorrent;
|
||||||
Name=qBittorrent
|
Name=qBittorrent
|
||||||
Name[ko]=큐비토런트
|
Name[ko]=큐비토런트
|
||||||
Terminal=false
|
Terminal=false
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 75 KiB After Width: | Height: | Size: 76 KiB |
@@ -41,6 +41,7 @@ SearchTab::SearchTab(SearchEngine *parent) : QWidget()
|
|||||||
box=new QVBoxLayout();
|
box=new QVBoxLayout();
|
||||||
results_lbl=new QLabel();
|
results_lbl=new QLabel();
|
||||||
resultsBrowser = new QTreeView();
|
resultsBrowser = new QTreeView();
|
||||||
|
resultsBrowser->setSelectionMode(QAbstractItemView::ExtendedSelection);
|
||||||
box->addWidget(results_lbl);
|
box->addWidget(results_lbl);
|
||||||
box->addWidget(resultsBrowser);
|
box->addWidget(resultsBrowser);
|
||||||
|
|
||||||
@@ -185,4 +186,5 @@ bool SearchTab::loadColWidthSearchList(){
|
|||||||
}
|
}
|
||||||
qDebug("Search list columns width loaded");
|
qDebug("Search list columns width loaded");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -57,12 +57,14 @@ class about : public QDialog, private Ui::AboutDlg{
|
|||||||
- <u>Bulgarian:</u> Tsvetan & Boiko Bankov (emerge_life@users.sourceforge.net)<br>\
|
- <u>Bulgarian:</u> Tsvetan & Boiko Bankov (emerge_life@users.sourceforge.net)<br>\
|
||||||
- <u>Catalan:</u> Gekko Dam Beer (gekko04@users.sourceforge.net)<br>\
|
- <u>Catalan:</u> Gekko Dam Beer (gekko04@users.sourceforge.net)<br>\
|
||||||
- <u>Chinese (Simplified):</u> Guo Yue (guoyue0418@hotmail.com)<br>\
|
- <u>Chinese (Simplified):</u> Guo Yue (guoyue0418@hotmail.com)<br>\
|
||||||
|
- <u>Chinese (Traditional):</u> Yi-Shun Wang (dnextstep@gmail.com)<br>\
|
||||||
|
- <u>Czech:</u> Jirka Vilim (web@tets.cz)<br>\
|
||||||
- <u>Danish:</u> Mathias Nielsen (comoneo@gmail.com)<br>\
|
- <u>Danish:</u> Mathias Nielsen (comoneo@gmail.com)<br>\
|
||||||
- <u>Dutch:</u> Joost Schipper (heavyjoost@users.sourceforge.net)<br>\
|
- <u>Dutch:</u> Joost Schipper (heavyjoost@users.sourceforge.net) and Peter Koeleman (peter@peerweb.nl)<br>\
|
||||||
- <u>Finnish:</u> Niklas Laxström (nikerabbit@users.sourceforge.net)<br>\
|
- <u>Finnish:</u> Niklas Laxström (nikerabbit@users.sourceforge.net)<br>\
|
||||||
- <u>German:</u> Niels Hoffmann (zentralmaschine@users.sourceforge.net)<br>\
|
- <u>German:</u> Niels Hoffmann (zentralmaschine@users.sourceforge.net)<br>\
|
||||||
- <u>Greek:</u> Tsvetan Bankov (emerge_life@users.sourceforge.net)<br>\
|
- <u>Greek:</u> Tsvetan Bankov (emerge_life@users.sourceforge.net)<br>\
|
||||||
- <u>Hungarian:</u> Majoros Péter (majoros.j.p@t-online.hu)<br>\
|
- <u>Hungarian:</u> Majoros Péter (majoros.peterj@gmail.com)<br>\
|
||||||
- <u>Italian:</u> Mirko Ferrari (mirkoferrari@gmail.com) and Ferraro Luciano (luciano.ferraro@gmail.com)<br>\
|
- <u>Italian:</u> Mirko Ferrari (mirkoferrari@gmail.com) and Ferraro Luciano (luciano.ferraro@gmail.com)<br>\
|
||||||
- <u>Japanese:</u> Nardog (nardog@e2umail.com)<br>\
|
- <u>Japanese:</u> Nardog (nardog@e2umail.com)<br>\
|
||||||
- <u>Korean:</u> Jin Woo Sin (jin828sin@users.sourceforge.net)<br>\
|
- <u>Korean:</u> Jin Woo Sin (jin828sin@users.sourceforge.net)<br>\
|
||||||
@@ -70,9 +72,9 @@ class about : public QDialog, private Ui::AboutDlg{
|
|||||||
- <u>Polish:</u> Jarek Smieja (ajep9691@wp.pl)<br>\
|
- <u>Polish:</u> Jarek Smieja (ajep9691@wp.pl)<br>\
|
||||||
- <u>Portuguese:</u> Nick Marinho (nickmarinho@gmail.com)<br>\
|
- <u>Portuguese:</u> Nick Marinho (nickmarinho@gmail.com)<br>\
|
||||||
- <u>Romanian:</u> Obada Denis (obadadenis@users.sourceforge.net)<br>\
|
- <u>Romanian:</u> Obada Denis (obadadenis@users.sourceforge.net)<br>\
|
||||||
- <u>Russian:</u> Nick Khazov (m2k3d0n at users.sourceforge.net)<br>\
|
- <u>Russian:</u> Nick Khazov (m2k3d0n@users.sourceforge.net) and Alexey Morsov (samurai@ricom.ru)<br>\
|
||||||
- <u>Slovak:</u> helix84<br>\
|
- <u>Slovak:</u> helix84<br>\
|
||||||
- <u>Spanish:</u> Vicente Raul Plata Fonseca (silverxnt@users.sourceforge.net)<br>\
|
- <u>Spanish:</u> Vicente Raul Plata Fonseca (silverxnt@users.sourceforge.net) and Gabriel de Oliveira (deadloop@hotmail.com)<br>\
|
||||||
- <u>Swedish:</u> Daniel Nylander (po@danielnylander.se)<br>\
|
- <u>Swedish:</u> Daniel Nylander (po@danielnylander.se)<br>\
|
||||||
- <u>Turkish:</u> Erdem Bingöl (erdem84@gmail.com)<br>\
|
- <u>Turkish:</u> Erdem Bingöl (erdem84@gmail.com)<br>\
|
||||||
- <u>Ukrainian:</u> Andrey Shpachenko (masterfix@users.sourceforge.net)<br><br>"));
|
- <u>Ukrainian:</u> Andrey Shpachenko (masterfix@users.sourceforge.net)<br><br>"));
|
||||||
|
@@ -234,7 +234,7 @@ class arborescence {
|
|||||||
void addFile(QString path, size_type file_size, int index, float progress=0., int priority=1) {
|
void addFile(QString path, size_type file_size, int index, float progress=0., int priority=1) {
|
||||||
Q_ASSERT(root->isDir());
|
Q_ASSERT(root->isDir());
|
||||||
path = QDir::cleanPath(path);
|
path = QDir::cleanPath(path);
|
||||||
Q_ASSERT(path.startsWith(root->path()));
|
//Q_ASSERT(path.startsWith(root->path()));
|
||||||
QString relative_path = path.remove(0, root->path().size());
|
QString relative_path = path.remove(0, root->path().size());
|
||||||
if(relative_path.at(0) ==QDir::separator())
|
if(relative_path.at(0) ==QDir::separator())
|
||||||
relative_path.remove(0, 1);
|
relative_path.remove(0, 1);
|
||||||
|
@@ -933,6 +933,19 @@ void bittorrent::saveFastResumeAndRatioData() {
|
|||||||
}
|
}
|
||||||
saveFastResumeAndRatioData(hash);
|
saveFastResumeAndRatioData(hash);
|
||||||
}
|
}
|
||||||
|
hashes = getFinishedTorrents();
|
||||||
|
foreach(hash, hashes) {
|
||||||
|
QTorrentHandle h = getTorrentHandle(hash);
|
||||||
|
if(!h.is_valid()) {
|
||||||
|
qDebug("/!\\ Error: Invalid handle");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(h.is_paused()) {
|
||||||
|
// Do not need to save ratio data for paused torrents
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
saveDownloadUploadForTorrent(hash);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void bittorrent::saveFastResumeAndRatioData(QString hash) {
|
void bittorrent::saveFastResumeAndRatioData(QString hash) {
|
||||||
|
@@ -24,6 +24,8 @@
|
|||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#define MAX_THREADS 3
|
||||||
|
|
||||||
// http://curl.rtin.bz/libcurl/c/libcurl-errors.html
|
// http://curl.rtin.bz/libcurl/c/libcurl-errors.html
|
||||||
QString subDownloadThread::errorCodeToString(CURLcode status) {
|
QString subDownloadThread::errorCodeToString(CURLcode status) {
|
||||||
switch(status){
|
switch(status){
|
||||||
@@ -150,9 +152,7 @@ downloadThread::~downloadThread(){
|
|||||||
|
|
||||||
void downloadThread::downloadUrl(QString url){
|
void downloadThread::downloadUrl(QString url){
|
||||||
QMutexLocker locker(&mutex);
|
QMutexLocker locker(&mutex);
|
||||||
if(downloading_list.contains(url)) return;
|
urls_queue.enqueue(url);
|
||||||
url_list << url;
|
|
||||||
downloading_list << url;
|
|
||||||
if(!isRunning()){
|
if(!isRunning()){
|
||||||
start();
|
start();
|
||||||
}else{
|
}else{
|
||||||
@@ -165,8 +165,8 @@ void downloadThread::run(){
|
|||||||
if(abort)
|
if(abort)
|
||||||
return;
|
return;
|
||||||
mutex.lock();
|
mutex.lock();
|
||||||
if(url_list.size() != 0){
|
if(!urls_queue.empty() && subThreads.size() < MAX_THREADS){
|
||||||
QString url = url_list.takeFirst();
|
QString url = urls_queue.dequeue();
|
||||||
mutex.unlock();
|
mutex.unlock();
|
||||||
subDownloadThread *st = new subDownloadThread(0, url);
|
subDownloadThread *st = new subDownloadThread(0, url);
|
||||||
subThreads << st;
|
subThreads << st;
|
||||||
@@ -187,9 +187,9 @@ void downloadThread::propagateDownloadedFile(subDownloadThread* st, QString url,
|
|||||||
delete st;
|
delete st;
|
||||||
emit downloadFinished(url, path);
|
emit downloadFinished(url, path);
|
||||||
mutex.lock();
|
mutex.lock();
|
||||||
index = downloading_list.indexOf(url);
|
if(!urls_queue.empty()) {
|
||||||
Q_ASSERT(index != -1);
|
condition.wakeOne();
|
||||||
downloading_list.removeAt(index);
|
}
|
||||||
mutex.unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -200,8 +200,8 @@ void downloadThread::propagateDownloadFailure(subDownloadThread* st, QString url
|
|||||||
delete st;
|
delete st;
|
||||||
emit downloadFailure(url, reason);
|
emit downloadFailure(url, reason);
|
||||||
mutex.lock();
|
mutex.lock();
|
||||||
index = downloading_list.indexOf(url);
|
if(!urls_queue.empty()) {
|
||||||
Q_ASSERT(index != -1);
|
condition.wakeOne();
|
||||||
downloading_list.removeAt(index);
|
}
|
||||||
mutex.unlock();
|
mutex.unlock();
|
||||||
}
|
}
|
||||||
|
@@ -30,6 +30,7 @@
|
|||||||
#include <QWaitCondition>
|
#include <QWaitCondition>
|
||||||
#include <QStringList>
|
#include <QStringList>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
#include <QQueue>
|
||||||
|
|
||||||
class subDownloadThread : public QThread {
|
class subDownloadThread : public QThread {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@@ -55,8 +56,7 @@ class downloadThread : public QThread {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QStringList url_list;
|
QQueue<QString> urls_queue;
|
||||||
QStringList downloading_list;
|
|
||||||
QMutex mutex;
|
QMutex mutex;
|
||||||
QWaitCondition condition;
|
QWaitCondition condition;
|
||||||
bool abort;
|
bool abort;
|
||||||
|
@@ -311,7 +311,7 @@ void DownloadingTorrents::displayDLListMenu(const QPoint& pos) {
|
|||||||
myDLLlistMenu.addAction(actionBuy_it);
|
myDLLlistMenu.addAction(actionBuy_it);
|
||||||
// Call menu
|
// Call menu
|
||||||
// XXX: why mapToGlobal() is not enough?
|
// XXX: why mapToGlobal() is not enough?
|
||||||
myDLLlistMenu.exec(mapToGlobal(pos)+QPoint(10,60));
|
myDLLlistMenu.exec(mapToGlobal(pos)+QPoint(10,35));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -327,7 +327,7 @@ void DownloadingTorrents::displayDLHoSMenu(const QPoint& pos){
|
|||||||
hideshowColumn.addAction(getActionHoSCol(i));
|
hideshowColumn.addAction(getActionHoSCol(i));
|
||||||
}
|
}
|
||||||
// Call menu
|
// Call menu
|
||||||
hideshowColumn.exec(mapToGlobal(pos)+QPoint(10,55));
|
hideshowColumn.exec(mapToGlobal(pos)+QPoint(10,10));
|
||||||
}
|
}
|
||||||
|
|
||||||
// toggle hide/show a column
|
// toggle hide/show a column
|
||||||
|
@@ -30,6 +30,7 @@
|
|||||||
#include <QHttpResponseHeader>
|
#include <QHttpResponseHeader>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
#include <QTemporaryFile>
|
||||||
|
|
||||||
HttpConnection::HttpConnection(QTcpSocket *socket, HttpServer *parent)
|
HttpConnection::HttpConnection(QTcpSocket *socket, HttpServer *parent)
|
||||||
: QObject(parent), socket(socket), parent(parent)
|
: QObject(parent), socket(socket), parent(parent)
|
||||||
@@ -45,11 +46,17 @@ HttpConnection::~HttpConnection()
|
|||||||
|
|
||||||
void HttpConnection::read()
|
void HttpConnection::read()
|
||||||
{
|
{
|
||||||
QString input = socket->readAll();
|
QByteArray input = socket->readAll();
|
||||||
qDebug(" -------");
|
qDebug(" -------");
|
||||||
qDebug("|REQUEST|");
|
qDebug("|REQUEST|");
|
||||||
qDebug(" -------");
|
qDebug(" -------");
|
||||||
qDebug("%s", input.toAscii().constData());
|
//qDebug("%s", input.toAscii().constData());
|
||||||
|
if(input.size() > 100000) {
|
||||||
|
qDebug("Request too big");
|
||||||
|
generator.setStatusLine(400, "Bad Request");
|
||||||
|
write();
|
||||||
|
return;
|
||||||
|
}
|
||||||
parser.write(input);
|
parser.write(input);
|
||||||
if(parser.isError())
|
if(parser.isError())
|
||||||
{
|
{
|
||||||
@@ -74,6 +81,7 @@ void HttpConnection::write()
|
|||||||
|
|
||||||
void HttpConnection::respond()
|
void HttpConnection::respond()
|
||||||
{
|
{
|
||||||
|
qDebug("Respond called");
|
||||||
QStringList auth = parser.value("Authorization").split(" ", QString::SkipEmptyParts);
|
QStringList auth = parser.value("Authorization").split(" ", QString::SkipEmptyParts);
|
||||||
if (auth.size() != 2 || QString::compare(auth[0], "Basic", Qt::CaseInsensitive) != 0 || !parent->isAuthorized(auth[1].toUtf8()))
|
if (auth.size() != 2 || QString::compare(auth[0], "Basic", Qt::CaseInsensitive) != 0 || !parent->isAuthorized(auth[1].toUtf8()))
|
||||||
{
|
{
|
||||||
@@ -176,6 +184,25 @@ void HttpConnection::respondCommand(QString command)
|
|||||||
emit urlsReadyToBeDownloaded(url_list_cleaned);
|
emit urlsReadyToBeDownloaded(url_list_cleaned);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if(command == "upload")
|
||||||
|
{
|
||||||
|
QByteArray torrentfile = parser.torrent();
|
||||||
|
// XXX: Trick to get a unique filename
|
||||||
|
QString filePath;
|
||||||
|
QTemporaryFile *tmpfile = new QTemporaryFile();
|
||||||
|
if (tmpfile->open()) {
|
||||||
|
filePath = tmpfile->fileName();
|
||||||
|
}
|
||||||
|
delete tmpfile;
|
||||||
|
// write it to HD
|
||||||
|
QFile torrent(filePath);
|
||||||
|
if(torrent.open(QIODevice::WriteOnly)) {
|
||||||
|
torrent.write(torrentfile);
|
||||||
|
torrent.close();
|
||||||
|
}
|
||||||
|
emit torrentReadyToBeDownloaded(filePath, false, QString(), false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
if(command == "resumeall")
|
if(command == "resumeall")
|
||||||
{
|
{
|
||||||
emit resumeAllTorrents();
|
emit resumeAllTorrents();
|
||||||
|
@@ -57,6 +57,7 @@ class HttpConnection : public QObject
|
|||||||
|
|
||||||
signals:
|
signals:
|
||||||
void urlsReadyToBeDownloaded(const QStringList&);
|
void urlsReadyToBeDownloaded(const QStringList&);
|
||||||
|
void torrentReadyToBeDownloaded(QString, bool, QString, bool);
|
||||||
void deleteTorrent(QString hash);
|
void deleteTorrent(QString hash);
|
||||||
void resumeTorrent(QString hash);
|
void resumeTorrent(QString hash);
|
||||||
void pauseTorrent(QString hash);
|
void pauseTorrent(QString hash);
|
||||||
|
@@ -49,11 +49,11 @@ QString HttpRequestParser::url() const
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString HttpRequestParser::message() const
|
QByteArray HttpRequestParser::message() const
|
||||||
{
|
{
|
||||||
if(isParsable())
|
if(isParsable())
|
||||||
return data;
|
return data;
|
||||||
return QString();
|
return QByteArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString HttpRequestParser::get(const QString key) const
|
QString HttpRequestParser::get(const QString key) const
|
||||||
@@ -66,7 +66,12 @@ QString HttpRequestParser::post(const QString key) const
|
|||||||
return postMap[key];
|
return postMap[key];
|
||||||
}
|
}
|
||||||
|
|
||||||
void HttpRequestParser::write(QString str)
|
QByteArray HttpRequestParser::torrent() const
|
||||||
|
{
|
||||||
|
return torrent_content;
|
||||||
|
}
|
||||||
|
|
||||||
|
void HttpRequestParser::write(QByteArray str)
|
||||||
{
|
{
|
||||||
while (!headerDone && str.size()>0)
|
while (!headerDone && str.size()>0)
|
||||||
{
|
{
|
||||||
@@ -111,7 +116,7 @@ void HttpRequestParser::write(QString str)
|
|||||||
if(contentType() == "application/x-www-form-urlencoded")
|
if(contentType() == "application/x-www-form-urlencoded")
|
||||||
{
|
{
|
||||||
QUrl url;
|
QUrl url;
|
||||||
url.setEncodedQuery(data.toAscii());
|
url.setEncodedQuery(data);
|
||||||
QListIterator<QPair<QString, QString> > i(url.queryItems());
|
QListIterator<QPair<QString, QString> > i(url.queryItems());
|
||||||
while (i.hasNext())
|
while (i.hasNext())
|
||||||
{
|
{
|
||||||
@@ -120,9 +125,15 @@ void HttpRequestParser::write(QString str)
|
|||||||
qDebug() << pair.first << "=" << post(pair.first);
|
qDebug() << pair.first << "=" << post(pair.first);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(contentType() == "multipart/form-data")
|
||||||
|
{
|
||||||
|
//qDebug() << data.right(data.size()-data.indexOf("\r\n\r\n")-QByteArray("\r\n\r\n").size());
|
||||||
|
torrent_content = data.right(data.size()-data.indexOf("\r\n\r\n")-QByteArray("\r\n\r\n").size());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
error = true;
|
error = true;
|
||||||
}
|
}
|
||||||
|
qDebug() << "isError: " << isError();
|
||||||
}
|
}
|
||||||
|
@@ -30,10 +30,11 @@ class HttpRequestParser : public QHttpRequestHeader
|
|||||||
bool headerDone;
|
bool headerDone;
|
||||||
bool messageDone;
|
bool messageDone;
|
||||||
bool error;
|
bool error;
|
||||||
QString data;
|
QByteArray data;
|
||||||
QString path;
|
QString path;
|
||||||
QMap<QString, QString> postMap;
|
QMap<QString, QString> postMap;
|
||||||
QMap<QString, QString> getMap;
|
QMap<QString, QString> getMap;
|
||||||
|
QByteArray torrent_content;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
HttpRequestParser();
|
HttpRequestParser();
|
||||||
@@ -41,10 +42,11 @@ class HttpRequestParser : public QHttpRequestHeader
|
|||||||
bool isParsable() const;
|
bool isParsable() const;
|
||||||
bool isError() const;
|
bool isError() const;
|
||||||
QString url() const;
|
QString url() const;
|
||||||
QString message() const;
|
QByteArray message() const;
|
||||||
QString get(const QString key) const;
|
QString get(const QString key) const;
|
||||||
QString post(const QString key) const;
|
QString post(const QString key) const;
|
||||||
void write(QString str);
|
QByteArray torrent() const;
|
||||||
|
void write(QByteArray str);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -62,6 +62,7 @@ void HttpServer::newHttpConnection()
|
|||||||
HttpConnection *connection = new HttpConnection(socket, this);
|
HttpConnection *connection = new HttpConnection(socket, this);
|
||||||
//connect connection to BTSession
|
//connect connection to BTSession
|
||||||
connect(connection, SIGNAL(urlsReadyToBeDownloaded(const QStringList&)), BTSession, SLOT(downloadFromURLList(const QStringList&)));
|
connect(connection, SIGNAL(urlsReadyToBeDownloaded(const QStringList&)), BTSession, SLOT(downloadFromURLList(const QStringList&)));
|
||||||
|
connect(connection, SIGNAL(torrentReadyToBeDownloaded(QString, bool, QString, bool)), BTSession, SLOT(addTorrent(QString, bool, QString, bool)));
|
||||||
connect(connection, SIGNAL(deleteTorrent(QString)), BTSession, SLOT(deleteTorrent(QString)));
|
connect(connection, SIGNAL(deleteTorrent(QString)), BTSession, SLOT(deleteTorrent(QString)));
|
||||||
connect(connection, SIGNAL(pauseTorrent(QString)), BTSession, SLOT(pauseTorrent(QString)));
|
connect(connection, SIGNAL(pauseTorrent(QString)), BTSession, SLOT(pauseTorrent(QString)));
|
||||||
connect(connection, SIGNAL(resumeTorrent(QString)), BTSession, SLOT(resumeTorrent(QString)));
|
connect(connection, SIGNAL(resumeTorrent(QString)), BTSession, SLOT(resumeTorrent(QString)));
|
||||||
|
188
src/icons.qrc
188
src/icons.qrc
@@ -1,106 +1,108 @@
|
|||||||
<!DOCTYPE RCC><RCC version="1.0">
|
<!DOCTYPE RCC><RCC version="1.0">
|
||||||
<qresource>
|
<qresource>
|
||||||
<file>Icons/folder.png</file>
|
<file>Icons/add_file.png</file>
|
||||||
<file>Icons/qbittorrent32.png</file>
|
<file>Icons/add_folder.png</file>
|
||||||
<file>Icons/file.png</file>
|
<file>Icons/bt_settings.png</file>
|
||||||
<file>Icons/smile.png</file>
|
<file>Icons/button_cancel.png</file>
|
||||||
<file>Icons/qbittorrent22.png</file>
|
<file>Icons/button_ok.png</file>
|
||||||
<file>Icons/mascot.png</file>
|
|
||||||
<file>Icons/downarrow.png</file>
|
|
||||||
<file>Icons/unavailable.png</file>
|
|
||||||
<file>Icons/proxy.png</file>
|
|
||||||
<file>Icons/description.png</file>
|
|
||||||
<file>Icons/log.png</file>
|
|
||||||
<file>Icons/uparrow.png</file>
|
|
||||||
<file>Icons/home.png</file>
|
|
||||||
<file>Icons/unsubscribe.png</file>
|
|
||||||
<file>Icons/url.png</file>
|
|
||||||
<file>Icons/unsubscribe16.png</file>
|
|
||||||
<file>Icons/stare.png</file>
|
|
||||||
<file>Icons/qbittorrent16.png</file>
|
|
||||||
<file>Icons/locale.png</file>
|
|
||||||
<file>Icons/splash.png</file>
|
|
||||||
<file>Icons/subscribe16.png</file>
|
|
||||||
<file>Icons/loading.png</file>
|
|
||||||
<file>Icons/star.png</file>
|
|
||||||
<file>Icons/gnome-shutdown.png</file>
|
|
||||||
<file>Icons/style.png</file>
|
|
||||||
<file>Icons/rss16.png</file>
|
|
||||||
<file>Icons/configure.png</file>
|
<file>Icons/configure.png</file>
|
||||||
<file>Icons/connection.png</file>
|
<file>Icons/connection.png</file>
|
||||||
<file>Icons/systemtray.png</file>
|
<file>Icons/description.png</file>
|
||||||
<file>Icons/sphere.png</file>
|
<file>Icons/downarrow.png</file>
|
||||||
<file>Icons/add_folder.png</file>
|
|
||||||
<file>Icons/button_cancel.png</file>
|
|
||||||
<file>Icons/encrypted.png</file>
|
|
||||||
<file>Icons/wizard.png</file>
|
|
||||||
<file>Icons/edit_clear.png</file>
|
|
||||||
<file>Icons/rss32.png</file>
|
|
||||||
<file>Icons/subscribe.png</file>
|
|
||||||
<file>Icons/bt_settings.png</file>
|
|
||||||
<file>Icons/password.png</file>
|
|
||||||
<file>Icons/newmsg.png</file>
|
|
||||||
<file>Icons/sphere2.png</file>
|
|
||||||
<file>Icons/button_ok.png</file>
|
|
||||||
<file>Icons/unhappy.png</file>
|
|
||||||
<file>Icons/add_file.png</file>
|
|
||||||
<file>Icons/filter.png</file>
|
|
||||||
<file>Icons/money.png</file>
|
|
||||||
<file>Icons/download.png</file>
|
<file>Icons/download.png</file>
|
||||||
<file>Icons/time.png</file>
|
<file>Icons/edit_clear.png</file>
|
||||||
<file>Icons/refresh.png</file>
|
<file>Icons/encrypted.png</file>
|
||||||
|
<file>Icons/file.png</file>
|
||||||
|
<file>Icons/filter.png</file>
|
||||||
|
<file>Icons/folder.png</file>
|
||||||
<file>Icons/gear.png</file>
|
<file>Icons/gear.png</file>
|
||||||
<file>Icons/skin/new.png</file>
|
<file>Icons/gnome-shutdown.png</file>
|
||||||
<file>Icons/skin/qb_question.png</file>
|
<file>Icons/home.png</file>
|
||||||
<file>Icons/skin/play.png</file>
|
<file>Icons/loading.png</file>
|
||||||
<file>Icons/skin/connecting.png</file>
|
<file>Icons/locale.png</file>
|
||||||
<file>Icons/skin/settings.png</file>
|
<file>Icons/log.png</file>
|
||||||
<file>Icons/skin/add.png</file>
|
<file>Icons/mascot.png</file>
|
||||||
<file>Icons/skin/open.png</file>
|
<file>Icons/money.png</file>
|
||||||
<file>Icons/skin/play_all.png</file>
|
<file>Icons/newmsg.png</file>
|
||||||
<file>Icons/skin/info.png</file>
|
<file>Icons/password.png</file>
|
||||||
<file>Icons/skin/connected.png</file>
|
<file>Icons/proxy.png</file>
|
||||||
<file>Icons/skin/search.png</file>
|
<file>Icons/qbittorrent16.png</file>
|
||||||
<file>Icons/skin/url.png</file>
|
<file>Icons/qbittorrent22.png</file>
|
||||||
<file>Icons/skin/firewalled.png</file>
|
<file>Icons/qbittorrent32.png</file>
|
||||||
<file>Icons/skin/properties.png</file>
|
<file>Icons/refresh.png</file>
|
||||||
<file>Icons/skin/preview.png</file>
|
<file>Icons/rss16.png</file>
|
||||||
<file>Icons/skin/remove.png</file>
|
<file>Icons/rss32.png</file>
|
||||||
<file>Icons/skin/delete_perm.png</file>
|
<file>Icons/smile.png</file>
|
||||||
<file>Icons/skin/pause_all.png</file>
|
<file>Icons/sphere.png</file>
|
||||||
<file>Icons/skin/delete_all.png</file>
|
<file>Icons/sphere2.png</file>
|
||||||
<file>Icons/skin/stalled.png</file>
|
<file>Icons/splash.png</file>
|
||||||
<file>Icons/skin/downloading.png</file>
|
<file>Icons/star.png</file>
|
||||||
<file>Icons/skin/delete.png</file>
|
<file>Icons/stare.png</file>
|
||||||
<file>Icons/skin/exit.png</file>
|
<file>Icons/style.png</file>
|
||||||
<file>Icons/skin/seeding.png</file>
|
<file>Icons/subscribe.png</file>
|
||||||
<file>Icons/skin/paused.png</file>
|
<file>Icons/subscribe16.png</file>
|
||||||
<file>Icons/skin/disconnected.png</file>
|
<file>Icons/systemtray.png</file>
|
||||||
<file>Icons/skin/pause.png</file>
|
<file>Icons/time.png</file>
|
||||||
<file>Icons/flags/turkey.png</file>
|
<file>Icons/unavailable.png</file>
|
||||||
<file>Icons/flags/portugal.png</file>
|
<file>Icons/unhappy.png</file>
|
||||||
<file>Icons/flags/finland.png</file>
|
<file>Icons/unsubscribe.png</file>
|
||||||
<file>Icons/flags/ukraine.png</file>
|
<file>Icons/unsubscribe16.png</file>
|
||||||
<file>Icons/flags/bulgaria.png</file>
|
<file>Icons/uparrow.png</file>
|
||||||
<file>Icons/flags/spain_catalunya.png</file>
|
<file>Icons/url.png</file>
|
||||||
|
<file>Icons/wizard.png</file>
|
||||||
<file>Icons/flags/brazil.png</file>
|
<file>Icons/flags/brazil.png</file>
|
||||||
<file>Icons/flags/norway.png</file>
|
<file>Icons/flags/bulgaria.png</file>
|
||||||
<file>Icons/flags/slovakia.png</file>
|
|
||||||
<file>Icons/flags/romania.png</file>
|
|
||||||
<file>Icons/flags/united_kingdom.png</file>
|
|
||||||
<file>Icons/flags/netherlands.png</file>
|
|
||||||
<file>Icons/flags/china.png</file>
|
<file>Icons/flags/china.png</file>
|
||||||
|
<file>Icons/flags/czech.png</file>
|
||||||
<file>Icons/flags/denmark.png</file>
|
<file>Icons/flags/denmark.png</file>
|
||||||
<file>Icons/flags/hungary.png</file>
|
<file>Icons/flags/finland.png</file>
|
||||||
<file>Icons/flags/greece.png</file>
|
|
||||||
<file>Icons/flags/spain.png</file>
|
|
||||||
<file>Icons/flags/italy.png</file>
|
|
||||||
<file>Icons/flags/germany.png</file>
|
|
||||||
<file>Icons/flags/russia.png</file>
|
|
||||||
<file>Icons/flags/japan.png</file>
|
|
||||||
<file>Icons/flags/south_korea.png</file>
|
|
||||||
<file>Icons/flags/france.png</file>
|
<file>Icons/flags/france.png</file>
|
||||||
<file>Icons/flags/sweden.png</file>
|
<file>Icons/flags/germany.png</file>
|
||||||
|
<file>Icons/flags/greece.png</file>
|
||||||
|
<file>Icons/flags/hungary.png</file>
|
||||||
|
<file>Icons/flags/italy.png</file>
|
||||||
|
<file>Icons/flags/japan.png</file>
|
||||||
|
<file>Icons/flags/netherlands.png</file>
|
||||||
|
<file>Icons/flags/norway.png</file>
|
||||||
<file>Icons/flags/poland.png</file>
|
<file>Icons/flags/poland.png</file>
|
||||||
|
<file>Icons/flags/portugal.png</file>
|
||||||
|
<file>Icons/flags/romania.png</file>
|
||||||
|
<file>Icons/flags/russia.png</file>
|
||||||
|
<file>Icons/flags/slovakia.png</file>
|
||||||
|
<file>Icons/flags/south_korea.png</file>
|
||||||
|
<file>Icons/flags/spain.png</file>
|
||||||
|
<file>Icons/flags/spain_catalunya.png</file>
|
||||||
|
<file>Icons/flags/sweden.png</file>
|
||||||
|
<file>Icons/flags/taiwan.png</file>
|
||||||
|
<file>Icons/flags/turkey.png</file>
|
||||||
|
<file>Icons/flags/ukraine.png</file>
|
||||||
|
<file>Icons/flags/united_kingdom.png</file>
|
||||||
|
<file>Icons/skin/add.png</file>
|
||||||
|
<file>Icons/skin/connected.png</file>
|
||||||
|
<file>Icons/skin/connecting.png</file>
|
||||||
|
<file>Icons/skin/delete.png</file>
|
||||||
|
<file>Icons/skin/delete_all.png</file>
|
||||||
|
<file>Icons/skin/delete_perm.png</file>
|
||||||
|
<file>Icons/skin/disconnected.png</file>
|
||||||
|
<file>Icons/skin/downloading.png</file>
|
||||||
|
<file>Icons/skin/exit.png</file>
|
||||||
|
<file>Icons/skin/firewalled.png</file>
|
||||||
|
<file>Icons/skin/info.png</file>
|
||||||
|
<file>Icons/skin/new.png</file>
|
||||||
|
<file>Icons/skin/open.png</file>
|
||||||
|
<file>Icons/skin/pause.png</file>
|
||||||
|
<file>Icons/skin/pause_all.png</file>
|
||||||
|
<file>Icons/skin/paused.png</file>
|
||||||
|
<file>Icons/skin/play.png</file>
|
||||||
|
<file>Icons/skin/play_all.png</file>
|
||||||
|
<file>Icons/skin/preview.png</file>
|
||||||
|
<file>Icons/skin/properties.png</file>
|
||||||
|
<file>Icons/skin/qb_question.png</file>
|
||||||
|
<file>Icons/skin/remove.png</file>
|
||||||
|
<file>Icons/skin/search.png</file>
|
||||||
|
<file>Icons/skin/seeding.png</file>
|
||||||
|
<file>Icons/skin/settings.png</file>
|
||||||
|
<file>Icons/skin/stalled.png</file>
|
||||||
|
<file>Icons/skin/url.png</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
38
src/lang.qrc
38
src/lang.qrc
@@ -1,29 +1,31 @@
|
|||||||
<!DOCTYPE RCC><RCC version="1.0">
|
<!DOCTYPE RCC><RCC version="1.0">
|
||||||
<qresource>
|
<qresource>
|
||||||
<file>lang/qbittorrent_uk.qm</file>
|
<file>lang/qbittorrent_bg.qm</file>
|
||||||
<file>lang/qbittorrent_tr.qm</file>
|
<file>lang/qbittorrent_ca.qm</file>
|
||||||
<file>lang/qbittorrent_nl.qm</file>
|
<file>lang/qbittorrent_cs.qm</file>
|
||||||
<file>lang/qbittorrent_de.qm</file>
|
|
||||||
<file>lang/qbittorrent_ru.qm</file>
|
|
||||||
<file>lang/qbittorrent_fr.qm</file>
|
|
||||||
<file>lang/qbittorrent_da.qm</file>
|
<file>lang/qbittorrent_da.qm</file>
|
||||||
|
<file>lang/qbittorrent_de.qm</file>
|
||||||
|
<file>lang/qbittorrent_el.qm</file>
|
||||||
|
<file>lang/qbittorrent_en.qm</file>
|
||||||
|
<file>lang/qbittorrent_es.qm</file>
|
||||||
<file>lang/qbittorrent_fi.qm</file>
|
<file>lang/qbittorrent_fi.qm</file>
|
||||||
<file>lang/qbittorrent_pl.qm</file>
|
<file>lang/qbittorrent_fr.qm</file>
|
||||||
|
<file>lang/qbittorrent_hu.qm</file>
|
||||||
|
<file>lang/qbittorrent_it.qm</file>
|
||||||
|
<file>lang/qbittorrent_ja.qm</file>
|
||||||
<file>lang/qbittorrent_ko.qm</file>
|
<file>lang/qbittorrent_ko.qm</file>
|
||||||
<file>lang/qbittorrent_nb.qm</file>
|
<file>lang/qbittorrent_nb.qm</file>
|
||||||
<file>lang/qbittorrent_sv.qm</file>
|
<file>lang/qbittorrent_nl.qm</file>
|
||||||
<file>lang/qbittorrent_zh.qm</file>
|
<file>lang/qbittorrent_pl.qm</file>
|
||||||
<file>lang/qbittorrent_el.qm</file>
|
|
||||||
<file>lang/qbittorrent_sk.qm</file>
|
|
||||||
<file>lang/qbittorrent_ca.qm</file>
|
|
||||||
<file>lang/qbittorrent_hu.qm</file>
|
|
||||||
<file>lang/qbittorrent_bg.qm</file>
|
|
||||||
<file>lang/qbittorrent_it.qm</file>
|
|
||||||
<file>lang/qbittorrent_pt.qm</file>
|
<file>lang/qbittorrent_pt.qm</file>
|
||||||
<file>lang/qbittorrent_en.qm</file>
|
|
||||||
<file>lang/qbittorrent_pt_BR.qm</file>
|
<file>lang/qbittorrent_pt_BR.qm</file>
|
||||||
<file>lang/qbittorrent_ja.qm</file>
|
|
||||||
<file>lang/qbittorrent_ro.qm</file>
|
<file>lang/qbittorrent_ro.qm</file>
|
||||||
<file>lang/qbittorrent_es.qm</file>
|
<file>lang/qbittorrent_ru.qm</file>
|
||||||
|
<file>lang/qbittorrent_sk.qm</file>
|
||||||
|
<file>lang/qbittorrent_sv.qm</file>
|
||||||
|
<file>lang/qbittorrent_tr.qm</file>
|
||||||
|
<file>lang/qbittorrent_uk.qm</file>
|
||||||
|
<file>lang/qbittorrent_zh.qm</file>
|
||||||
|
<file>lang/qbittorrent_zh_TW.qm</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
Binary file not shown.
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@@ -2666,7 +2666,7 @@ Are you sure you want to quit qBittorrent?</source>
|
|||||||
<message>
|
<message>
|
||||||
<location filename="../rss_imp.cpp" line="171"/>
|
<location filename="../rss_imp.cpp" line="171"/>
|
||||||
<source>qBittorrent</source>
|
<source>qBittorrent</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished">qBittorrent</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../rss_imp.cpp" line="172"/>
|
<location filename="../rss_imp.cpp" line="172"/>
|
||||||
@@ -2838,31 +2838,31 @@ Log:
|
|||||||
<context>
|
<context>
|
||||||
<name>SearchTab</name>
|
<name>SearchTab</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="50"/>
|
<location filename="../SearchTab.cpp" line="51"/>
|
||||||
<source>Name</source>
|
<source>Name</source>
|
||||||
<comment>i.e: file name</comment>
|
<comment>i.e: file name</comment>
|
||||||
<translation type="unfinished">Nom</translation>
|
<translation type="unfinished">Nom</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="51"/>
|
<location filename="../SearchTab.cpp" line="52"/>
|
||||||
<source>Size</source>
|
<source>Size</source>
|
||||||
<comment>i.e: file size</comment>
|
<comment>i.e: file size</comment>
|
||||||
<translation type="unfinished">Mida</translation>
|
<translation type="unfinished">Mida</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="52"/>
|
<location filename="../SearchTab.cpp" line="53"/>
|
||||||
<source>Seeders</source>
|
<source>Seeders</source>
|
||||||
<comment>i.e: Number of full sources</comment>
|
<comment>i.e: Number of full sources</comment>
|
||||||
<translation type="unfinished">Seeders</translation>
|
<translation type="unfinished">Seeders</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="53"/>
|
<location filename="../SearchTab.cpp" line="54"/>
|
||||||
<source>Leechers</source>
|
<source>Leechers</source>
|
||||||
<comment>i.e: Number of partial sources</comment>
|
<comment>i.e: Number of partial sources</comment>
|
||||||
<translation type="unfinished">Leechers</translation>
|
<translation type="unfinished">Leechers</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="54"/>
|
<location filename="../SearchTab.cpp" line="55"/>
|
||||||
<source>Search engine</source>
|
<source>Search engine</source>
|
||||||
<translation type="unfinished">Motor per cercar</translation>
|
<translation type="unfinished">Motor per cercar</translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -2958,7 +2958,7 @@ Log:
|
|||||||
<message>
|
<message>
|
||||||
<location filename="../about_imp.h" line="43"/>
|
<location filename="../about_imp.h" line="43"/>
|
||||||
<source>qBittorrent</source>
|
<source>qBittorrent</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished">qBittorrent</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../about_imp.h" line="54"/>
|
<location filename="../about_imp.h" line="54"/>
|
||||||
@@ -2966,7 +2966,7 @@ Log:
|
|||||||
<translation type="unfinished">Vui agrair a les següents persones la seva voluntat per traduir qBittorrent:</translation>
|
<translation type="unfinished">Vui agrair a les següents persones la seva voluntat per traduir qBittorrent:</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../about_imp.h" line="79"/>
|
<location filename="../about_imp.h" line="81"/>
|
||||||
<source>Please contact me if you would like to translate qBittorrent into your own language.</source>
|
<source>Please contact me if you would like to translate qBittorrent into your own language.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -3673,7 +3673,7 @@ However, those plugins were disabled.</source>
|
|||||||
<message>
|
<message>
|
||||||
<location filename="../engineSelectDlg.cpp" line="700"/>
|
<location filename="../engineSelectDlg.cpp" line="700"/>
|
||||||
<source>qBittorrent</source>
|
<source>qBittorrent</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished">qBittorrent</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../engineSelectDlg.cpp" line="478"/>
|
<location filename="../engineSelectDlg.cpp" line="478"/>
|
||||||
@@ -3800,7 +3800,7 @@ However, those plugins were disabled.</source>
|
|||||||
<message>
|
<message>
|
||||||
<location filename="../misc.h" line="322"/>
|
<location filename="../misc.h" line="322"/>
|
||||||
<source>Unknown</source>
|
<source>Unknown</source>
|
||||||
<translation>Desconegut</translation>
|
<translation type="obsolete">Desconegut</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../misc.h" line="110"/>
|
<location filename="../misc.h" line="110"/>
|
||||||
@@ -3947,17 +3947,17 @@ However, those plugins were disabled.</source>
|
|||||||
<translation type="obsolete">Aquesta IP es invalida.</translation>
|
<translation type="obsolete">Aquesta IP es invalida.</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="774"/>
|
<location filename="../options_imp.cpp" line="778"/>
|
||||||
<source>Options were saved successfully.</source>
|
<source>Options were saved successfully.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1052"/>
|
<location filename="../options_imp.cpp" line="1056"/>
|
||||||
<source>Choose scan directory</source>
|
<source>Choose scan directory</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1067"/>
|
<location filename="../options_imp.cpp" line="1071"/>
|
||||||
<source>Choose a save directory</source>
|
<source>Choose a save directory</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -3968,12 +3968,12 @@ However, those plugins were disabled.</source>
|
|||||||
<translation type="obsolete">I/O Error</translation>
|
<translation type="obsolete">I/O Error</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1059"/>
|
<location filename="../options_imp.cpp" line="1063"/>
|
||||||
<source>Choose an ip filter file</source>
|
<source>Choose an ip filter file</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1059"/>
|
<location filename="../options_imp.cpp" line="1063"/>
|
||||||
<source>Filters</source>
|
<source>Filters</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -4372,7 +4372,7 @@ However, those plugins were disabled.</source>
|
|||||||
<message>
|
<message>
|
||||||
<location filename="../properties_imp.cpp" line="534"/>
|
<location filename="../properties_imp.cpp" line="534"/>
|
||||||
<source>qBittorrent</source>
|
<source>qBittorrent</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished">qBittorrent</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../properties_imp.cpp" line="535"/>
|
<location filename="../properties_imp.cpp" line="535"/>
|
||||||
@@ -4601,47 +4601,47 @@ However, those plugins were disabled.</source>
|
|||||||
<context>
|
<context>
|
||||||
<name>subDownloadThread</name>
|
<name>subDownloadThread</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="32"/>
|
<location filename="../downloadThread.cpp" line="34"/>
|
||||||
<source>Host is unreachable</source>
|
<source>Host is unreachable</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="35"/>
|
<location filename="../downloadThread.cpp" line="37"/>
|
||||||
<source>File was not found (404)</source>
|
<source>File was not found (404)</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="39"/>
|
<location filename="../downloadThread.cpp" line="41"/>
|
||||||
<source>Connection was denied</source>
|
<source>Connection was denied</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="41"/>
|
<location filename="../downloadThread.cpp" line="43"/>
|
||||||
<source>Url is invalid</source>
|
<source>Url is invalid</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="51"/>
|
<location filename="../downloadThread.cpp" line="53"/>
|
||||||
<source>Connection failure</source>
|
<source>Connection failure</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="53"/>
|
<location filename="../downloadThread.cpp" line="55"/>
|
||||||
<source>Connection was timed out</source>
|
<source>Connection was timed out</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="55"/>
|
<location filename="../downloadThread.cpp" line="57"/>
|
||||||
<source>Incorrect network interface</source>
|
<source>Incorrect network interface</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="57"/>
|
<location filename="../downloadThread.cpp" line="59"/>
|
||||||
<source>Unknown error</source>
|
<source>Unknown error</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="43"/>
|
<location filename="../downloadThread.cpp" line="45"/>
|
||||||
<source>Could not resolve proxy</source>
|
<source>Could not resolve proxy</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
BIN
src/lang/qbittorrent_cs.qm
Normal file
BIN
src/lang/qbittorrent_cs.qm
Normal file
Binary file not shown.
2968
src/lang/qbittorrent_cs.ts
Normal file
2968
src/lang/qbittorrent_cs.ts
Normal file
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@@ -2296,31 +2296,31 @@ Changelog:
|
|||||||
<context>
|
<context>
|
||||||
<name>SearchTab</name>
|
<name>SearchTab</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="50"/>
|
<location filename="../SearchTab.cpp" line="51"/>
|
||||||
<source>Name</source>
|
<source>Name</source>
|
||||||
<comment>i.e: file name</comment>
|
<comment>i.e: file name</comment>
|
||||||
<translation type="unfinished">Navn</translation>
|
<translation type="unfinished">Navn</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="51"/>
|
<location filename="../SearchTab.cpp" line="52"/>
|
||||||
<source>Size</source>
|
<source>Size</source>
|
||||||
<comment>i.e: file size</comment>
|
<comment>i.e: file size</comment>
|
||||||
<translation type="unfinished">Størrelse</translation>
|
<translation type="unfinished">Størrelse</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="52"/>
|
<location filename="../SearchTab.cpp" line="53"/>
|
||||||
<source>Seeders</source>
|
<source>Seeders</source>
|
||||||
<comment>i.e: Number of full sources</comment>
|
<comment>i.e: Number of full sources</comment>
|
||||||
<translation type="unfinished">Seedere</translation>
|
<translation type="unfinished">Seedere</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="53"/>
|
<location filename="../SearchTab.cpp" line="54"/>
|
||||||
<source>Leechers</source>
|
<source>Leechers</source>
|
||||||
<comment>i.e: Number of partial sources</comment>
|
<comment>i.e: Number of partial sources</comment>
|
||||||
<translation type="unfinished">Leechere</translation>
|
<translation type="unfinished">Leechere</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../SearchTab.cpp" line="54"/>
|
<location filename="../SearchTab.cpp" line="55"/>
|
||||||
<source>Search engine</source>
|
<source>Search engine</source>
|
||||||
<translation type="unfinished">Søgemaskine</translation>
|
<translation type="unfinished">Søgemaskine</translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -2404,7 +2404,7 @@ Changelog:
|
|||||||
<translation type="unfinished">Jeg vil gerne takke disse personer, som meldte sig frivilligt til at oversætte qBittorrent:</translation>
|
<translation type="unfinished">Jeg vil gerne takke disse personer, som meldte sig frivilligt til at oversætte qBittorrent:</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../about_imp.h" line="79"/>
|
<location filename="../about_imp.h" line="81"/>
|
||||||
<source>Please contact me if you would like to translate qBittorrent into your own language.</source>
|
<source>Please contact me if you would like to translate qBittorrent into your own language.</source>
|
||||||
<translation type="unfinished">Kontakt mig venligst hvis du kunne tænke dig og oversætte qBittorrent til dit eget sprog.</translation>
|
<translation type="unfinished">Kontakt mig venligst hvis du kunne tænke dig og oversætte qBittorrent til dit eget sprog.</translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -3195,7 +3195,7 @@ However, those plugins were disabled.</source>
|
|||||||
<message>
|
<message>
|
||||||
<location filename="../misc.h" line="322"/>
|
<location filename="../misc.h" line="322"/>
|
||||||
<source>Unknown</source>
|
<source>Unknown</source>
|
||||||
<translation>Ukendt</translation>
|
<translation type="obsolete">Ukendt</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../misc.h" line="110"/>
|
<location filename="../misc.h" line="110"/>
|
||||||
@@ -3282,12 +3282,12 @@ However, those plugins were disabled.</source>
|
|||||||
<translation type="obsolete">Denne IP er ugyldig.</translation>
|
<translation type="obsolete">Denne IP er ugyldig.</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="774"/>
|
<location filename="../options_imp.cpp" line="778"/>
|
||||||
<source>Options were saved successfully.</source>
|
<source>Options were saved successfully.</source>
|
||||||
<translation>Indstillingerne blev gemt.</translation>
|
<translation>Indstillingerne blev gemt.</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1052"/>
|
<location filename="../options_imp.cpp" line="1056"/>
|
||||||
<source>Choose scan directory</source>
|
<source>Choose scan directory</source>
|
||||||
<translation>Vælg mappe til scan</translation>
|
<translation>Vælg mappe til scan</translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -3297,7 +3297,7 @@ However, those plugins were disabled.</source>
|
|||||||
<translation type="obsolete">Vælg en ipfilter.dat fil</translation>
|
<translation type="obsolete">Vælg en ipfilter.dat fil</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1067"/>
|
<location filename="../options_imp.cpp" line="1071"/>
|
||||||
<source>Choose a save directory</source>
|
<source>Choose a save directory</source>
|
||||||
<translation>Vælg en standart mappe</translation>
|
<translation>Vælg en standart mappe</translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -3313,12 +3313,12 @@ However, those plugins were disabled.</source>
|
|||||||
<translation type="obsolete">Kunne ikke åbne %1 til læsning.</translation>
|
<translation type="obsolete">Kunne ikke åbne %1 til læsning.</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1059"/>
|
<location filename="../options_imp.cpp" line="1063"/>
|
||||||
<source>Choose an ip filter file</source>
|
<source>Choose an ip filter file</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../options_imp.cpp" line="1059"/>
|
<location filename="../options_imp.cpp" line="1063"/>
|
||||||
<source>Filters</source>
|
<source>Filters</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -3826,47 +3826,47 @@ However, those plugins were disabled.</source>
|
|||||||
<context>
|
<context>
|
||||||
<name>subDownloadThread</name>
|
<name>subDownloadThread</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="32"/>
|
<location filename="../downloadThread.cpp" line="34"/>
|
||||||
<source>Host is unreachable</source>
|
<source>Host is unreachable</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="35"/>
|
<location filename="../downloadThread.cpp" line="37"/>
|
||||||
<source>File was not found (404)</source>
|
<source>File was not found (404)</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="39"/>
|
<location filename="../downloadThread.cpp" line="41"/>
|
||||||
<source>Connection was denied</source>
|
<source>Connection was denied</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="41"/>
|
<location filename="../downloadThread.cpp" line="43"/>
|
||||||
<source>Url is invalid</source>
|
<source>Url is invalid</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="51"/>
|
<location filename="../downloadThread.cpp" line="53"/>
|
||||||
<source>Connection failure</source>
|
<source>Connection failure</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="53"/>
|
<location filename="../downloadThread.cpp" line="55"/>
|
||||||
<source>Connection was timed out</source>
|
<source>Connection was timed out</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="55"/>
|
<location filename="../downloadThread.cpp" line="57"/>
|
||||||
<source>Incorrect network interface</source>
|
<source>Incorrect network interface</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="57"/>
|
<location filename="../downloadThread.cpp" line="59"/>
|
||||||
<source>Unknown error</source>
|
<source>Unknown error</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../downloadThread.cpp" line="43"/>
|
<location filename="../downloadThread.cpp" line="45"/>
|
||||||
<source>Could not resolve proxy</source>
|
<source>Could not resolve proxy</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
Binary file not shown.
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user