- Optimized Bittorrent class for faster compilation

This commit is contained in:
Christophe Dumez 2007-07-30 13:56:31 +00:00
parent 58b5d4378d
commit 8fdc59c37c
2 changed files with 15 additions and 8 deletions

View File

@ -22,6 +22,7 @@
#include <QDir>
#include <QTime>
#include <QString>
#include <QTimer>
#include <libtorrent/extensions/metadata_transfer.hpp>
#include <libtorrent/extensions/ut_pex.hpp>
@ -43,6 +44,7 @@
bittorrent::bittorrent(){
// To avoid some exceptions
fs::path::default_name_check(fs::no_check);
timerScan = 0;
// Supported preview extensions
// XXX: A bit dirty to do it this way (use mime types?)
supported_preview_extensions << "AVI" << "DIVX" << "MPG" << "MPEG" << "MPE" << "MP3" << "OGG" << "WMV" << "WMA" << "RMV" << "RMVB" << "ASF" << "MOV" << "WAV" << "MP2" << "SWF" << "AC3" << "OGM" << "MP4" << "FLV" << "VOB" << "QT" << "MKV" << "AIF" << "AIFF" << "AIFC" << "MID" << "MPG" << "RA" << "RAM" << "AU" << "M4A" << "FLAC" << "M4P" << "3GP" << "AAC" << "RM" << "SWA" << "MPC" << "MPP";
@ -54,10 +56,12 @@ bittorrent::bittorrent(){
DHTEnabled = false;
// Enabling metadata plugin
s->add_extension(&create_metadata_plugin);
connect(&timerAlerts, SIGNAL(timeout()), this, SLOT(readAlerts()));
timerAlerts.start(3000);
connect(&ETARefresher, SIGNAL(timeout()), this, SLOT(updateETAs()));
ETARefresher.start(6000);
timerAlerts = new QTimer();
connect(timerAlerts, SIGNAL(timeout()), this, SLOT(readAlerts()));
timerAlerts->start(3000);
ETARefresher = new QTimer();
connect(ETARefresher, SIGNAL(timeout()), this, SLOT(updateETAs()));
ETARefresher->start(6000);
// To download from urls
downloader = new downloadThread(this);
connect(downloader, SIGNAL(downloadFinished(QString, QString)), this, SLOT(processDownloadedFile(QString, QString)));
@ -72,6 +76,8 @@ bittorrent::~bittorrent(){
saveDHTEntry();
saveFastResumeAndRatioData();
// Delete our objects
delete timerAlerts;
delete ETARefresher;
delete downloader;
delete s;
}
@ -752,8 +758,9 @@ void bittorrent::disableDirectoryScanning(){
if(timerScan->isActive()){
timerScan->stop();
}
delete timerScan;
}
if(timerScan != 0)
delete timerScan;
}
// Set the ports range in which is chosen the port the bittorrent

View File

@ -22,7 +22,6 @@
#define __BITTORRENT_H__
#include <QHash>
#include <QTimer>
#include <QList>
#include <QPair>
#include <QStringList>
@ -34,6 +33,7 @@ using namespace libtorrent;
class downloadThread;
class deleteThread;
class QTimer;
class bittorrent : public QObject{
Q_OBJECT
@ -43,7 +43,7 @@ class bittorrent : public QObject{
bool DHTEnabled;
QString scan_dir;
QTimer *timerScan;
QTimer timerAlerts;
QTimer *timerAlerts;
downloadThread *downloader;
QStringList supported_preview_extensions;
QString defaultSavePath;
@ -52,7 +52,7 @@ class bittorrent : public QObject{
QHash<QString, QList<long> > ETAstats;
QHash<QString, long> ETAs;
QHash<QString, QPair<size_type,size_type> > ratioData;
QTimer ETARefresher;
QTimer *ETARefresher;
QList<QString> fullAllocationModeList;
QHash<QString, QList<QPair<QString, QString> > > trackersErrors;