forked from premiere/premiere-libtorrent
*** empty log message ***
This commit is contained in:
parent
d2566ed20a
commit
1e574575b4
|
@ -135,13 +135,13 @@ boost.filesystem, boost.date_time and various other boost libraries as well as z
|
||||||
<li>Windows 2000 vc7.1</li>
|
<li>Windows 2000 vc7.1</li>
|
||||||
<li>Linux x86 (debian) GCC 3.0.4, GCC 3.2.3</li>
|
<li>Linux x86 (debian) GCC 3.0.4, GCC 3.2.3</li>
|
||||||
<li>Windows 2000, msvc6 sp5 (does not support 64-bit values due to problems with operator<<(ostream&, __int64))</li>
|
<li>Windows 2000, msvc6 sp5 (does not support 64-bit values due to problems with operator<<(ostream&, __int64))</li>
|
||||||
<li>Cygwin GCC 3.3.1</li>
|
|
||||||
</ul>
|
</ul>
|
||||||
</blockquote>
|
</blockquote>
|
||||||
<p>Fails on:</p>
|
<p>Fails on:</p>
|
||||||
<blockquote>
|
<blockquote>
|
||||||
<ul class="simple">
|
<ul class="simple">
|
||||||
<li>GCC 2.95.4 (<tt class="literal"><span class="pre">std::ios_base</span></tt> is missing)</li>
|
<li>GCC 2.95.4 (<tt class="literal"><span class="pre">std::ios_base</span></tt> is missing)</li>
|
||||||
|
<li>Cygwin GCC 3.3.1 (builds but crashes)</li>
|
||||||
</ul>
|
</ul>
|
||||||
</blockquote>
|
</blockquote>
|
||||||
<p>libtorrent is released under the <a class="reference" href="http://www.opensource.org/licenses/bsd-license.php">BSD-license</a>.</p>
|
<p>libtorrent is released under the <a class="reference" href="http://www.opensource.org/licenses/bsd-license.php">BSD-license</a>.</p>
|
||||||
|
@ -166,10 +166,7 @@ bjam <toolset>
|
||||||
"force conformance in for loop scope" and "treat wchar_t as built-in type" to Yes.</p>
|
"force conformance in for loop scope" and "treat wchar_t as built-in type" to Yes.</p>
|
||||||
<p>If you're building in developer studio 6, you will probably have to use the previous
|
<p>If you're building in developer studio 6, you will probably have to use the previous
|
||||||
version of boost, <a class="reference" href="http://sourceforge.net/project/showfiles.php?group_id=7586&package_id=8041&release_id=178835">boost 1.30.2</a>.</p>
|
version of boost, <a class="reference" href="http://sourceforge.net/project/showfiles.php?group_id=7586&package_id=8041&release_id=178835">boost 1.30.2</a>.</p>
|
||||||
<p>There are two versions of the socket code, one that works with unix systems (and bsd-sockets) and
|
<p>There are two versions of the file abstraction. There's one <tt class="literal"><span class="pre">file_win.cpp</span></tt> which
|
||||||
one that uses winsock. If you're building in windows, the file <tt class="literal"><span class="pre">socket_win.cpp</span></tt> is supposed to
|
|
||||||
be included in the build while <tt class="literal"><span class="pre">socket_bsd.cpp</span></tt> is supposed to be excluded.</p>
|
|
||||||
<p>The file abstraction has the same kind of separation. There's one <tt class="literal"><span class="pre">file_win.cpp</span></tt> which
|
|
||||||
relies on windows file API that supports files larger than 2 Gigabytes. This does not work
|
relies on windows file API that supports files larger than 2 Gigabytes. This does not work
|
||||||
in vc6 for some reason, possibly because it may require windows NT and above. The other file,
|
in vc6 for some reason, possibly because it may require windows NT and above. The other file,
|
||||||
<tt class="literal"><span class="pre">file.cpp</span></tt> is the default implementation that simply relies on the standard library's fstream,
|
<tt class="literal"><span class="pre">file.cpp</span></tt> is the default implementation that simply relies on the standard library's fstream,
|
||||||
|
@ -249,8 +246,12 @@ the <tt class="literal"><span class="pre">session</span></tt>, it contains the m
|
||||||
<pre class="literal-block">
|
<pre class="literal-block">
|
||||||
class session: public boost::noncopyable
|
class session: public boost::noncopyable
|
||||||
{
|
{
|
||||||
session(std::pair<int, int> listen_port_range, const fingerprint& print);
|
|
||||||
session(std::pair<int, int> listen_port_range);
|
session(std::pair<int, int> listen_port_range);
|
||||||
|
session(
|
||||||
|
std::pair<int, int> listen_port_range
|
||||||
|
, const fingerprint& print
|
||||||
|
, const char* listen_interface = 0);
|
||||||
|
|
||||||
torrent_handle add_torrent(
|
torrent_handle add_torrent(
|
||||||
const torrent_info& t
|
const torrent_info& t
|
||||||
|
@ -262,6 +263,13 @@ class session: public boost::noncopyable
|
||||||
void set_http_settings(const http_settings& settings);
|
void set_http_settings(const http_settings& settings);
|
||||||
void set_upload_rate_limit(int bytes_per_second);
|
void set_upload_rate_limit(int bytes_per_second);
|
||||||
|
|
||||||
|
bool is_listening() const;
|
||||||
|
unsigned short listen_port() const;
|
||||||
|
bool listen_on(
|
||||||
|
std::pair<int, int> const& port_range
|
||||||
|
, const char* interface = 0);
|
||||||
|
|
||||||
|
|
||||||
std::auto_ptr<alert> pop_alert();
|
std::auto_ptr<alert> pop_alert();
|
||||||
void set_severity_level(alert::severity_t s);
|
void set_severity_level(alert::severity_t s);
|
||||||
|
|
||||||
|
@ -290,6 +298,21 @@ fingerprint class.</p>
|
||||||
<p><tt class="literal"><span class="pre">set_upload_rate_limit()</span></tt> set the maximum number of bytes allowed to be
|
<p><tt class="literal"><span class="pre">set_upload_rate_limit()</span></tt> set the maximum number of bytes allowed to be
|
||||||
sent to peers per second. This bandwidth is distributed among all the peers. If
|
sent to peers per second. This bandwidth is distributed among all the peers. If
|
||||||
you don't want to limit upload rate, you can set this to -1 (the default).</p>
|
you don't want to limit upload rate, you can set this to -1 (the default).</p>
|
||||||
|
<p><tt class="literal"><span class="pre">is_listening()</span></tt> will tell you wether or not the session has successfully
|
||||||
|
opened a listening port. If it hasn't, this function will return false, and
|
||||||
|
then you can use <tt class="literal"><span class="pre">listen_on()</span></tt> to make another try.</p>
|
||||||
|
<p><tt class="literal"><span class="pre">listen_port()</span></tt> returns the port we ended up listening on. Since you just pass
|
||||||
|
a port-range to the constructor and to <tt class="literal"><span class="pre">listen_on()</span></tt>, to know which port it
|
||||||
|
ended up using, you have to ask the session using this function.</p>
|
||||||
|
<p><tt class="literal"><span class="pre">listen_on()</span></tt> will change the listen port and/or the listen interface. If the
|
||||||
|
session is already listening on a port, this socket will be closed and a new socket
|
||||||
|
will be opened with these new settings. The port range is the ports it will try
|
||||||
|
to listen on, if the first port fails, it will continue trying the next port within
|
||||||
|
the range and so on. The interface parameter can be left as 0, in that case the
|
||||||
|
os will decide which interface to listen on, otherwise it should be the ip-address
|
||||||
|
of the interface you want the listener socket bound to. <tt class="literal"><span class="pre">listen_on()</span></tt> returns true
|
||||||
|
if it managed to open the socket, and false if it failed. If it fails, it will also
|
||||||
|
generate an appropriate alert (<a class="reference" href="#listen-failed-alert">listen_failed_alert</a>).</p>
|
||||||
<p>The destructor of session will notify all trackers that our torrents has been shut down.
|
<p>The destructor of session will notify all trackers that our torrents has been shut down.
|
||||||
If some trackers are down, they will timout. All this before the destructor of session
|
If some trackers are down, they will timout. All this before the destructor of session
|
||||||
returns. So, it's adviced that any kind of interface (such as windows) are closed before
|
returns. So, it's adviced that any kind of interface (such as windows) are closed before
|
||||||
|
@ -302,7 +325,11 @@ increase the port number by one and try again. If it still fails it will continu
|
||||||
increasing the port number until it succeeds or has reached the end of the range. If it
|
increasing the port number until it succeeds or has reached the end of the range. If it
|
||||||
fails with all ports, a <a class="reference" href="#listen-failed-alert">listen_failed_alert</a> will be posted and the session thread will
|
fails with all ports, a <a class="reference" href="#listen-failed-alert">listen_failed_alert</a> will be posted and the session thread will
|
||||||
exit. The only thing you can do with your session if this alert is posted is to destruct
|
exit. The only thing you can do with your session if this alert is posted is to destruct
|
||||||
it and possibly try again or change the port range.</p>
|
it and possibly try again or change the port range. The listen interaface string is
|
||||||
|
the name (ip address) of the interface you want to listen on. If this is left as
|
||||||
|
0, the os will decide which interface to listen on (works in most cases). All torrents
|
||||||
|
will use this interface to open outgoing connections on by default. You can change
|
||||||
|
which interface to use for outgoing connections on a per torrent basis. See <a class="reference" href="#torrent-handle">torrent_handle</a>.</p>
|
||||||
<p>For information about the <tt class="literal"><span class="pre">pop_alert()</span></tt> function, see <a class="reference" href="#alerts">alerts</a>.</p>
|
<p>For information about the <tt class="literal"><span class="pre">pop_alert()</span></tt> function, see <a class="reference" href="#alerts">alerts</a>.</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="section" id="parsing-torrent-files">
|
<div class="section" id="parsing-torrent-files">
|
||||||
|
@ -535,6 +562,8 @@ struct torrent_handle
|
||||||
|
|
||||||
void set_tracker_login(std::string const& username, std::string const& password);
|
void set_tracker_login(std::string const& username, std::string const& password);
|
||||||
|
|
||||||
|
void use_interface(const char* net_interface);
|
||||||
|
|
||||||
boost::filsystem::path save_path() const;
|
boost::filsystem::path save_path() const;
|
||||||
|
|
||||||
void set_max_uploads(int max_uploads);
|
void set_max_uploads(int max_uploads);
|
||||||
|
@ -569,6 +598,8 @@ attempt to upload in return for each download. e.g. if set to 2, the client will
|
||||||
as a standard client.</p>
|
as a standard client.</p>
|
||||||
<p><tt class="literal"><span class="pre">set_tracker_login()</span></tt> sets a username and password that will be sent along in the HTTP-request
|
<p><tt class="literal"><span class="pre">set_tracker_login()</span></tt> sets a username and password that will be sent along in the HTTP-request
|
||||||
of the tracker announce. Set this if the tracker requires authorization.</p>
|
of the tracker announce. Set this if the tracker requires authorization.</p>
|
||||||
|
<p><tt class="literal"><span class="pre">use_interface()</span></tt> sets the network interface this torrent will use when it opens outgoing
|
||||||
|
connections. By default, it uses the same interface as the <a class="reference" href="#session">session</a> uses to listen on.</p>
|
||||||
<p><tt class="literal"><span class="pre">info_hash()</span></tt> returns the info hash for the torrent.</p>
|
<p><tt class="literal"><span class="pre">info_hash()</span></tt> returns the info hash for the torrent.</p>
|
||||||
<p><tt class="literal"><span class="pre">set_max_uploads()</span></tt> sets the maximum number of peers that's unchoked at the same time on this
|
<p><tt class="literal"><span class="pre">set_max_uploads()</span></tt> sets the maximum number of peers that's unchoked at the same time on this
|
||||||
torrent. If you set this to -1, there will be no limit.</p>
|
torrent. If you set this to -1, there will be no limit.</p>
|
||||||
|
@ -1089,8 +1120,8 @@ user in different ways.</p>
|
||||||
<div class="section" id="listen-failed-alert">
|
<div class="section" id="listen-failed-alert">
|
||||||
<h2><a name="listen-failed-alert">listen_failed_alert</a></h2>
|
<h2><a name="listen-failed-alert">listen_failed_alert</a></h2>
|
||||||
<p>This alert is generated when none of the ports, given in the port range, to
|
<p>This alert is generated when none of the ports, given in the port range, to
|
||||||
<a class="reference" href="#session">session</a> can be opened for listening. Without a listening port the session
|
<a class="reference" href="#session">session</a> can be opened for listening. This alert is generated as severity
|
||||||
object will exit its thread. This alert is generated as severity level <tt class="literal"><span class="pre">fatal</span></tt>.</p>
|
level <tt class="literal"><span class="pre">fatal</span></tt>.</p>
|
||||||
<pre class="literal-block">
|
<pre class="literal-block">
|
||||||
struct listen_failed_alert: alert
|
struct listen_failed_alert: alert
|
||||||
{
|
{
|
||||||
|
|
|
@ -202,6 +202,13 @@ The ``session`` class has the following synopsis::
|
||||||
void set_http_settings(const http_settings& settings);
|
void set_http_settings(const http_settings& settings);
|
||||||
void set_upload_rate_limit(int bytes_per_second);
|
void set_upload_rate_limit(int bytes_per_second);
|
||||||
|
|
||||||
|
bool is_listening() const;
|
||||||
|
unsigned short listen_port() const;
|
||||||
|
bool listen_on(
|
||||||
|
std::pair<int, int> const& port_range
|
||||||
|
, const char* interface = 0);
|
||||||
|
|
||||||
|
|
||||||
std::auto_ptr<alert> pop_alert();
|
std::auto_ptr<alert> pop_alert();
|
||||||
void set_severity_level(alert::severity_t s);
|
void set_severity_level(alert::severity_t s);
|
||||||
|
|
||||||
|
@ -236,6 +243,24 @@ fingerprint class.
|
||||||
sent to peers per second. This bandwidth is distributed among all the peers. If
|
sent to peers per second. This bandwidth is distributed among all the peers. If
|
||||||
you don't want to limit upload rate, you can set this to -1 (the default).
|
you don't want to limit upload rate, you can set this to -1 (the default).
|
||||||
|
|
||||||
|
``is_listening()`` will tell you wether or not the session has successfully
|
||||||
|
opened a listening port. If it hasn't, this function will return false, and
|
||||||
|
then you can use ``listen_on()`` to make another try.
|
||||||
|
|
||||||
|
``listen_port()`` returns the port we ended up listening on. Since you just pass
|
||||||
|
a port-range to the constructor and to ``listen_on()``, to know which port it
|
||||||
|
ended up using, you have to ask the session using this function.
|
||||||
|
|
||||||
|
``listen_on()`` will change the listen port and/or the listen interface. If the
|
||||||
|
session is already listening on a port, this socket will be closed and a new socket
|
||||||
|
will be opened with these new settings. The port range is the ports it will try
|
||||||
|
to listen on, if the first port fails, it will continue trying the next port within
|
||||||
|
the range and so on. The interface parameter can be left as 0, in that case the
|
||||||
|
os will decide which interface to listen on, otherwise it should be the ip-address
|
||||||
|
of the interface you want the listener socket bound to. ``listen_on()`` returns true
|
||||||
|
if it managed to open the socket, and false if it failed. If it fails, it will also
|
||||||
|
generate an appropriate alert (listen_failed_alert_).
|
||||||
|
|
||||||
The destructor of session will notify all trackers that our torrents has been shut down.
|
The destructor of session will notify all trackers that our torrents has been shut down.
|
||||||
If some trackers are down, they will timout. All this before the destructor of session
|
If some trackers are down, they will timout. All this before the destructor of session
|
||||||
returns. So, it's adviced that any kind of interface (such as windows) are closed before
|
returns. So, it's adviced that any kind of interface (such as windows) are closed before
|
||||||
|
@ -1136,8 +1161,8 @@ listen_failed_alert
|
||||||
-------------------
|
-------------------
|
||||||
|
|
||||||
This alert is generated when none of the ports, given in the port range, to
|
This alert is generated when none of the ports, given in the port range, to
|
||||||
session_ can be opened for listening. Without a listening port the session
|
session_ can be opened for listening. This alert is generated as severity
|
||||||
object will exit its thread. This alert is generated as severity level ``fatal``.
|
level ``fatal``.
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
|
|
|
@ -139,7 +139,7 @@ namespace libtorrent
|
||||||
// the torrent is added to the session
|
// the torrent is added to the session
|
||||||
session_impl& m_ses;
|
session_impl& m_ses;
|
||||||
|
|
||||||
boost::mutex m_mutex;
|
mutable boost::mutex m_mutex;
|
||||||
boost::condition m_cond;
|
boost::condition m_cond;
|
||||||
|
|
||||||
// a list of all torrents that are currently checking
|
// a list of all torrents that are currently checking
|
||||||
|
@ -164,9 +164,11 @@ namespace libtorrent
|
||||||
|
|
||||||
void operator()();
|
void operator()();
|
||||||
|
|
||||||
|
void open_listen_port();
|
||||||
|
|
||||||
// must be locked to access the data
|
// must be locked to access the data
|
||||||
// in this struct
|
// in this struct
|
||||||
boost::mutex m_mutex;
|
mutable boost::mutex m_mutex;
|
||||||
torrent* find_torrent(const sha1_hash& info_hash);
|
torrent* find_torrent(const sha1_hash& info_hash);
|
||||||
const peer_id& get_peer_id() const { return m_peer_id; }
|
const peer_id& get_peer_id() const { return m_peer_id; }
|
||||||
|
|
||||||
|
@ -202,6 +204,8 @@ namespace libtorrent
|
||||||
// them
|
// them
|
||||||
selector m_selector;
|
selector m_selector;
|
||||||
|
|
||||||
|
boost::shared_ptr<socket> m_listen_socket;
|
||||||
|
|
||||||
// the settings for the client
|
// the settings for the client
|
||||||
http_settings m_settings;
|
http_settings m_settings;
|
||||||
|
|
||||||
|
@ -257,8 +261,25 @@ namespace libtorrent
|
||||||
, const boost::filesystem::path& save_path
|
, const boost::filesystem::path& save_path
|
||||||
, const entry& resume_data = entry());
|
, const entry& resume_data = entry());
|
||||||
|
|
||||||
// TODO: add the ability to change listen-port on the fly
|
bool is_listening() const;
|
||||||
// TODO: make it possible to ask for the current listen port
|
|
||||||
|
// if the listen port failed in some way
|
||||||
|
// you can retry to listen on another port-
|
||||||
|
// range with this function. If the listener
|
||||||
|
// succeeded and is currently listening,
|
||||||
|
// a call to this function will shut down the
|
||||||
|
// listen port and reopen it using these new
|
||||||
|
// properties (the given interface and port range).
|
||||||
|
// As usual, if the interface is left as 0
|
||||||
|
// this function will return false on failure.
|
||||||
|
// If it fails, it will also generate alerts describing
|
||||||
|
// the error. It will return true on success.
|
||||||
|
bool listen_on(
|
||||||
|
std::pair<int, int> const& port_range
|
||||||
|
, const char* interface = 0);
|
||||||
|
|
||||||
|
// returns the port we ended up listening on
|
||||||
|
unsigned short listen_port() const;
|
||||||
|
|
||||||
void remove_torrent(const torrent_handle& h);
|
void remove_torrent(const torrent_handle& h);
|
||||||
|
|
||||||
|
|
|
@ -52,9 +52,6 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
// TODO: support ToS
|
// TODO: support ToS
|
||||||
// TODO: support binding to selected interface
|
|
||||||
// Distinguish between binding listen sockets and
|
|
||||||
// outgoing connections.
|
|
||||||
|
|
||||||
namespace libtorrent
|
namespace libtorrent
|
||||||
{
|
{
|
||||||
|
@ -102,8 +99,8 @@ namespace libtorrent
|
||||||
|
|
||||||
unsigned short port;
|
unsigned short port;
|
||||||
|
|
||||||
const static unsigned short any_port = 0;
|
BOOST_STATIC_CONSTANT(unsigned short, any_port = 0);
|
||||||
const static unsigned int any_addr = 0;
|
BOOST_STATIC_CONSTANT(unsigned int, any_addr = 0);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
|
|
@ -169,7 +169,7 @@ namespace libtorrent
|
||||||
// (make a rerequest from the tracker)
|
// (make a rerequest from the tracker)
|
||||||
void force_reannounce() const;
|
void force_reannounce() const;
|
||||||
|
|
||||||
// TODO: add a feature where the user can ask the torrent
|
// TODO: add a feature where the user can tell the torrent
|
||||||
// to finish all pieces currently in the pipeline, and then
|
// to finish all pieces currently in the pipeline, and then
|
||||||
// abort the torrent.
|
// abort the torrent.
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,10 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <boost/limits.hpp>
|
#include <boost/limits.hpp>
|
||||||
|
|
||||||
|
#if defined(_MSC_VER) && _MSC_VER < 1300
|
||||||
|
#define for if (false) {} else for
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace libtorrent
|
namespace libtorrent
|
||||||
{
|
{
|
||||||
namespace
|
namespace
|
||||||
|
|
143
src/session.cpp
143
src/session.cpp
|
@ -160,9 +160,7 @@ namespace
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace libtorrent
|
namespace libtorrent { namespace detail
|
||||||
{
|
|
||||||
namespace detail
|
|
||||||
{
|
{
|
||||||
void checker_impl::operator()()
|
void checker_impl::operator()()
|
||||||
{
|
{
|
||||||
|
@ -218,6 +216,7 @@ namespace libtorrent
|
||||||
catch(const std::exception& e)
|
catch(const std::exception& e)
|
||||||
{
|
{
|
||||||
// TODO: generate an alert here!
|
// TODO: generate an alert here!
|
||||||
|
// This will happen if the storage fails to initialize
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
std::cerr << "error while checking files: " << e.what() << "\n";
|
std::cerr << "error while checking files: " << e.what() << "\n";
|
||||||
#endif
|
#endif
|
||||||
|
@ -295,6 +294,69 @@ namespace libtorrent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void session_impl::open_listen_port()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// create listener socket
|
||||||
|
m_listen_socket = boost::shared_ptr<socket>(new socket(socket::tcp, false));
|
||||||
|
|
||||||
|
for(;;)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
m_listen_socket->listen(m_listen_interface, 10);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
catch (network_error& e)
|
||||||
|
{
|
||||||
|
if (e.error_code() == socket::address_not_available)
|
||||||
|
{
|
||||||
|
std::string msg = "cannot listen on the given interface '" + m_listen_interface.as_string() + "'";
|
||||||
|
m_alerts.post_alert(listen_failed_alert(msg));
|
||||||
|
#ifndef NDEBUG
|
||||||
|
(*m_logger) << msg << "\n";
|
||||||
|
#endif
|
||||||
|
m_listen_socket.reset();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
m_listen_interface.port++;
|
||||||
|
if (m_listen_interface.port > m_listen_port_range.second)
|
||||||
|
{
|
||||||
|
std::stringstream msg;
|
||||||
|
msg << "none of the ports in the range ["
|
||||||
|
<< m_listen_port_range.first
|
||||||
|
<< ", " << m_listen_port_range.second
|
||||||
|
<< "] could be opened for listening";
|
||||||
|
m_alerts.post_alert(listen_failed_alert(msg.str()));
|
||||||
|
#ifndef NDEBUG
|
||||||
|
(*m_logger) << msg.str() << "\n";
|
||||||
|
#endif
|
||||||
|
m_listen_socket.reset();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (network_error& e)
|
||||||
|
{
|
||||||
|
m_alerts.post_alert(listen_failed_alert(e.what()));
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef NDEBUG
|
||||||
|
if (m_listen_socket)
|
||||||
|
{
|
||||||
|
(*m_logger) << "listening on port: " << m_listen_interface.port << "\n";
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (m_listen_socket)
|
||||||
|
{
|
||||||
|
m_selector.monitor_readability(m_listen_socket);
|
||||||
|
m_selector.monitor_errors(m_listen_socket);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void session_impl::operator()()
|
void session_impl::operator()()
|
||||||
{
|
{
|
||||||
eh_initializer();
|
eh_initializer();
|
||||||
|
@ -304,41 +366,8 @@ namespace libtorrent
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
#endif
|
#endif
|
||||||
// create listener socket
|
|
||||||
// TODO: if this fails, no alert is generated
|
|
||||||
boost::shared_ptr<socket> listener(new socket(socket::tcp, false));
|
|
||||||
|
|
||||||
for(;;)
|
open_listen_port();
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
listener->listen(m_listen_interface, 10);
|
|
||||||
}
|
|
||||||
catch (network_error& e)
|
|
||||||
{
|
|
||||||
if (e.error_code() == socket::address_not_available)
|
|
||||||
{
|
|
||||||
std::string msg = "cannot listen on the given interface '" + m_listen_interface.as_string() + "'";
|
|
||||||
m_alerts.post_alert(listen_failed_alert(msg));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
m_listen_interface.port++;
|
|
||||||
if (m_listen_interface.port > m_listen_port_range.second)
|
|
||||||
{
|
|
||||||
m_alerts.post_alert(listen_failed_alert(
|
|
||||||
"none of the ports in the given range could be opened"));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef NDEBUG
|
|
||||||
(*m_logger) << "listening on port: " << m_listen_interface.port << "\n";
|
|
||||||
#endif
|
|
||||||
m_selector.monitor_readability(listener);
|
|
||||||
m_selector.monitor_errors(listener);
|
|
||||||
|
|
||||||
std::vector<boost::shared_ptr<socket> > readable_clients;
|
std::vector<boost::shared_ptr<socket> > readable_clients;
|
||||||
std::vector<boost::shared_ptr<socket> > writable_clients;
|
std::vector<boost::shared_ptr<socket> > writable_clients;
|
||||||
|
@ -470,9 +499,10 @@ namespace libtorrent
|
||||||
i != readable_clients.end();
|
i != readable_clients.end();
|
||||||
++i)
|
++i)
|
||||||
{
|
{
|
||||||
// special case for listener socket
|
// special case for m_listen_socket socket
|
||||||
if (*i == listener)
|
if (*i == m_listen_socket)
|
||||||
{
|
{
|
||||||
|
assert(m_listen_socket);
|
||||||
boost::shared_ptr<libtorrent::socket> s = (*i)->accept();
|
boost::shared_ptr<libtorrent::socket> s = (*i)->accept();
|
||||||
if (s)
|
if (s)
|
||||||
{
|
{
|
||||||
|
@ -747,7 +777,10 @@ namespace libtorrent
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}}
|
||||||
|
|
||||||
|
namespace libtorrent
|
||||||
|
{
|
||||||
|
|
||||||
session::session(
|
session::session(
|
||||||
std::pair<int, int> listen_port_range
|
std::pair<int, int> listen_port_range
|
||||||
|
@ -861,6 +894,36 @@ namespace libtorrent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool session::listen_on(
|
||||||
|
std::pair<int, int> const& port_range
|
||||||
|
, const char* net_interface)
|
||||||
|
{
|
||||||
|
boost::mutex::scoped_lock l(m_impl.m_mutex);
|
||||||
|
|
||||||
|
if (m_impl.m_listen_socket)
|
||||||
|
{
|
||||||
|
m_impl.m_selector.remove(m_impl.m_listen_socket);
|
||||||
|
m_impl.m_listen_socket.reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
m_impl.m_listen_port_range = port_range;
|
||||||
|
m_impl.m_listen_interface = address(net_interface, port_range.first);
|
||||||
|
m_impl.open_listen_port();
|
||||||
|
return m_impl.m_listen_socket;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned short session::listen_port() const
|
||||||
|
{
|
||||||
|
boost::mutex::scoped_lock l(m_impl.m_mutex);
|
||||||
|
return m_impl.m_listen_interface.port;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool session::is_listening() const
|
||||||
|
{
|
||||||
|
boost::mutex::scoped_lock l(m_impl.m_mutex);
|
||||||
|
return m_impl.m_listen_socket;
|
||||||
|
}
|
||||||
|
|
||||||
void session::set_http_settings(const http_settings& s)
|
void session::set_http_settings(const http_settings& s)
|
||||||
{
|
{
|
||||||
boost::mutex::scoped_lock l(m_impl.m_mutex);
|
boost::mutex::scoped_lock l(m_impl.m_mutex);
|
||||||
|
|
Loading…
Reference in New Issue