1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-09 14:27:56 +00:00

- Fixed torrent creation from a folder

- Fixed start seeding directly after torrent creation
This commit is contained in:
Christophe Dumez 2007-12-30 18:06:51 +00:00
parent 00b3677867
commit 1e1313dffc
2 changed files with 14 additions and 4 deletions

View File

@ -767,7 +767,7 @@ void bittorrent::loadFilesPriorities(QTorrentHandle &h) {
if( priority < 0 || priority > 7) { if( priority < 0 || priority > 7) {
priority = 1; priority = 1;
} }
//qDebug("Setting piece piority to %d", priority); qDebug("Setting piece piority to %d", priority);
v.push_back(priority); v.push_back(priority);
} }
h.prioritize_files(v); h.prioritize_files(v);

View File

@ -36,6 +36,7 @@
#include <libtorrent/file_pool.hpp> #include <libtorrent/file_pool.hpp>
#include "createtorrent_imp.h" #include "createtorrent_imp.h"
#include "misc.h"
using namespace libtorrent; using namespace libtorrent;
using namespace boost::filesystem; using namespace boost::filesystem;
@ -120,11 +121,13 @@ void createtorrent::on_addURLSeed_button_clicked(){
// Subfunction to add files to a torrent_info structure // Subfunction to add files to a torrent_info structure
// Written by Arvid Norberg (libtorrent Author) // Written by Arvid Norberg (libtorrent Author)
void add_files(torrent_info& t, path const& p, path const& l){ void add_files(torrent_info& t, path const& p, path const& l){
qDebug("p: %s, l: %s, l.leaf(): %s", p.string().c_str(), l.string().c_str(), l.leaf().c_str());
path f(p / l); path f(p / l);
if (is_directory(f)){ if (is_directory(f)){
for (directory_iterator i(f), end; i != end; ++i) for (directory_iterator i(f), end; i != end; ++i)
add_files(t, p, l / i->leaf()); add_files(t, p, l / i->leaf());
}else{ }else{
qDebug("Adding %s", l.string().c_str());
t.add_file(l, file_size(f)); t.add_file(l, file_size(f));
} }
} }
@ -141,6 +144,8 @@ QStringList createtorrent::allItems(QListWidget *list){
// Main function that create a .torrent file // Main function that create a .torrent file
void createtorrent::on_createButton_clicked(){ void createtorrent::on_createButton_clicked(){
QString input = textInputPath->text().trimmed(); QString input = textInputPath->text().trimmed();
if (input.endsWith(QDir::separator()))
input.chop(1);
if(input.isEmpty()){ if(input.isEmpty()){
QMessageBox::critical(0, tr("No input path set"), tr("Please type an input path first")); QMessageBox::critical(0, tr("No input path set"), tr("Please type an input path first"));
return; return;
@ -161,9 +166,8 @@ void createtorrent::on_createButton_clicked(){
try { try {
boost::intrusive_ptr<torrent_info> t(new torrent_info); boost::intrusive_ptr<torrent_info> t(new torrent_info);
ofstream out(complete(path((const char*)destination.toUtf8())), std::ios_base::binary); ofstream out(complete(path((const char*)destination.toUtf8())), std::ios_base::binary);
path full_path;
// Adding files to the torrent // Adding files to the torrent
full_path = complete(path(input.toUtf8().data())); path full_path = complete(path(input.toUtf8().data()));
add_files(*t, full_path.branch_path(), full_path.leaf()); add_files(*t, full_path.branch_path(), full_path.leaf());
// Set piece size // Set piece size
int piece_size = getPieceSize(); int piece_size = getPieceSize();
@ -200,8 +204,14 @@ void createtorrent::on_createButton_clicked(){
entry e = t->create_torrent(); entry e = t->create_torrent();
libtorrent::bencode(std::ostream_iterator<char>(out), e); libtorrent::bencode(std::ostream_iterator<char>(out), e);
out.flush(); out.flush();
if(checkStartSeeding->isChecked()) if(checkStartSeeding->isChecked()) {
// Create save path file
QFile savepath_file(misc::qBittorrentPath()+QString::fromUtf8("BT_backup")+QDir::separator()+misc::toQString(t->info_hash())+QString::fromUtf8(".savepath"));
savepath_file.open(QIODevice::WriteOnly | QIODevice::Text);
savepath_file.write(full_path.branch_path().string().c_str());
savepath_file.close();
emit torrent_to_seed(destination); emit torrent_to_seed(destination);
}
} }
catch (std::exception& e){ catch (std::exception& e){
std::cerr << e.what() << "\n"; std::cerr << e.what() << "\n";