2003-10-30 00:28:09 +01:00
|
|
|
/*
|
|
|
|
|
2016-01-18 00:57:46 +01:00
|
|
|
Copyright (c) 2003-2016, Arvid Norberg
|
2003-10-30 00:28:09 +01:00
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in
|
|
|
|
the documentation and/or other materials provided with the distribution.
|
|
|
|
* Neither the name of the author nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2015-04-21 03:16:28 +02:00
|
|
|
#include "libtorrent/aux_/disable_warnings_push.hpp"
|
2015-04-18 04:33:39 +02:00
|
|
|
|
2003-10-30 00:28:09 +01:00
|
|
|
#include <ctime>
|
|
|
|
#include <iterator>
|
|
|
|
#include <algorithm>
|
|
|
|
#include <set>
|
|
|
|
#include <cctype>
|
|
|
|
#include <algorithm>
|
|
|
|
|
2003-12-09 19:09:34 +01:00
|
|
|
#include <boost/optional.hpp>
|
2004-03-23 23:58:18 +01:00
|
|
|
#include <boost/bind.hpp>
|
2003-10-30 00:28:09 +01:00
|
|
|
|
2015-04-21 03:16:28 +02:00
|
|
|
#include "libtorrent/aux_/disable_warnings_pop.hpp"
|
2004-01-25 19:18:36 +01:00
|
|
|
|
2003-10-30 00:28:09 +01:00
|
|
|
#include "libtorrent/peer_id.hpp"
|
2006-04-25 23:04:48 +02:00
|
|
|
#include "libtorrent/bt_peer_connection.hpp"
|
2003-10-30 00:28:09 +01:00
|
|
|
#include "libtorrent/torrent_info.hpp"
|
2004-01-31 11:46:15 +01:00
|
|
|
#include "libtorrent/tracker_manager.hpp"
|
2003-10-30 00:28:09 +01:00
|
|
|
#include "libtorrent/bencode.hpp"
|
|
|
|
#include "libtorrent/hasher.hpp"
|
|
|
|
#include "libtorrent/entry.hpp"
|
|
|
|
#include "libtorrent/session.hpp"
|
2006-10-11 16:02:21 +02:00
|
|
|
#include "libtorrent/aux_/session_impl.hpp"
|
2014-08-26 06:51:09 +02:00
|
|
|
#include "libtorrent/aux_/session_call.hpp"
|
2004-02-29 17:39:52 +01:00
|
|
|
#include "libtorrent/invariant_check.hpp"
|
2008-11-30 09:12:26 +01:00
|
|
|
#include "libtorrent/utf8.hpp"
|
2010-07-14 06:16:38 +02:00
|
|
|
#include "libtorrent/thread.hpp"
|
2015-09-18 06:23:45 +02:00
|
|
|
#include "libtorrent/announce_entry.hpp"
|
2003-10-30 00:28:09 +01:00
|
|
|
|
2015-08-16 18:17:23 +02:00
|
|
|
#ifdef __GNUC__
|
|
|
|
#pragma GCC diagnostic push
|
|
|
|
#pragma GCC diagnostic ignored "-Wunused-macros"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __clang__
|
|
|
|
#pragma clang diagnostic push
|
|
|
|
#pragma clang diagnostic ignored "-Wunused-macros"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define TORRENT_ASYNC_CALL(x) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (!t) return; \
|
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session()); \
|
|
|
|
ses.get_io_service().dispatch(boost::bind(&torrent:: x, t))
|
|
|
|
|
|
|
|
#define TORRENT_ASYNC_CALL1(x, a1) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (!t) return; \
|
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session()); \
|
|
|
|
ses.get_io_service().dispatch(boost::bind(&torrent:: x, t, a1))
|
|
|
|
|
|
|
|
#define TORRENT_ASYNC_CALL2(x, a1, a2) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (!t) return; \
|
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session()); \
|
|
|
|
ses.get_io_service().dispatch(boost::bind(&torrent:: x, t, a1, a2))
|
|
|
|
|
|
|
|
#define TORRENT_ASYNC_CALL3(x, a1, a2, a3) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (!t) return; \
|
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session()); \
|
|
|
|
ses.get_io_service().dispatch(boost::bind(&torrent:: x, t, a1, a2, a3))
|
|
|
|
|
|
|
|
#define TORRENT_ASYNC_CALL4(x, a1, a2, a3, a4) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (!t) return; \
|
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session()); \
|
|
|
|
ses.get_io_service().dispatch(boost::bind(&torrent:: x, t, a1, a2, a3, a4))
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL(x) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (t) aux::sync_call_handle(t, boost::bind(&torrent:: x, t));
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL1(x, a1) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (t) aux::sync_call_handle(t, boost::bind(&torrent:: x, t, a1));
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL2(x, a1, a2) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (t) aux::sync_call_handle(t, boost::bind(&torrent:: x, t, a1, a2));
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL3(x, a1, a2, a3) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
if (t) aux::sync_call_handle(t, boost::bind(&torrent:: x, t, a1, a2, a3));
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL_RET(type, def, x) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
type r = def; \
|
|
|
|
if (t) aux::sync_call_ret_handle(t, r, boost::function<type(void)>(boost::bind(&torrent:: x, t)));
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL_RET1(type, def, x, a1) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
type r = def; \
|
|
|
|
if (t) aux::sync_call_ret_handle(t, r, boost::function<type(void)>(boost::bind(&torrent:: x, t, a1)));
|
|
|
|
|
|
|
|
#define TORRENT_SYNC_CALL_RET2(type, def, x, a1, a2) \
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock(); \
|
|
|
|
type r = def; \
|
|
|
|
if (t) aux::sync_call_ret_handle(t, r, boost::function<type(void)>(boost::bind(&torrent:: x, t, a1, a2)));
|
|
|
|
|
|
|
|
#ifdef __clang__
|
|
|
|
#pragma clang diagnostic pop
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __GNUC__
|
|
|
|
#pragma GCC diagnostic pop
|
2003-10-30 00:28:09 +01:00
|
|
|
#endif
|
|
|
|
|
2006-10-11 16:02:21 +02:00
|
|
|
using libtorrent::aux::session_impl;
|
2004-10-29 15:21:09 +02:00
|
|
|
|
2010-07-14 06:16:38 +02:00
|
|
|
namespace libtorrent
|
|
|
|
{
|
2007-11-25 19:48:43 +01:00
|
|
|
|
2012-03-19 07:06:52 +01:00
|
|
|
torrent_status::torrent_status()
|
2015-11-07 07:01:07 +01:00
|
|
|
: error_file(torrent_status::error_file_none)
|
|
|
|
, total_download(0)
|
2012-03-19 07:06:52 +01:00
|
|
|
, total_upload(0)
|
|
|
|
, total_payload_download(0)
|
|
|
|
, total_payload_upload(0)
|
|
|
|
, total_failed_bytes(0)
|
|
|
|
, total_redundant_bytes(0)
|
2013-11-26 05:39:33 +01:00
|
|
|
, total_done(0)
|
|
|
|
, total_wanted_done(0)
|
|
|
|
, total_wanted(0)
|
|
|
|
, all_time_upload(0)
|
|
|
|
, all_time_download(0)
|
|
|
|
, added_time(0)
|
|
|
|
, completed_time(0)
|
|
|
|
, last_seen_complete(0)
|
|
|
|
, storage_mode(storage_mode_sparse)
|
|
|
|
, progress(0.f)
|
|
|
|
, progress_ppm(0)
|
|
|
|
, queue_position(0)
|
2012-03-19 07:06:52 +01:00
|
|
|
, download_rate(0)
|
|
|
|
, upload_rate(0)
|
|
|
|
, download_payload_rate(0)
|
|
|
|
, upload_payload_rate(0)
|
|
|
|
, num_seeds(0)
|
|
|
|
, num_peers(0)
|
|
|
|
, num_complete(-1)
|
|
|
|
, num_incomplete(-1)
|
|
|
|
, list_seeds(0)
|
|
|
|
, list_peers(0)
|
|
|
|
, connect_candidates(0)
|
|
|
|
, num_pieces(0)
|
|
|
|
, distributed_full_copies(0)
|
|
|
|
, distributed_fraction(0)
|
|
|
|
, distributed_copies(0.f)
|
|
|
|
, block_size(0)
|
|
|
|
, num_uploads(0)
|
|
|
|
, num_connections(0)
|
|
|
|
, uploads_limit(0)
|
|
|
|
, connections_limit(0)
|
|
|
|
, up_bandwidth_queue(0)
|
|
|
|
, down_bandwidth_queue(0)
|
2013-11-26 05:39:33 +01:00
|
|
|
, time_since_upload(0)
|
|
|
|
, time_since_download(0)
|
2012-03-19 07:06:52 +01:00
|
|
|
, active_time(0)
|
|
|
|
, finished_time(0)
|
|
|
|
, seeding_time(0)
|
|
|
|
, seed_rank(0)
|
|
|
|
, last_scrape(0)
|
|
|
|
, priority(0)
|
2013-11-26 05:39:33 +01:00
|
|
|
, state(checking_resume_data)
|
2012-03-19 07:06:52 +01:00
|
|
|
, need_save_resume(false)
|
|
|
|
, ip_filter_applies(true)
|
2013-11-26 05:39:33 +01:00
|
|
|
, upload_mode(false)
|
|
|
|
, share_mode(false)
|
|
|
|
, super_seeding(false)
|
|
|
|
, paused(false)
|
|
|
|
, auto_managed(false)
|
|
|
|
, sequential_download(false)
|
|
|
|
, is_seeding(false)
|
|
|
|
, is_finished(false)
|
|
|
|
, has_metadata(false)
|
|
|
|
, has_incoming(false)
|
|
|
|
, seed_mode(false)
|
2014-01-01 03:04:26 +01:00
|
|
|
, moving_storage(false)
|
2014-07-06 21:18:00 +02:00
|
|
|
, is_loaded(true)
|
2012-03-19 07:06:52 +01:00
|
|
|
, info_hash(0)
|
|
|
|
{}
|
|
|
|
|
|
|
|
torrent_status::~torrent_status() {}
|
|
|
|
|
2007-11-25 19:48:43 +01:00
|
|
|
#ifndef BOOST_NO_EXCEPTIONS
|
2009-02-23 02:21:19 +01:00
|
|
|
void throw_invalid_handle()
|
|
|
|
{
|
2009-11-29 08:06:38 +01:00
|
|
|
throw libtorrent_exception(errors::invalid_torrent_handle);
|
2004-03-23 23:58:18 +01:00
|
|
|
}
|
2009-02-23 02:21:19 +01:00
|
|
|
#endif
|
2004-03-23 23:58:18 +01:00
|
|
|
|
2008-04-09 22:09:36 +02:00
|
|
|
sha1_hash torrent_handle::info_hash() const
|
|
|
|
{
|
2014-11-12 17:57:59 +01:00
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock();
|
2015-03-14 01:42:27 +01:00
|
|
|
static const sha1_hash empty;
|
2014-11-12 17:57:59 +01:00
|
|
|
if (!t) return empty;
|
|
|
|
return t->info_hash();
|
2008-04-09 22:09:36 +02:00
|
|
|
}
|
|
|
|
|
2009-04-07 17:55:05 +02:00
|
|
|
int torrent_handle::max_uploads() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(int, 0, max_uploads);
|
|
|
|
return r;
|
2009-04-07 17:55:05 +02:00
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::set_max_uploads(int max_uploads) const
|
2003-12-14 06:56:12 +01:00
|
|
|
{
|
2014-03-23 08:40:43 +01:00
|
|
|
TORRENT_ASSERT_PRECOND(max_uploads >= 2 || max_uploads == -1);
|
2012-08-31 19:04:02 +02:00
|
|
|
TORRENT_ASYNC_CALL2(set_max_uploads, max_uploads, true);
|
2003-12-14 06:56:12 +01:00
|
|
|
}
|
2004-01-21 01:59:38 +01:00
|
|
|
|
2008-11-08 08:40:55 +01:00
|
|
|
int torrent_handle::max_connections() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(int, 0, max_connections);
|
|
|
|
return r;
|
2008-11-08 08:40:55 +01:00
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::set_max_connections(int max_connections) const
|
2004-01-21 01:59:38 +01:00
|
|
|
{
|
2014-03-23 08:40:43 +01:00
|
|
|
TORRENT_ASSERT_PRECOND(max_connections >= 2 || max_connections == -1);
|
2012-08-31 19:04:02 +02:00
|
|
|
TORRENT_ASYNC_CALL2(set_max_connections, max_connections, true);
|
2004-01-21 01:59:38 +01:00
|
|
|
}
|
2003-10-30 00:28:09 +01:00
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::set_upload_limit(int limit) const
|
2003-11-28 18:29:27 +01:00
|
|
|
{
|
2014-03-23 08:40:43 +01:00
|
|
|
TORRENT_ASSERT_PRECOND(limit >= -1);
|
2014-07-06 21:18:00 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_upload_limit, limit);
|
2003-11-28 18:29:27 +01:00
|
|
|
}
|
|
|
|
|
2007-04-10 11:25:17 +02:00
|
|
|
int torrent_handle::upload_limit() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(int, 0, upload_limit);
|
|
|
|
return r;
|
2007-04-10 11:25:17 +02:00
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::set_download_limit(int limit) const
|
2004-07-01 20:51:13 +02:00
|
|
|
{
|
2014-03-23 08:40:43 +01:00
|
|
|
TORRENT_ASSERT_PRECOND(limit >= -1);
|
2014-07-06 21:18:00 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_download_limit, limit);
|
2004-07-01 20:51:13 +02:00
|
|
|
}
|
|
|
|
|
2007-04-10 11:25:17 +02:00
|
|
|
int torrent_handle::download_limit() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(int, 0, download_limit);
|
|
|
|
return r;
|
2007-04-10 11:25:17 +02:00
|
|
|
}
|
|
|
|
|
2007-06-10 22:46:09 +02:00
|
|
|
void torrent_handle::move_storage(
|
2013-05-09 04:50:16 +02:00
|
|
|
std::string const& save_path, int flags) const
|
2004-07-18 02:39:58 +02:00
|
|
|
{
|
2013-05-09 04:50:16 +02:00
|
|
|
TORRENT_ASYNC_CALL2(move_storage, save_path, flags);
|
2004-07-18 02:39:58 +02:00
|
|
|
}
|
|
|
|
|
2009-10-26 02:29:39 +01:00
|
|
|
#if TORRENT_USE_WSTRING
|
2013-08-02 07:03:22 +02:00
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
2008-11-30 09:12:26 +01:00
|
|
|
void torrent_handle::move_storage(
|
2013-05-09 04:50:16 +02:00
|
|
|
std::wstring const& save_path, int flags) const
|
2008-11-30 09:12:26 +01:00
|
|
|
{
|
|
|
|
std::string utf8;
|
2009-10-26 02:29:39 +01:00
|
|
|
wchar_utf8(save_path, utf8);
|
2013-05-09 04:50:16 +02:00
|
|
|
TORRENT_ASYNC_CALL2(move_storage, utf8, flags);
|
2008-11-30 09:12:26 +01:00
|
|
|
}
|
|
|
|
|
2009-10-26 02:29:39 +01:00
|
|
|
void torrent_handle::rename_file(int index, std::wstring const& new_name) const
|
2008-11-30 09:12:26 +01:00
|
|
|
{
|
|
|
|
std::string utf8;
|
2009-10-26 02:29:39 +01:00
|
|
|
wchar_utf8(new_name, utf8);
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(rename_file, index, utf8);
|
2008-11-30 09:12:26 +01:00
|
|
|
}
|
2013-08-02 07:03:22 +02:00
|
|
|
#endif // TORRENT_NO_DEPRECATE
|
2009-10-26 02:29:39 +01:00
|
|
|
#endif // TORRENT_USE_WSTRING
|
2009-03-31 10:12:35 +02:00
|
|
|
|
2009-10-26 02:29:39 +01:00
|
|
|
void torrent_handle::rename_file(int index, std::string const& new_name) const
|
2009-03-31 10:12:35 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(rename_file, index, new_name);
|
2009-03-31 10:12:35 +02:00
|
|
|
}
|
2008-11-30 09:12:26 +01:00
|
|
|
|
2007-11-08 02:45:35 +01:00
|
|
|
void torrent_handle::add_extension(
|
2015-07-25 18:39:25 +02:00
|
|
|
boost::function<boost::shared_ptr<torrent_plugin>(torrent_handle const&, void*)> const& ext
|
2007-11-08 02:45:35 +01:00
|
|
|
, void* userdata)
|
|
|
|
{
|
2013-04-09 04:38:11 +02:00
|
|
|
#ifndef TORRENT_DISABLE_EXTENSIONS
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(add_extension, ext, userdata);
|
2015-08-22 00:28:12 +02:00
|
|
|
#else
|
|
|
|
TORRENT_UNUSED(ext);
|
|
|
|
TORRENT_UNUSED(userdata);
|
2011-01-29 13:13:49 +01:00
|
|
|
#endif
|
2013-04-09 04:38:11 +02:00
|
|
|
}
|
2007-11-08 02:45:35 +01:00
|
|
|
|
2008-09-24 04:32:33 +02:00
|
|
|
bool torrent_handle::set_metadata(char const* metadata, int size) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET2(bool, false, set_metadata, metadata, size);
|
|
|
|
return r;
|
2008-09-24 04:32:33 +02:00
|
|
|
}
|
|
|
|
|
2010-10-30 10:36:18 +02:00
|
|
|
void torrent_handle::pause(int flags) const
|
2004-03-21 03:03:37 +01:00
|
|
|
{
|
2010-10-30 10:36:18 +02:00
|
|
|
TORRENT_ASYNC_CALL1(pause, bool(flags & graceful_pause));
|
2004-03-21 03:03:37 +01:00
|
|
|
}
|
|
|
|
|
2015-10-04 00:15:29 +02:00
|
|
|
void torrent_handle::stop_when_ready(bool b) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(stop_when_ready, b);
|
|
|
|
}
|
|
|
|
|
2011-02-27 18:26:57 +01:00
|
|
|
void torrent_handle::apply_ip_filter(bool b) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(set_apply_ip_filter, b);
|
|
|
|
}
|
|
|
|
|
2010-09-05 18:01:36 +02:00
|
|
|
void torrent_handle::set_share_mode(bool b) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(set_share_mode, b);
|
|
|
|
}
|
|
|
|
|
2009-06-19 00:32:55 +02:00
|
|
|
void torrent_handle::set_upload_mode(bool b) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_upload_mode, b);
|
2009-06-19 00:32:55 +02:00
|
|
|
}
|
|
|
|
|
2010-01-09 22:17:52 +01:00
|
|
|
void torrent_handle::flush_cache() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL(flush_cache);
|
2010-01-09 22:17:52 +01:00
|
|
|
}
|
|
|
|
|
2011-09-12 05:51:49 +02:00
|
|
|
void torrent_handle::set_ssl_certificate(
|
|
|
|
std::string const& certificate
|
|
|
|
, std::string const& private_key
|
|
|
|
, std::string const& dh_params
|
|
|
|
, std::string const& passphrase)
|
2011-09-10 07:52:07 +02:00
|
|
|
{
|
|
|
|
#ifdef TORRENT_USE_OPENSSL
|
2011-09-12 05:51:49 +02:00
|
|
|
TORRENT_ASYNC_CALL4(set_ssl_cert, certificate, private_key, dh_params, passphrase);
|
2015-04-20 06:52:49 +02:00
|
|
|
#else
|
|
|
|
TORRENT_UNUSED(certificate);
|
|
|
|
TORRENT_UNUSED(private_key);
|
|
|
|
TORRENT_UNUSED(dh_params);
|
|
|
|
TORRENT_UNUSED(passphrase);
|
2011-09-10 07:52:07 +02:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2014-05-10 23:53:50 +02:00
|
|
|
void torrent_handle::set_ssl_certificate_buffer(
|
|
|
|
std::string const& certificate
|
|
|
|
, std::string const& private_key
|
|
|
|
, std::string const& dh_params)
|
|
|
|
{
|
|
|
|
#ifdef TORRENT_USE_OPENSSL
|
|
|
|
TORRENT_ASYNC_CALL3(set_ssl_cert_buffer, certificate, private_key, dh_params);
|
2015-04-20 06:52:49 +02:00
|
|
|
#else
|
|
|
|
TORRENT_UNUSED(certificate);
|
|
|
|
TORRENT_UNUSED(private_key);
|
|
|
|
TORRENT_UNUSED(dh_params);
|
2014-05-10 23:53:50 +02:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2010-10-29 04:42:41 +02:00
|
|
|
void torrent_handle::save_resume_data(int f) const
|
2008-04-13 20:54:36 +02:00
|
|
|
{
|
2010-10-29 04:42:41 +02:00
|
|
|
TORRENT_ASYNC_CALL1(save_resume_data, f);
|
2008-04-13 20:54:36 +02:00
|
|
|
}
|
|
|
|
|
2010-04-12 02:36:31 +02:00
|
|
|
bool torrent_handle::need_save_resume_data() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, need_save_resume_data);
|
|
|
|
return r;
|
2010-04-12 02:36:31 +02:00
|
|
|
}
|
|
|
|
|
2008-06-07 18:24:56 +02:00
|
|
|
void torrent_handle::force_recheck() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL(force_recheck);
|
2008-06-07 18:24:56 +02:00
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::resume() const
|
2004-03-21 03:03:37 +01:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL(resume);
|
2004-03-23 23:58:18 +01:00
|
|
|
}
|
2004-03-21 03:03:37 +01:00
|
|
|
|
2008-04-24 05:28:48 +02:00
|
|
|
void torrent_handle::auto_managed(bool m) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(auto_managed, m);
|
2008-04-24 05:28:48 +02:00
|
|
|
}
|
|
|
|
|
2009-09-13 04:24:25 +02:00
|
|
|
void torrent_handle::set_priority(int p) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_priority, p);
|
2009-09-13 04:24:25 +02:00
|
|
|
}
|
|
|
|
|
2008-05-29 05:37:19 +02:00
|
|
|
int torrent_handle::queue_position() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(int, -1, queue_position);
|
|
|
|
return r;
|
2008-05-29 05:37:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::queue_position_up() const
|
|
|
|
{
|
2012-05-23 17:18:30 +02:00
|
|
|
TORRENT_ASYNC_CALL(queue_up);
|
2008-05-29 05:37:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::queue_position_down() const
|
|
|
|
{
|
2012-05-23 17:18:30 +02:00
|
|
|
TORRENT_ASYNC_CALL(queue_down);
|
2008-05-29 05:37:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::queue_position_top() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_queue_position, 0);
|
2008-05-29 05:37:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::queue_position_bottom() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_queue_position, INT_MAX);
|
2008-05-29 05:37:19 +02:00
|
|
|
}
|
|
|
|
|
2008-07-12 19:00:52 +02:00
|
|
|
void torrent_handle::clear_error() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL(clear_error);
|
2008-07-12 19:00:52 +02:00
|
|
|
}
|
|
|
|
|
2015-12-13 21:14:19 +01:00
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::set_tracker_login(std::string const& name
|
|
|
|
, std::string const& password) const
|
2004-03-23 23:58:18 +01:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(set_tracker_login, name, password);
|
2004-03-21 03:03:37 +01:00
|
|
|
}
|
2015-12-13 21:14:19 +01:00
|
|
|
#endif
|
2004-03-21 03:03:37 +01:00
|
|
|
|
2014-12-03 05:32:50 +01:00
|
|
|
void torrent_handle::file_progress(std::vector<boost::int64_t>& progress, int flags) const
|
2006-06-12 01:24:36 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL2(file_progress, boost::ref(progress), flags);
|
2006-06-12 01:24:36 +02:00
|
|
|
}
|
2004-03-23 23:58:18 +01:00
|
|
|
|
2010-03-04 20:24:39 +01:00
|
|
|
torrent_status torrent_handle::status(boost::uint32_t flags) const
|
2004-02-22 23:40:45 +01:00
|
|
|
{
|
2011-02-01 10:48:28 +01:00
|
|
|
torrent_status st;
|
|
|
|
TORRENT_SYNC_CALL2(status, &st, flags);
|
|
|
|
return st;
|
2004-02-22 23:40:45 +01:00
|
|
|
}
|
|
|
|
|
2014-07-06 21:18:00 +02:00
|
|
|
void torrent_handle::set_pinned(bool p) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(set_pinned, p);
|
|
|
|
}
|
|
|
|
|
2008-01-31 18:52:29 +01:00
|
|
|
void torrent_handle::set_sequential_download(bool sd) const
|
2006-09-04 19:17:45 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(set_sequential_download, sd);
|
2006-09-04 19:17:45 +02:00
|
|
|
}
|
|
|
|
|
2007-05-30 08:52:59 +02:00
|
|
|
void torrent_handle::piece_availability(std::vector<int>& avail) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL1(piece_availability, boost::ref(avail));
|
2007-05-30 08:52:59 +02:00
|
|
|
}
|
|
|
|
|
2007-03-20 02:59:00 +01:00
|
|
|
void torrent_handle::piece_priority(int index, int priority) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(set_piece_priority, index, priority);
|
2007-03-20 02:59:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int torrent_handle::piece_priority(int index) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET1(int, 0, piece_priority, index);
|
|
|
|
return r;
|
2007-03-20 02:59:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::prioritize_pieces(std::vector<int> const& pieces) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(prioritize_pieces, pieces);
|
2007-03-20 02:59:00 +01:00
|
|
|
}
|
|
|
|
|
2014-07-06 21:18:00 +02:00
|
|
|
void torrent_handle::prioritize_pieces(std::vector<std::pair<int, int> > const& pieces) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(prioritize_piece_list, pieces);
|
|
|
|
}
|
|
|
|
|
2007-03-20 02:59:00 +01:00
|
|
|
std::vector<int> torrent_handle::piece_priorities() const
|
|
|
|
{
|
|
|
|
std::vector<int> ret;
|
2011-05-01 19:43:15 +02:00
|
|
|
TORRENT_SYNC_CALL1(piece_priorities, &ret);
|
2007-03-20 02:59:00 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2008-07-20 18:00:08 +02:00
|
|
|
void torrent_handle::file_priority(int index, int priority) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(set_file_priority, index, priority);
|
2008-07-20 18:00:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
int torrent_handle::file_priority(int index) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET1(int, 0, file_priority, index);
|
|
|
|
return r;
|
2008-07-20 18:00:08 +02:00
|
|
|
}
|
|
|
|
|
2007-03-20 02:59:00 +01:00
|
|
|
void torrent_handle::prioritize_files(std::vector<int> const& files) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(prioritize_files, files);
|
2007-03-20 02:59:00 +01:00
|
|
|
}
|
|
|
|
|
2008-07-20 18:00:08 +02:00
|
|
|
std::vector<int> torrent_handle::file_priorities() const
|
|
|
|
{
|
|
|
|
std::vector<int> ret;
|
2011-05-01 19:43:15 +02:00
|
|
|
TORRENT_SYNC_CALL1(file_priorities, &ret);
|
2008-07-20 18:00:08 +02:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2014-07-06 21:18:00 +02:00
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
|
|
|
// ============ start deprecation ===============
|
|
|
|
|
2015-04-20 06:52:49 +02:00
|
|
|
int torrent_handle::get_peer_upload_limit(tcp::endpoint) const { return -1; }
|
|
|
|
int torrent_handle::get_peer_download_limit(tcp::endpoint) const { return -1; }
|
|
|
|
void torrent_handle::set_peer_upload_limit(tcp::endpoint, int /* limit */) const {}
|
|
|
|
void torrent_handle::set_peer_download_limit(tcp::endpoint, int /* limit */) const {}
|
|
|
|
void torrent_handle::set_ratio(float) const {}
|
2012-11-02 17:48:18 +01:00
|
|
|
void torrent_handle::use_interface(const char* net_interface) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(use_interface, std::string(net_interface));
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !TORRENT_NO_FPU
|
|
|
|
void torrent_handle::file_progress(std::vector<float>& progress) const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL1(file_progress, boost::ref(progress));
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-10-30 19:23:30 +02:00
|
|
|
bool torrent_handle::is_seed() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, is_seed);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool torrent_handle::is_finished() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, is_finished);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool torrent_handle::is_paused() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, is_torrent_paused);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool torrent_handle::is_sequential_download() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, is_sequential_download);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool torrent_handle::is_auto_managed() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, is_auto_managed);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool torrent_handle::has_metadata() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, valid_metadata);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::filter_piece(int index, bool filter) const
|
2005-05-25 12:01:01 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(filter_piece, index, filter);
|
2005-05-25 12:01:01 +02:00
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::filter_pieces(std::vector<bool> const& pieces) const
|
2005-06-23 01:04:37 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(filter_pieces, pieces);
|
2005-06-23 01:04:37 +02:00
|
|
|
}
|
|
|
|
|
2005-05-25 12:01:01 +02:00
|
|
|
bool torrent_handle::is_piece_filtered(int index) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET1(bool, false, is_piece_filtered, index);
|
|
|
|
return r;
|
2005-05-25 12:01:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<bool> torrent_handle::filtered_pieces() const
|
|
|
|
{
|
|
|
|
std::vector<bool> ret;
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL1(filtered_pieces, ret);
|
2005-05-25 12:01:01 +02:00
|
|
|
return ret;
|
|
|
|
}
|
2005-07-02 10:47:46 +02:00
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::filter_files(std::vector<bool> const& files) const
|
2005-07-04 01:33:47 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(filter_files, files);
|
2005-07-04 01:33:47 +02:00
|
|
|
}
|
|
|
|
|
2012-03-01 10:01:48 +01:00
|
|
|
bool torrent_handle::super_seeding() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, super_seeding);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2007-03-20 02:59:00 +01:00
|
|
|
// ============ end deprecation ===============
|
2008-08-03 17:14:08 +02:00
|
|
|
#endif
|
2007-03-20 02:59:00 +01:00
|
|
|
|
2008-11-29 09:38:40 +01:00
|
|
|
std::vector<announce_entry> torrent_handle::trackers() const
|
2004-09-12 12:12:16 +02:00
|
|
|
{
|
2015-03-14 01:42:27 +01:00
|
|
|
static const std::vector<announce_entry> empty;
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(std::vector<announce_entry>, empty, trackers);
|
|
|
|
return r;
|
2004-09-12 12:12:16 +02:00
|
|
|
}
|
|
|
|
|
2007-08-17 18:40:55 +02:00
|
|
|
void torrent_handle::add_url_seed(std::string const& url) const
|
2006-04-25 23:04:48 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(add_web_seed, url, web_seed_entry::url_seed);
|
2006-04-25 23:04:48 +02:00
|
|
|
}
|
|
|
|
|
2007-08-17 18:40:55 +02:00
|
|
|
void torrent_handle::remove_url_seed(std::string const& url) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(remove_web_seed, url, web_seed_entry::url_seed);
|
2007-08-17 18:40:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
std::set<std::string> torrent_handle::url_seeds() const
|
|
|
|
{
|
2015-03-14 01:42:27 +01:00
|
|
|
static const std::set<std::string> empty;
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET1(std::set<std::string>, empty, web_seeds, web_seed_entry::url_seed);
|
|
|
|
return r;
|
2008-12-30 04:54:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::add_http_seed(std::string const& url) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(add_web_seed, url, web_seed_entry::http_seed);
|
2008-12-30 04:54:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void torrent_handle::remove_http_seed(std::string const& url) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL2(remove_web_seed, url, web_seed_entry::http_seed);
|
2008-12-30 04:54:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
std::set<std::string> torrent_handle::http_seeds() const
|
|
|
|
{
|
2015-03-14 01:42:27 +01:00
|
|
|
static const std::set<std::string> empty;
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET1(std::set<std::string>, empty, web_seeds, web_seed_entry::http_seed);
|
|
|
|
return r;
|
2007-08-17 18:40:55 +02:00
|
|
|
}
|
|
|
|
|
2005-10-19 15:58:41 +02:00
|
|
|
void torrent_handle::replace_trackers(
|
|
|
|
std::vector<announce_entry> const& urls) const
|
2004-09-12 12:12:16 +02:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(replace_trackers, urls);
|
2004-09-12 12:12:16 +02:00
|
|
|
}
|
|
|
|
|
2008-11-26 02:42:14 +01:00
|
|
|
void torrent_handle::add_tracker(announce_entry const& url) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(add_tracker, url);
|
2008-11-26 02:42:14 +01:00
|
|
|
}
|
|
|
|
|
2008-12-07 22:04:19 +01:00
|
|
|
void torrent_handle::add_piece(int piece, char const* data, int flags) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL3(add_piece, piece, data, flags);
|
2008-12-07 22:04:19 +01:00
|
|
|
}
|
|
|
|
|
2008-12-14 20:47:02 +01:00
|
|
|
void torrent_handle::read_piece(int piece) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(read_piece, piece);
|
2008-12-14 20:47:02 +01:00
|
|
|
}
|
|
|
|
|
2011-11-27 01:01:13 +01:00
|
|
|
bool torrent_handle::have_piece(int piece) const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET1(bool, false, have_piece, piece);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2008-09-04 18:20:19 +02:00
|
|
|
storage_interface* torrent_handle::get_storage_impl() const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(storage_interface*, 0, get_storage);
|
|
|
|
return r;
|
2008-09-04 18:20:19 +02:00
|
|
|
}
|
|
|
|
|
2012-10-02 18:07:55 +02:00
|
|
|
bool torrent_handle::is_valid() const
|
|
|
|
{
|
|
|
|
return !m_torrent.expired();
|
|
|
|
}
|
|
|
|
|
2014-07-06 21:18:00 +02:00
|
|
|
boost::shared_ptr<const torrent_info> torrent_handle::torrent_file() const
|
2012-10-02 18:07:55 +02:00
|
|
|
{
|
2014-07-06 21:18:00 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(boost::shared_ptr<const torrent_info>
|
|
|
|
, boost::shared_ptr<const torrent_info>(), get_torrent_copy);
|
2012-10-02 18:07:55 +02:00
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
|
|
|
// this function should either be removed, or return
|
|
|
|
// reference counted handle to the torrent_info which
|
|
|
|
// forces the torrent to stay loaded while the client holds it
|
2006-11-14 01:08:16 +01:00
|
|
|
torrent_info const& torrent_handle::get_torrent_info() const
|
2004-03-23 23:58:18 +01:00
|
|
|
{
|
2014-07-06 21:18:00 +02:00
|
|
|
static boost::shared_ptr<const torrent_info> holder[4];
|
|
|
|
static int cursor = 0;
|
|
|
|
static mutex holder_mutex;
|
|
|
|
|
|
|
|
boost::shared_ptr<const torrent_info> r = torrent_file();
|
|
|
|
|
|
|
|
mutex::scoped_lock l(holder_mutex);
|
|
|
|
holder[cursor++] = r;
|
|
|
|
cursor = cursor % (sizeof(holder) / sizeof(holder[0]));
|
|
|
|
return *r;
|
2004-03-23 23:58:18 +01:00
|
|
|
}
|
|
|
|
|
2004-02-25 00:55:42 +01:00
|
|
|
entry torrent_handle::write_resume_data() const
|
2004-01-02 21:46:24 +01:00
|
|
|
{
|
2004-01-07 01:48:02 +01:00
|
|
|
entry ret(entry::dictionary_t);
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL1(write_resume_data, boost::ref(ret));
|
2010-07-24 19:10:45 +02:00
|
|
|
t = m_torrent.lock();
|
2010-07-14 06:16:38 +02:00
|
|
|
if (t)
|
|
|
|
{
|
|
|
|
bool done = false;
|
2015-08-02 01:55:28 +02:00
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session());
|
2014-07-06 21:18:00 +02:00
|
|
|
storage_error ec;
|
2015-06-03 06:33:20 +02:00
|
|
|
ses.get_io_service().dispatch(boost::bind(&aux::fun_wrap, boost::ref(done), boost::ref(ses.cond)
|
2014-08-26 06:51:09 +02:00
|
|
|
, boost::ref(ses.mut), boost::function<void(void)>(boost::bind(
|
2014-07-06 21:18:00 +02:00
|
|
|
&piece_manager::write_resume_data, &t->storage(), boost::ref(ret), boost::ref(ec)))));
|
2010-07-24 19:10:45 +02:00
|
|
|
t.reset();
|
2014-08-26 06:51:09 +02:00
|
|
|
aux::torrent_wait(done, ses);
|
2010-07-14 06:16:38 +02:00
|
|
|
}
|
2004-01-12 04:05:10 +01:00
|
|
|
|
2004-01-07 01:48:02 +01:00
|
|
|
return ret;
|
2004-01-02 21:46:24 +01:00
|
|
|
}
|
|
|
|
|
2009-10-26 02:29:39 +01:00
|
|
|
std::string torrent_handle::save_path() const
|
2003-12-07 06:53:04 +01:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(std::string, "", save_path);
|
|
|
|
return r;
|
2003-12-07 06:53:04 +01:00
|
|
|
}
|
|
|
|
|
2013-03-03 00:17:48 +01:00
|
|
|
std::string torrent_handle::name() const
|
|
|
|
{
|
|
|
|
TORRENT_SYNC_CALL_RET(std::string, "", name);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2014-07-06 21:18:00 +02:00
|
|
|
void torrent_handle::connect_peer(tcp::endpoint const& adr, int source, int flags) const
|
2004-01-08 18:03:04 +01:00
|
|
|
{
|
2014-07-06 21:18:00 +02:00
|
|
|
TORRENT_ASYNC_CALL3(add_peer, adr, source, flags);
|
2004-01-08 18:03:04 +01:00
|
|
|
}
|
|
|
|
|
2014-01-02 03:16:31 +01:00
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
2005-05-03 15:13:57 +02:00
|
|
|
void torrent_handle::force_reannounce(
|
2007-04-07 05:05:59 +02:00
|
|
|
boost::posix_time::time_duration duration) const
|
2005-05-03 15:13:57 +02:00
|
|
|
{
|
2015-03-12 05:34:54 +01:00
|
|
|
TORRENT_ASYNC_CALL2(force_tracker_request, aux::time_now()
|
2014-01-02 03:16:31 +01:00
|
|
|
+ seconds(duration.total_seconds()), -1);
|
2005-05-03 15:13:57 +02:00
|
|
|
}
|
2014-01-02 03:16:31 +01:00
|
|
|
#endif
|
2005-05-03 15:13:57 +02:00
|
|
|
|
2009-10-25 03:37:45 +01:00
|
|
|
void torrent_handle::force_dht_announce() const
|
|
|
|
{
|
2013-04-09 03:04:43 +02:00
|
|
|
#ifndef TORRENT_DISABLE_DHT
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL(dht_announce);
|
2009-10-25 03:37:45 +01:00
|
|
|
#endif
|
2013-04-09 03:04:43 +02:00
|
|
|
}
|
2009-10-25 03:37:45 +01:00
|
|
|
|
2014-01-02 03:16:31 +01:00
|
|
|
void torrent_handle::force_reannounce(int s, int idx) const
|
2004-01-08 18:03:04 +01:00
|
|
|
{
|
2015-03-12 05:34:54 +01:00
|
|
|
TORRENT_ASYNC_CALL2(force_tracker_request, aux::time_now() + seconds(s), idx);
|
2004-01-08 18:03:04 +01:00
|
|
|
}
|
|
|
|
|
2014-07-06 21:18:00 +02:00
|
|
|
void torrent_handle::file_status(std::vector<pool_file_status>& status) const
|
|
|
|
{
|
|
|
|
status.clear();
|
|
|
|
|
|
|
|
boost::shared_ptr<torrent> t = m_torrent.lock();
|
|
|
|
if (!t || !t->has_storage()) return;
|
2015-08-02 01:55:28 +02:00
|
|
|
session_impl& ses = static_cast<session_impl&>(t->session());
|
2015-06-03 06:33:20 +02:00
|
|
|
ses.disk_thread().files().get_status(&status, &t->storage());
|
2014-07-06 21:18:00 +02:00
|
|
|
}
|
|
|
|
|
2016-01-25 06:51:20 +01:00
|
|
|
void torrent_handle::scrape_tracker(int idx) const
|
2007-11-20 23:46:27 +01:00
|
|
|
{
|
2016-01-25 06:51:20 +01:00
|
|
|
TORRENT_ASYNC_CALL2(scrape_tracker, idx, true);
|
2007-11-20 23:46:27 +01:00
|
|
|
}
|
|
|
|
|
2008-12-08 07:36:22 +01:00
|
|
|
void torrent_handle::super_seeding(bool on) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(super_seeding, on);
|
2008-12-08 07:36:22 +01:00
|
|
|
}
|
|
|
|
|
2015-12-15 00:31:49 +01:00
|
|
|
#ifndef TORRENT_NO_DEPRECATE
|
2007-01-29 08:39:33 +01:00
|
|
|
void torrent_handle::resolve_countries(bool r)
|
|
|
|
{
|
2013-04-09 02:37:53 +02:00
|
|
|
#ifndef TORRENT_DISABLE_RESOLVE_COUNTRIES
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL1(resolve_countries, r);
|
2013-04-09 02:37:53 +02:00
|
|
|
#endif
|
2007-01-29 08:39:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool torrent_handle::resolve_countries() const
|
|
|
|
{
|
2013-04-09 02:37:53 +02:00
|
|
|
#ifndef TORRENT_DISABLE_RESOLVE_COUNTRIES
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL_RET(bool, false, resolving_countries);
|
|
|
|
return r;
|
2013-04-09 02:37:53 +02:00
|
|
|
#else
|
|
|
|
return false;
|
2007-05-02 21:47:38 +02:00
|
|
|
#endif
|
2013-04-09 02:37:53 +02:00
|
|
|
}
|
2015-12-15 00:31:49 +01:00
|
|
|
#endif // TORRENT_NO_DEPRECATE
|
2007-01-29 08:39:33 +01:00
|
|
|
|
2008-04-13 08:32:48 +02:00
|
|
|
void torrent_handle::get_full_peer_list(std::vector<peer_list_entry>& v) const
|
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL1(get_full_peer_list, boost::ref(v));
|
2008-04-13 08:32:48 +02:00
|
|
|
}
|
|
|
|
|
2003-12-07 06:53:04 +01:00
|
|
|
void torrent_handle::get_peer_info(std::vector<peer_info>& v) const
|
2003-10-30 00:28:09 +01:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_SYNC_CALL1(get_peer_info, boost::ref(v));
|
2003-10-30 00:28:09 +01:00
|
|
|
}
|
2005-03-22 18:50:05 +01:00
|
|
|
|
2003-12-07 06:53:04 +01:00
|
|
|
void torrent_handle::get_download_queue(std::vector<partial_piece_info>& queue) const
|
2003-10-30 00:28:09 +01:00
|
|
|
{
|
2011-11-20 21:49:18 +01:00
|
|
|
TORRENT_SYNC_CALL1(get_download_queue, &queue);
|
2003-11-02 22:06:50 +01:00
|
|
|
}
|
|
|
|
|
2009-12-05 08:24:22 +01:00
|
|
|
void torrent_handle::set_piece_deadline(int index, int deadline, int flags) const
|
2009-03-17 10:34:44 +01:00
|
|
|
{
|
2010-07-14 06:16:38 +02:00
|
|
|
TORRENT_ASYNC_CALL3(set_piece_deadline, index, deadline, flags);
|
2009-03-17 10:34:44 +01:00
|
|
|
}
|
|
|
|
|
2011-08-05 08:31:46 +02:00
|
|
|
void torrent_handle::reset_piece_deadline(int index) const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL1(reset_piece_deadline, index);
|
|
|
|
}
|
|
|
|
|
2014-05-23 04:23:11 +02:00
|
|
|
void torrent_handle::clear_piece_deadlines() const
|
|
|
|
{
|
|
|
|
TORRENT_ASYNC_CALL(clear_time_critical);
|
|
|
|
}
|
|
|
|
|
2012-08-30 03:54:35 +02:00
|
|
|
boost::shared_ptr<torrent> torrent_handle::native_handle() const
|
|
|
|
{
|
|
|
|
return m_torrent.lock();
|
|
|
|
}
|
|
|
|
|
2011-12-23 06:36:13 +01:00
|
|
|
std::size_t hash_value(torrent_status const& ts)
|
|
|
|
{
|
|
|
|
return hash_value(ts.handle);
|
|
|
|
}
|
|
|
|
|
|
|
|
std::size_t hash_value(torrent_handle const& th)
|
|
|
|
{
|
2012-11-10 20:50:10 +01:00
|
|
|
// using the locked shared_ptr value as hash doesn't work
|
|
|
|
// for expired weak_ptrs. So, we're left with a hack
|
|
|
|
return std::size_t(*reinterpret_cast<void* const*>(&th.m_torrent));
|
2011-12-23 06:36:13 +01:00
|
|
|
}
|
2012-08-30 03:54:35 +02:00
|
|
|
|
2003-10-30 00:28:09 +01:00
|
|
|
}
|
2005-10-19 15:58:41 +02:00
|
|
|
|