*** empty log message ***

This commit is contained in:
Arvid Norberg 2004-10-31 23:16:08 +00:00
parent 189375b761
commit df281f81ae
10 changed files with 230 additions and 149 deletions

33
Jamfile
View File

@ -8,33 +8,33 @@ BOOST_ROOT = [ modules.peek : BOOST_ROOT ] ;
ECHO "BOOST_ROOT =" $(BOOST_ROOT) ;
ECHO "OS =" [ os.name ] ;
use-project /boost/thread : $(BOOST_ROOT)/libs/thread/build ;
use-project /boost/filesystem : $(BOOST_ROOT)/libs/filesystem/build ;
use-project /boost/date_time : $(BOOST_ROOT)/libs/date_time/build ;
use-project /boost : $(BOOST_ROOT) ;
project torrent
: requirements
REQUIREMENTS =
<include>./include
<include>./zlib
<include>$(BOOST_ROOT)
<variant>release:<define>NDEBUG
<define>BOOST_ALL_NO_LIB
<define>_FILE_OFFSET_BITS=64
<library>/boost/thread//boost_thread
<library>/boost/thread//boost_thread/
<library>/boost/filesystem//boost_filesystem/<link>static
<library>/boost/date_time//boost_date_time/<link>static
# devstudio switches
<link>static
<threading>multi
<toolset>msvc-7:<cxxflags>/Zc:wchar_t
<toolset>msvc-7.1:<cxxflags>/Zc:wchar_t
;
: usage-requirements
USAGE_REQUIREMENTS =
<include>./include
<include>$(BOOST_ROOT)
<variant>release:<define>NDEBUG
<define>BOOST_ALL_NO_LIB
;
SOURCES =
@ -89,24 +89,11 @@ LIBS = ;
SOURCES += file.cpp ;
}
project torrent
: requirements
$(REQUIREMENTS)
: usage-requirements
$(USAGE_REQUIREMENTS)
;
lib torrent
:
src/$(SOURCES)
zlib/$(ZLIB_SOURCES)
$(LIBS)
:
<threading>multi
<link>static
<variant>debug:<define>TORRENT_VERBOSE_LOGGING
: debug release
;

View File

@ -25,98 +25,99 @@
<li><a class="reference" href="#id9" id="id25" name="id25">~session()</a></li>
<li><a class="reference" href="#add-torrent" id="id26" name="id26">add_torrent()</a></li>
<li><a class="reference" href="#remove-torrent" id="id27" name="id27">remove_torrent()</a></li>
<li><a class="reference" href="#set-upload-rate-limit-set-download-rate-limit" id="id28" name="id28">set_upload_rate_limit() set_download_rate_limit()</a></li>
<li><a class="reference" href="#set-max-uploads-set-max-connections" id="id29" name="id29">set_max_uploads() set_max_connections()</a></li>
<li><a class="reference" href="#status" id="id30" name="id30">status()</a></li>
<li><a class="reference" href="#is-listening-listen-port-listen-on" id="id31" name="id31">is_listening() listen_port() listen_on()</a></li>
<li><a class="reference" href="#pop-alert-set-severity-level" id="id32" name="id32">pop_alert() set_severity_level()</a></li>
<li><a class="reference" href="#disable-extensions-enable-extension" id="id28" name="id28">disable_extensions() enable_extension()</a></li>
<li><a class="reference" href="#set-upload-rate-limit-set-download-rate-limit" id="id29" name="id29">set_upload_rate_limit() set_download_rate_limit()</a></li>
<li><a class="reference" href="#set-max-uploads-set-max-connections" id="id30" name="id30">set_max_uploads() set_max_connections()</a></li>
<li><a class="reference" href="#status" id="id31" name="id31">status()</a></li>
<li><a class="reference" href="#is-listening-listen-port-listen-on" id="id32" name="id32">is_listening() listen_port() listen_on()</a></li>
<li><a class="reference" href="#pop-alert-set-severity-level" id="id33" name="id33">pop_alert() set_severity_level()</a></li>
</ul>
</li>
<li><a class="reference" href="#entry" id="id33" name="id33">entry</a><ul>
<li><a class="reference" href="#integer-string-list-dict-type" id="id34" name="id34">integer() string() list() dict() type()</a></li>
<li><a class="reference" href="#entry" id="id34" name="id34">entry</a><ul>
<li><a class="reference" href="#integer-string-list-dict-type" id="id35" name="id35">integer() string() list() dict() type()</a></li>
</ul>
</li>
<li><a class="reference" href="#torrent-info" id="id35" name="id35">torrent_info</a><ul>
<li><a class="reference" href="#begin-files-end-files-rbegin-files-rend-files" id="id36" name="id36">begin_files() end_files() rbegin_files() rend_files()</a></li>
<li><a class="reference" href="#num-files-file-at" id="id37" name="id37">num_files() file_at()</a></li>
<li><a class="reference" href="#print" id="id38" name="id38">print()</a></li>
<li><a class="reference" href="#trackers" id="id39" name="id39">trackers()</a></li>
<li><a class="reference" href="#total-size-piece-length-piece-size-num-pieces" id="id40" name="id40">total_size() piece_length() piece_size() num_pieces()</a></li>
<li><a class="reference" href="#hash-for-piece-info-hash" id="id41" name="id41">hash_for_piece() info_hash()</a></li>
<li><a class="reference" href="#name-comment-creation-date" id="id42" name="id42">name() comment() creation_date()</a></li>
<li><a class="reference" href="#torrent-info" id="id36" name="id36">torrent_info</a><ul>
<li><a class="reference" href="#begin-files-end-files-rbegin-files-rend-files" id="id37" name="id37">begin_files() end_files() rbegin_files() rend_files()</a></li>
<li><a class="reference" href="#num-files-file-at" id="id38" name="id38">num_files() file_at()</a></li>
<li><a class="reference" href="#print" id="id39" name="id39">print()</a></li>
<li><a class="reference" href="#trackers" id="id40" name="id40">trackers()</a></li>
<li><a class="reference" href="#total-size-piece-length-piece-size-num-pieces" id="id41" name="id41">total_size() piece_length() piece_size() num_pieces()</a></li>
<li><a class="reference" href="#hash-for-piece-info-hash" id="id42" name="id42">hash_for_piece() info_hash()</a></li>
<li><a class="reference" href="#name-comment-creation-date" id="id43" name="id43">name() comment() creation_date()</a></li>
</ul>
</li>
<li><a class="reference" href="#torrent-handle" id="id43" name="id43">torrent_handle</a><ul>
<li><a class="reference" href="#save-path" id="id44" name="id44">save_path()</a></li>
<li><a class="reference" href="#move-storage" id="id45" name="id45">move_storage()</a></li>
<li><a class="reference" href="#force-reannounce" id="id46" name="id46">force_reannounce()</a></li>
<li><a class="reference" href="#connect-peer" id="id47" name="id47">connect_peer()</a></li>
<li><a class="reference" href="#set-ratio" id="id48" name="id48">set_ratio()</a></li>
<li><a class="reference" href="#set-upload-limit-set-download-limit" id="id49" name="id49">set_upload_limit() set_download_limit()</a></li>
<li><a class="reference" href="#pause-resume-is-paused" id="id50" name="id50">pause() resume() is_paused()</a></li>
<li><a class="reference" href="#is-seed" id="id51" name="id51">is_seed()</a></li>
<li><a class="reference" href="#set-tracker-login" id="id52" name="id52">set_tracker_login()</a></li>
<li><a class="reference" href="#use-interface" id="id53" name="id53">use_interface()</a></li>
<li><a class="reference" href="#info-hash" id="id54" name="id54">info_hash()</a></li>
<li><a class="reference" href="#id11" id="id55" name="id55">set_max_uploads() set_max_connections()</a></li>
<li><a class="reference" href="#write-resume-data" id="id56" name="id56">write_resume_data()</a></li>
<li><a class="reference" href="#metadata" id="id57" name="id57">metadata()</a></li>
<li><a class="reference" href="#id12" id="id58" name="id58">status()</a></li>
<li><a class="reference" href="#get-download-queue" id="id59" name="id59">get_download_queue()</a></li>
<li><a class="reference" href="#get-peer-info" id="id60" name="id60">get_peer_info()</a></li>
<li><a class="reference" href="#get-torrent-info" id="id61" name="id61">get_torrent_info()</a></li>
<li><a class="reference" href="#is-valid" id="id62" name="id62">is_valid()</a></li>
<li><a class="reference" href="#torrent-handle" id="id44" name="id44">torrent_handle</a><ul>
<li><a class="reference" href="#save-path" id="id45" name="id45">save_path()</a></li>
<li><a class="reference" href="#move-storage" id="id46" name="id46">move_storage()</a></li>
<li><a class="reference" href="#force-reannounce" id="id47" name="id47">force_reannounce()</a></li>
<li><a class="reference" href="#connect-peer" id="id48" name="id48">connect_peer()</a></li>
<li><a class="reference" href="#set-ratio" id="id49" name="id49">set_ratio()</a></li>
<li><a class="reference" href="#set-upload-limit-set-download-limit" id="id50" name="id50">set_upload_limit() set_download_limit()</a></li>
<li><a class="reference" href="#pause-resume-is-paused" id="id51" name="id51">pause() resume() is_paused()</a></li>
<li><a class="reference" href="#is-seed" id="id52" name="id52">is_seed()</a></li>
<li><a class="reference" href="#set-tracker-login" id="id53" name="id53">set_tracker_login()</a></li>
<li><a class="reference" href="#use-interface" id="id54" name="id54">use_interface()</a></li>
<li><a class="reference" href="#info-hash" id="id55" name="id55">info_hash()</a></li>
<li><a class="reference" href="#id11" id="id56" name="id56">set_max_uploads() set_max_connections()</a></li>
<li><a class="reference" href="#write-resume-data" id="id57" name="id57">write_resume_data()</a></li>
<li><a class="reference" href="#metadata" id="id58" name="id58">metadata()</a></li>
<li><a class="reference" href="#id12" id="id59" name="id59">status()</a></li>
<li><a class="reference" href="#get-download-queue" id="id60" name="id60">get_download_queue()</a></li>
<li><a class="reference" href="#get-peer-info" id="id61" name="id61">get_peer_info()</a></li>
<li><a class="reference" href="#get-torrent-info" id="id62" name="id62">get_torrent_info()</a></li>
<li><a class="reference" href="#is-valid" id="id63" name="id63">is_valid()</a></li>
</ul>
</li>
<li><a class="reference" href="#torrent-status" id="id63" name="id63">torrent_status</a></li>
<li><a class="reference" href="#peer-info" id="id64" name="id64">peer_info</a></li>
<li><a class="reference" href="#address" id="id65" name="id65">address</a></li>
<li><a class="reference" href="#http-settings" id="id66" name="id66">http_settings</a></li>
<li><a class="reference" href="#big-number" id="id67" name="id67">big_number</a></li>
<li><a class="reference" href="#hasher" id="id68" name="id68">hasher</a></li>
<li><a class="reference" href="#fingerprint" id="id69" name="id69">fingerprint</a></li>
<li><a class="reference" href="#free-functions" id="id70" name="id70">free functions</a><ul>
<li><a class="reference" href="#identify-client" id="id71" name="id71">identify_client()</a></li>
<li><a class="reference" href="#bdecode-bencode" id="id72" name="id72">bdecode() bencode()</a></li>
<li><a class="reference" href="#torrent-status" id="id64" name="id64">torrent_status</a></li>
<li><a class="reference" href="#peer-info" id="id65" name="id65">peer_info</a></li>
<li><a class="reference" href="#address" id="id66" name="id66">address</a></li>
<li><a class="reference" href="#http-settings" id="id67" name="id67">http_settings</a></li>
<li><a class="reference" href="#big-number" id="id68" name="id68">big_number</a></li>
<li><a class="reference" href="#hasher" id="id69" name="id69">hasher</a></li>
<li><a class="reference" href="#fingerprint" id="id70" name="id70">fingerprint</a></li>
<li><a class="reference" href="#free-functions" id="id71" name="id71">free functions</a><ul>
<li><a class="reference" href="#identify-client" id="id72" name="id72">identify_client()</a></li>
<li><a class="reference" href="#bdecode-bencode" id="id73" name="id73">bdecode() bencode()</a></li>
</ul>
</li>
<li><a class="reference" href="#alerts" id="id73" name="id73">alerts</a><ul>
<li><a class="reference" href="#listen-failed-alert" id="id74" name="id74">listen_failed_alert</a></li>
<li><a class="reference" href="#file-error-alert" id="id75" name="id75">file_error_alert</a></li>
<li><a class="reference" href="#tracker-alert" id="id76" name="id76">tracker_alert</a></li>
<li><a class="reference" href="#hash-failed-alert" id="id77" name="id77">hash_failed_alert</a></li>
<li><a class="reference" href="#peer-ban-alert" id="id78" name="id78">peer_ban_alert</a></li>
<li><a class="reference" href="#peer-error-alert" id="id79" name="id79">peer_error_alert</a></li>
<li><a class="reference" href="#invalid-request-alert" id="id80" name="id80">invalid_request_alert</a></li>
<li><a class="reference" href="#torrent-finished-alert" id="id81" name="id81">torrent_finished_alert</a></li>
<li><a class="reference" href="#metadata-received-alert" id="id82" name="id82">metadata_received_alert</a></li>
<li><a class="reference" href="#dispatcher" id="id83" name="id83">dispatcher</a></li>
<li><a class="reference" href="#alerts" id="id74" name="id74">alerts</a><ul>
<li><a class="reference" href="#listen-failed-alert" id="id75" name="id75">listen_failed_alert</a></li>
<li><a class="reference" href="#file-error-alert" id="id76" name="id76">file_error_alert</a></li>
<li><a class="reference" href="#tracker-alert" id="id77" name="id77">tracker_alert</a></li>
<li><a class="reference" href="#hash-failed-alert" id="id78" name="id78">hash_failed_alert</a></li>
<li><a class="reference" href="#peer-ban-alert" id="id79" name="id79">peer_ban_alert</a></li>
<li><a class="reference" href="#peer-error-alert" id="id80" name="id80">peer_error_alert</a></li>
<li><a class="reference" href="#invalid-request-alert" id="id81" name="id81">invalid_request_alert</a></li>
<li><a class="reference" href="#torrent-finished-alert" id="id82" name="id82">torrent_finished_alert</a></li>
<li><a class="reference" href="#metadata-received-alert" id="id83" name="id83">metadata_received_alert</a></li>
<li><a class="reference" href="#dispatcher" id="id84" name="id84">dispatcher</a></li>
</ul>
</li>
<li><a class="reference" href="#exceptions" id="id84" name="id84">exceptions</a><ul>
<li><a class="reference" href="#invalid-handle" id="id85" name="id85">invalid_handle</a></li>
<li><a class="reference" href="#duplicate-torrent" id="id86" name="id86">duplicate_torrent</a></li>
<li><a class="reference" href="#invalid-encoding" id="id87" name="id87">invalid_encoding</a></li>
<li><a class="reference" href="#type-error" id="id88" name="id88">type_error</a></li>
<li><a class="reference" href="#invalid-torrent-file" id="id89" name="id89">invalid_torrent_file</a></li>
<li><a class="reference" href="#exceptions" id="id85" name="id85">exceptions</a><ul>
<li><a class="reference" href="#invalid-handle" id="id86" name="id86">invalid_handle</a></li>
<li><a class="reference" href="#duplicate-torrent" id="id87" name="id87">duplicate_torrent</a></li>
<li><a class="reference" href="#invalid-encoding" id="id88" name="id88">invalid_encoding</a></li>
<li><a class="reference" href="#type-error" id="id89" name="id89">type_error</a></li>
<li><a class="reference" href="#invalid-torrent-file" id="id90" name="id90">invalid_torrent_file</a></li>
</ul>
</li>
<li><a class="reference" href="#examples" id="id90" name="id90">examples</a><ul>
<li><a class="reference" href="#dump-torrent" id="id91" name="id91">dump_torrent</a></li>
<li><a class="reference" href="#simple-client" id="id92" name="id92">simple client</a></li>
<li><a class="reference" href="#examples" id="id91" name="id91">examples</a><ul>
<li><a class="reference" href="#dump-torrent" id="id92" name="id92">dump_torrent</a></li>
<li><a class="reference" href="#simple-client" id="id93" name="id93">simple client</a></li>
</ul>
</li>
<li><a class="reference" href="#fast-resume" id="id93" name="id93">fast resume</a><ul>
<li><a class="reference" href="#file-format" id="id94" name="id94">file format</a></li>
<li><a class="reference" href="#fast-resume" id="id94" name="id94">fast resume</a><ul>
<li><a class="reference" href="#file-format" id="id95" name="id95">file format</a></li>
</ul>
</li>
<li><a class="reference" href="#extensions" id="id95" name="id95">extensions</a><ul>
<li><a class="reference" href="#chat-messages" id="id96" name="id96">chat messages</a></li>
<li><a class="reference" href="#metadata-from-peers" id="id97" name="id97">metadata from peers</a></li>
<li><a class="reference" href="#extensions" id="id96" name="id96">extensions</a><ul>
<li><a class="reference" href="#chat-messages" id="id97" name="id97">chat messages</a></li>
<li><a class="reference" href="#metadata-from-peers" id="id98" name="id98">metadata from peers</a></li>
</ul>
</li>
<li><a class="reference" href="#filename-checks" id="id98" name="id98">filename checks</a></li>
<li><a class="reference" href="#acknowledgements" id="id99" name="id99">acknowledgements</a></li>
<li><a class="reference" href="#filename-checks" id="id99" name="id99">filename checks</a></li>
<li><a class="reference" href="#acknowledgements" id="id100" name="id100">acknowledgements</a></li>
</ul>
</div>
<div class="section" id="introduction">
@ -174,22 +175,22 @@ means it can resume a torrent downloaded by any client.</li>
<li>file-level priority</li>
</ul>
</blockquote>
<p>libtorrent is portable at least among windows, macosx, and UNIX-systems. It uses boost.thread,
boost.filesystem, boost.date_time and various other boost libraries as well as zlib.</p>
<p>libtorrent is portable at least among windows, macosx, and other UNIX-systems. It uses Boost.Thread,
Boost.Filesystem, Boost.Date_time and various other boost libraries as well as zlib.</p>
<p>libtorrent has been successfully compiled and tested on:</p>
<blockquote>
<ul class="simple">
<li>Windows 2000 vc7.1</li>
<li>Linux x86 (debian) GCC 3.0.4, GCC 3.2.3</li>
<li>Linux x86 GCC 3.0.4, GCC 3.2.3, GCC 3.4.2</li>
<li>MacOS X, GCC 3.3</li>
<li>SunOS 5.8 GCC 3.1</li>
<li>Cygwin GCC 3.3.3</li>
</ul>
</blockquote>
<p>Fails on:</p>
<blockquote>
<ul class="simple">
<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>
<li>msvc6 sp5</li>
</ul>
</blockquote>
@ -272,11 +273,6 @@ written.</td>
checks in the storage, including logging of
piece sorting.</td>
</tr>
<tr><td><tt class="literal"><span class="pre">TORRENT_DISABLE_EXTENSIONS</span></tt></td>
<td>This will disble the support for extensions.
For more information on which extensions are
currently implemented, see <a class="reference" href="#extensions">extensions</a>.</td>
</tr>
</tbody>
</table>
<p>If you experience that libtorrent uses unreasonable amounts of cpu, it will definately help to
@ -337,6 +333,9 @@ class session: public boost::noncopyable
void remove_torrent(torrent_handle const&amp; h);
void disable_extensions();
void enable_extension(peer_connection::extension_index);
void set_http_settings(const http_settings&amp; settings);
void set_upload_rate_limit(int bytes_per_second);
@ -429,6 +428,31 @@ void remove_torrent(torrent_handle const&amp; h);
<p><tt class="literal"><span class="pre">remove_torrent()</span></tt> will close all peer connections associated with the torrent and tell
the tracker that we've stopped participating in the swarm.</p>
</div>
<div class="section" id="disable-extensions-enable-extension">
<h2><a name="disable-extensions-enable-extension">disable_extensions() enable_extension()</a></h2>
<blockquote>
<pre class="literal-block">
void disable_extensions();
void enable_extension(peer_connection::extension_index);
</pre>
</blockquote>
<p><tt class="literal"><span class="pre">disable_extensions()</span></tt> will disable all extensions available in libtorrent.
<tt class="literal"><span class="pre">enable_extension()</span></tt> will enable a single extension. The available extensions
are enumerated in the <tt class="literal"><span class="pre">peer_connection</span></tt> class. These are the available extensions:</p>
<pre class="literal-block">
enum extension_index
{
extended_chat_message,
extended_metadata_message,
extended_peer_exchange_message,
extended_listen_port_message,
num_supported_extensions
};
</pre>
<p><em>peer_exchange is not implemented yet</em></p>
<p>By default, all extensions are enabled.
For more information about the extensions, see the <a class="reference" href="#extensions">extensions</a> section.</p>
</div>
<div class="section" id="set-upload-rate-limit-set-download-rate-limit">
<h2><a name="set-upload-rate-limit-set-download-rate-limit">set_upload_rate_limit() set_download_rate_limit()</a></h2>
<blockquote>

View File

@ -61,20 +61,20 @@ Functions that are yet to be implemented:
* ip-filters
* file-level priority
libtorrent is portable at least among windows, macosx, and UNIX-systems. It uses boost.thread,
boost.filesystem, boost.date_time and various other boost libraries as well as zlib.
libtorrent is portable at least among windows, macosx, and other UNIX-systems. It uses Boost.Thread,
Boost.Filesystem, Boost.Date_time and various other boost libraries as well as zlib.
libtorrent has been successfully compiled and tested on:
* Windows 2000 vc7.1
* Linux x86 (debian) GCC 3.0.4, GCC 3.2.3
* Linux x86 GCC 3.0.4, GCC 3.2.3, GCC 3.4.2
* MacOS X, GCC 3.3
* SunOS 5.8 GCC 3.1
* Cygwin GCC 3.3.3
Fails on:
* GCC 2.95.4 (``std::ios_base`` is missing)
* Cygwin GCC 3.3.1 (builds but crashes)
* msvc6 sp5
libtorrent is released under the BSD-license_.
@ -174,10 +174,6 @@ table below for which defines you can use to control the build. The ``Jamfile``
| | checks in the storage, including logging of |
| | piece sorting. |
+--------------------------------+-------------------------------------------------+
| ``TORRENT_DISABLE_EXTENSIONS`` | This will disble the support for extensions. |
| | For more information on which extensions are |
| | currently implemented, see extensions_. |
+--------------------------------+-------------------------------------------------+
If you experience that libtorrent uses unreasonable amounts of cpu, it will definately help to
@ -235,6 +231,9 @@ The ``session`` class has the following synopsis::
void remove_torrent(torrent_handle const& h);
void disable_extensions();
void enable_extension(peer_connection::extension_index);
void set_http_settings(const http_settings& settings);
void set_upload_rate_limit(int bytes_per_second);
@ -335,6 +334,32 @@ remove_torrent()
the tracker that we've stopped participating in the swarm.
disable_extensions() enable_extension()
---------------------------------------
::
void disable_extensions();
void enable_extension(peer_connection::extension_index);
``disable_extensions()`` will disable all extensions available in libtorrent.
``enable_extension()`` will enable a single extension. The available extensions
are enumerated in the ``peer_connection`` class. These are the available extensions::
enum extension_index
{
extended_chat_message,
extended_metadata_message,
extended_peer_exchange_message,
extended_listen_port_message,
num_supported_extensions
};
*peer_exchange is not implemented yet*
By default, all extensions are enabled.
For more information about the extensions, see the extensions_ section.
set_upload_rate_limit() set_download_rate_limit()
-------------------------------------------------

View File

@ -1,38 +1,25 @@
use-project /torrent : .. ;
project
: requirements <source>/torrent <threading>multi
;
exe client_test
: client_test.cpp
/torrent
:
<threading>multi
: debug release
;
exe simple_client
: simple_client.cpp
/torrent
:
<threading>multi
: debug release
;
exe dump_torrent
: dump_torrent.cpp
/torrent
:
<threading>multi
: debug release
;
exe make_torrent
: make_torrent.cpp
/torrent
:
<threading>multi
: debug release
;

View File

@ -216,6 +216,12 @@ namespace libtorrent
boost::shared_ptr<socket> m_listen_socket;
// the entries in this array maps the
// extension index (as specified in peer_connection)
bool m_extension_enabled[peer_connection::num_supported_extensions];
bool extensions_enabled() const;
// the settings for the client
http_settings m_settings;
@ -304,6 +310,9 @@ namespace libtorrent
session_status status() const;
void enable_extension(peer_connection::extension_index i);
void disable_extensions();
bool is_listening() const;
// if the listen port failed in some way

View File

@ -155,6 +155,7 @@ namespace
map_entry name_map[] =
{
map_entry("A", "ABC")
, map_entry("AR", "Arctic Torrent")
, map_entry("AZ", "Azureus")
, map_entry("BB", "BitBuddy")
, map_entry("BX", "BittorrentX")

View File

@ -413,9 +413,9 @@ namespace libtorrent
, m_send_buffer.begin() + pos + 8
, 0);
// indicate that we support the extension protocol
#ifndef TORRENT_DISABLE_EXTENSIONS
if (m_ses.extensions_enabled())
m_send_buffer[pos+7] = 0x01;
#endif
pos += 8;
// info hash
@ -1057,7 +1057,7 @@ namespace libtorrent
assert(m_torrent);
assert(received > 0);
if (m_packet_size > 100 * 1024)
if (m_packet_size > 100 * 1000)
{
// too big extension message, abort
throw protocol_error("'extensions' message size > 100kB");
@ -1125,6 +1125,9 @@ namespace libtorrent
const char* ptr = &m_recv_buffer[1];
int extended_id = detail::read_int32(ptr);
if (!m_ses.m_extension_enabled[extended_id])
throw protocol_error("'extended' message using disabled extension");
switch (extended_id)
{
case extended_chat_message:
@ -1587,6 +1590,9 @@ namespace libtorrent
for (int i = 0; i < num_supported_extensions; ++i)
{
// if this specific extension is disabled
// just don't add it to the supported set
if (!m_ses.m_extension_enabled[i]) continue;
extension_list[extension_names[i]] = i;
}
@ -1953,10 +1959,8 @@ namespace libtorrent
// ok, now we have got enough of the handshake. Is this connection
// attached to a torrent?
#ifndef TORRENT_DISABLE_EXTENSIONS
if (m_recv_buffer[7] & 0x01)
if ((m_recv_buffer[7] & 0x01) && m_ses.extensions_enabled())
m_supports_extensions = true;
#endif
if (m_torrent == 0)
{

View File

@ -203,6 +203,8 @@ namespace libtorrent { namespace detail
#ifndef NDEBUG
m_logger = create_log("main session");
#endif
std::fill(m_extension_enabled, m_extension_enabled
+ peer_connection::num_supported_extensions, true);
// ---- generate a peer id ----
std::srand((unsigned int)std::time(0));
@ -229,6 +231,13 @@ namespace libtorrent { namespace detail
}
}
bool session_impl::extensions_enabled() const
{
const int n = peer_connection::num_supported_extensions;
return std::find(m_extension_enabled
, m_extension_enabled + n, true) != m_extension_enabled + n;
}
void session_impl::purge_connections()
{
while (!m_disconnect_peer.empty())
@ -852,6 +861,21 @@ namespace libtorrent
#endif
}
void session::disable_extensions()
{
boost::mutex::scoped_lock l(m_impl.m_mutex);
std::fill(m_impl.m_extension_enabled, m_impl.m_extension_enabled
+ peer_connection::num_supported_extensions, false);
}
void session::enable_extension(peer_connection::extension_index i)
{
assert(i >= 0);
assert(i < peer_connection::num_supported_extensions);
boost::mutex::scoped_lock l(m_impl.m_mutex);
m_impl.m_extension_enabled[i] = true;
}
// TODO: add a check to see if filenames are accepted on the
// current platform.
// if the torrent already exists, this will throw duplicate_torrent
@ -903,7 +927,6 @@ namespace libtorrent
return torrent_handle(&m_impl, &m_checker_impl, ti.info_hash());
}
#ifndef TORRENT_DISABLE_EXTENSIONS
torrent_handle session::add_torrent(
char const* tracker_url
, sha1_hash const& info_hash
@ -923,6 +946,10 @@ namespace libtorrent
// lock the session
boost::mutex::scoped_lock l(m_impl.m_mutex);
// the metadata extension has to be enabled for this to work
assert(m_impl.m_extension_enabled
[peer_connection::extended_metadata_message]);
// is the torrent already active?
if (m_impl.find_torrent(info_hash))
throw duplicate_torrent();
@ -931,14 +958,14 @@ namespace libtorrent
// the checker thread and store it before starting
// the thread
boost::shared_ptr<torrent> torrent_ptr(
new torrent(m_impl, tracker_url, info_hash, save_path, m_impl.m_listen_interface));
new torrent(m_impl, tracker_url, info_hash, save_path
, m_impl.m_listen_interface));
m_impl.m_torrents.insert(
std::make_pair(info_hash, torrent_ptr)).first;
return torrent_handle(&m_impl, &m_checker_impl, info_hash);
}
#endif
void session::remove_torrent(const torrent_handle& h)
{

View File

@ -43,10 +43,10 @@ POSSIBILITY OF SUCH DAMAGE.
#endif
#include <boost/lexical_cast.hpp>
#include <boost/date_time/time.hpp>
#include <boost/date_time/gregorian/gregorian_types.hpp>
#include <boost/filesystem/path.hpp>
#include <boost/next_prior.hpp>
#include <boost/bind.hpp>
#ifdef _MSC_VER
#pragma warning(pop)
@ -83,13 +83,6 @@ namespace
}
}
size_type to_seconds(const boost::posix_time::time_duration& d)
{
return d.hours() * 60 * 60
+ d.minutes() * 60
+ d.seconds();
}
void remove_dir(path& p)
{
assert(p.begin() != p.end());
@ -318,6 +311,10 @@ namespace libtorrent
announce_entry e(url);
e.tier = tier;
m_urls.push_back(e);
using boost::bind;
std::sort(m_urls.begin(), m_urls.end(), bind(std::less<int>()
, bind(&announce_entry::tier, _1), bind(&announce_entry::tier, _2)));
}
void torrent_info::add_file(boost::filesystem::path file, size_type size)
@ -456,11 +453,31 @@ namespace libtorrent
dict["announce"] = m_urls.front().url;
if (m_urls.size() > 1)
{
entry trackers(entry::list_t);
entry tier(entry::list_t);
int current_tier = m_urls.front().tier;
for (std::vector<announce_entry>::const_iterator i = m_urls.begin();
i != m_urls.end(); ++i)
{
if (i->tier != current_tier)
{
current_tier = i->tier;
trackers.list().push_back(tier);
tier.list().clear();
}
tier.list().push_back(i->url);
}
trackers.list().push_back(tier);
dict["announce-list"] = trackers;
}
if (!m_comment.empty())
dict["comment"] = m_comment;
dict["creation date"] =
to_seconds(m_creation_date - ptime(date(1970, Jan, 1)));
(m_creation_date - ptime(date(1970, Jan, 1))).total_seconds();
if (!m_created_by.empty())
dict["created by"] = m_created_by;