tabWidget_(NULL),
dlView_(NULL),
seedView_(NULL),
+ searchWidget_(NULL),
preferencesDialog_(NULL),
settings_(),
pluginDirs_(),
SLOT(setEnabled(bool)));
connect(toolBar, SIGNAL(actionTriggered(QAction*)), this,
SLOT(handleToolBarAction(QAction*)));
-
+ connect (tabWidget_, SIGNAL(tabCloseRequested(int)), this, SLOT(on_tabWidget_tabCloseRequested(int)));
+
connect(&btSession_, SIGNAL(alert(std::auto_ptr<Alert>)),
this, SLOT(on_alert(std::auto_ptr<Alert>)));
}
// ===================== Implements PluginInterface =========================
-bool MainWindow::setGui(QWidget* widget, PluginWidgetType type)
+/// @todo add PluginInterface parameter to request plugin name
+bool MainWindow::setGui(QWidget* widget, PluginWidgetType type, qtrapids::PluginInterface* plugin)
{
#ifdef QTRAPIDS_DEBUG
qDebug() << "MainWindow::setGui():" << dlView_->currentItem();
#endif
+
+ if (plugin && plugin->identifier() == "SearchPlugin") {
+ searchWidget_ = widget;
+ } else {
+ return false;
+ }
+
tabWidget_->addTab(widget, tr("Search"));
return true;
}
-/// @todo Add PluginInterface parameter check which plugin gives the widget to handle appropriately
+/// @todo Add PluginInterface parameter to check which plugin gives the widget, to handle appropriately
void MainWindow::addPluginWidget(QWidget* widget, PluginWidgetType type)
{
#ifdef QTRAPIDS_DEBUG
#endif
if (type == qtrapids::PluginHostInterface::TAB_PAGE) {
- int index = tabWidget_->addTab(widget, tr("Test"));
+ int index = tabWidget_->addTab(widget, tr("Results"));
tabWidget_->setCurrentIndex(index);
//layout_->addWidget(widget);
}
bool MainWindow::eventRequest(QVariant param, PluginRequest req)
{
if (req == qtrapids::PluginHostInterface::OPEN_FILE) {
- QString sourceFile = param.toString();
-
+ QString sourceFile = param.toString();
+
// Get the source files name from the full path:
QFileInfo fInfo(sourceFile);
QString targetFile = fInfo.fileName();
- targetFile = settings_.value("download/directory").toString() + targetFile;
+ targetFile = settings_.value("download/directory").toString() + "/" + targetFile;
// Copy temoporary file to Downloads directory...
if (!QFile::copy(sourceFile, targetFile)) {
// If copying was successful, remove the original temporary file.
QFile::remove(sourceFile);
}
-
+
+ /// @todo Torrent bencoding validity should be checked before starting(?)
// ...and start the torrent:
on_torrentFileSelected(targetFile);
+
+ } else if (req == qtrapids::PluginHostInterface::READ_BUFFER) {
+ // Create torrent information from char* buffer and start.
+ StartTorrentFromBufferData(param.toByteArray().constData(), param.toByteArray().size());
}
return true;
}
}
-// =========================== SLOTS =================================
+
+
+// Opens torrent information from buffer data and adds torrent to session
+void MainWindow::StartTorrentFromBufferData(char const* data, int size)
+{
+ // For params, see: http://www.rasterbar.com/products/libtorrent/manual.html#add-torrent
+ /// @todo Should typedef libtorrent::torrent_info to something
+ AddTorrentParams addParams;
+ boost::intrusive_ptr<libtorrent::torrent_info> tiTmp =
+ new libtorrent::torrent_info(data, size);
+ addParams.ti = tiTmp;
+ // save_path is the only mandatory parameter, rest are optional.
+ addParams.save_path = boost::filesystem::path(settings_.value("download/directory").toString().toStdString());
+ //addParams.storage_mode = libtorrent::storage_mode_allocate;
+ qtrapids::QTorrentHandle handle = btSession_.addTorrent(addParams);
+ dlView_->newItem(handle);
+// torrentHandles_.push_back(handlePtr);
+#ifdef QTRAPIDS_DEBUG
+ qDebug() << "Is valid: " << handle.isValid();
+#endif
+}
+
+// =========================== PRIVATE SLOTS =================================
void MainWindow::on_openAction_clicked()
{
QFileDialog *dialog = new QFileDialog( this, "Open torrent file", QString(), tr("Torrent files (*.torrent)"));
btSession_.removeTorrent(handle);
}
+
void MainWindow::on_quitAction_clicked()
{
close();
}
+
void MainWindow::on_preferencesAction_clicked()
{
if (!preferencesDialog_) {
preferencesDialog_->activateWindow();
}
+
void MainWindow::on_aboutAction_clicked()
{
QMessageBox::about(this, tr("About QtRapids"), ABOUT_TEXT);
}
+void MainWindow::on_tabWidget_tabCloseRequested(int index)
+{
+
+ int searchWidgetIndex = tabWidget_->indexOf(searchWidget_);
+
+ // Allow closing other tabs than the first two
+ // TODO The first two may well be closable, just add "show tabs" action for these in the menu
+ if (index != 0 && index != 1 && index != searchWidgetIndex) {
+ QWidget *remove = tabWidget_->widget(index);
+ tabWidget_->removeTab(index);
+ delete remove;
+ remove = NULL;
+ }
+}
+
+
void MainWindow::on_downloadItemSelectionChanged()
{
#ifdef QTRAPIDS_DEBUG
}
}
+
void MainWindow::on_seedItemSelectionChanged()
{
#ifdef QTRAPIDS_DEBUG
}
}
+
void MainWindow::handleToolBarAction(QAction* action)
{
if (action->text() == "Open") {
}
}
+
void MainWindow::on_torrentFileSelected(const QString& file)
{
#ifdef QTRAPIDS_DEBUG
// Otherwise add torrent
// For params, see: http://www.rasterbar.com/products/libtorrent/manual.html#add-torrent
+ /// @todo Should typedef libtorrent::torrent_info to something
AddTorrentParams addParams;
boost::intrusive_ptr<libtorrent::torrent_info> tiTmp =
new libtorrent::torrent_info(boost::filesystem::path(file.toStdString()));
#endif
}
-
void MainWindow::on_alert(std::auto_ptr<Alert> al)
{
if (al.get() != NULL) {