Skip to content

Commit

Permalink
Merge pull request #608 from aldenml/python-missing-api
Browse files Browse the repository at this point in the history
Missing alert categories and support for dht_get_peers_reply_alert in python binding
  • Loading branch information
arvidn committed Apr 11, 2016
2 parents 2921caf + 4292cfb commit 3099bfd
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 1 deletion.
4 changes: 4 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
1.1.1 release

* Added missing alert categories in python binding
* Added dht_get_peers_reply_alert alert in python binding

1.1.0 release

Expand Down
29 changes: 29 additions & 0 deletions bindings/python/src/alert.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,22 @@ dict session_stats_values(session_stats_alert const& alert)
return d;
}

list dht_get_peers_reply_alert_peers(dht_get_peers_reply_alert const& a)
{
list result;

std::vector<tcp::endpoint> v;
a.peers(v);

for (std::vector<tcp::endpoint>::const_iterator i = v.begin();
i != v.end(); ++i)
{
result.append(endpoint_to_tuple(*i));
}

return result;
}

void bind_alert()
{
using boost::noncopyable;
Expand Down Expand Up @@ -239,10 +255,16 @@ void bind_alert()
.value("progress_notification", alert::progress_notification)
.value("ip_block_notification", alert::ip_block_notification)
.value("performance_warning", alert::performance_warning)
.value("dht_notification", alert::dht_notification)
.value("stats_notification", alert::stats_notification)
.value("session_log_notification", alert::session_log_notification)
.value("torrent_log_notification", alert::torrent_log_notification)
.value("peer_log_notification", alert::peer_log_notification)
.value("incoming_request_notification", alert::incoming_request_notification)
.value("dht_log_notification", alert::dht_log_notification)
.value("dht_operation_notification", alert::dht_operation_notification)
.value("port_mapping_log_notification", alert::port_mapping_log_notification)
.value("picker_log_notification", alert::picker_log_notification)
// deliberately not INT_MAX. Arch linux crash while throwing an exception
.value("all_categories", (alert::category_t)0xfffffff)
;
Expand Down Expand Up @@ -745,4 +767,11 @@ void bind_alert()
"session_stats_alert", no_init)
.add_property("values", &session_stats_values)
;

class_<dht_get_peers_reply_alert, bases<alert>, noncopyable>(
"dht_get_peers_reply_alert", no_init)
.def_readonly("info_hash", &dht_get_peers_reply_alert::info_hash)
.def("num_peers", &dht_get_peers_reply_alert::num_peers)
.add_property("peers", &dht_get_peers_reply_alert_peers)
;
}
2 changes: 1 addition & 1 deletion include/libtorrent/settings_pack.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -1033,7 +1033,7 @@ namespace libtorrent
//
// ``active_loaded_limit`` is the number of torrents that are allowed
// to be *loaded* at any given time. Note that a torrent can be active
// even though it's not loaded. if an unloaded torrents finds a peer
// even though it's not loaded. If an unloaded torrents finds a peer
// that wants to access it, the torrent will be loaded on demand,
// using a user-supplied callback function. If the feature of
// unloading torrents is not enabled, this setting have no effect. If
Expand Down

0 comments on commit 3099bfd

Please sign in to comment.