From d85db40b3c478efbfd4da478aa3579892f0c3be3 Mon Sep 17 00:00:00 2001 From: Arvid Norberg Date: Thu, 7 Feb 2013 02:27:39 +0000 Subject: [PATCH] merged python fix from RC_0_16 --- ChangeLog | 1 + bindings/python/src/big_number.cpp | 4 ++++ bindings/python/src/magnet_uri.cpp | 34 ++++++++++++++++++++++++++++++ 3 files changed, 39 insertions(+) diff --git a/ChangeLog b/ChangeLog index c8343c18d..d73283f95 100644 --- a/ChangeLog +++ b/ChangeLog @@ -13,6 +13,7 @@ * fix uTP edge case where udp socket buffer fills up * fix nagle implementation in uTP + * added missing python function: parse_magnet_uri * fix alerts.all_categories in python binding * fix torrent-abort issue which would cancel name lookups of other torrents * make torrent file parser reject invalid path elements earlier diff --git a/bindings/python/src/big_number.cpp b/bindings/python/src/big_number.cpp index d91f02af0..b887bc7a3 100644 --- a/bindings/python/src/big_number.cpp +++ b/bindings/python/src/big_number.cpp @@ -16,6 +16,10 @@ void bind_big_number() .def(self < self) .def(self_ns::str(self)) .def(init()) + .def("clear", &big_number::clear) + .def("is_all_zeros", &big_number::is_all_zeros) + .def("to_string", &big_number::to_string) +// .def("__getitem__", &big_number::opreator[]) ; } diff --git a/bindings/python/src/magnet_uri.cpp b/bindings/python/src/magnet_uri.cpp index 4998c6a02..f292763cd 100644 --- a/bindings/python/src/magnet_uri.cpp +++ b/bindings/python/src/magnet_uri.cpp @@ -35,6 +35,39 @@ namespace { } #endif + dict parse_magnet_uri_wrap(std::string const& uri) + { + add_torrent_params p; + error_code ec; + parse_magnet_uri(uri, p, ec); + + if (ec) throw libtorrent_exception(ec); + + dict ret; + + ret["ti"] = p.ti; + list tracker_list; + for (std::vector::const_iterator i = p.trackers.begin() + , end(p.trackers.end()); i != end; ++i) + tracker_list.append(*i); + ret["trackers"] = tracker_list; + + list nodes_list; + for (std::vector >::const_iterator i = p.dht_nodes.begin() + , end(p.dht_nodes.end()); i != end; ++i) + tracker_list.append(make_tuple(i->first, i->second)); + ret["dht_nodes"] = nodes_list; + ret["info_hash"] = p.info_hash; + ret["name"] = p.name; + ret["save_path"] = p.save_path; + ret["storage_mode"] = p.storage_mode; + ret["url"] = p.url; + ret["uuid"] = p.uuid; + ret["source_feed_url"] = p.source_feed_url; + ret["flags"] = p.flags; + return ret; + } + std::string (*make_magnet_uri0)(torrent_handle const&) = make_magnet_uri; std::string (*make_magnet_uri1)(torrent_info const&) = make_magnet_uri; } @@ -46,5 +79,6 @@ void bind_magnet_uri() #endif def("make_magnet_uri", make_magnet_uri0); def("make_magnet_uri", make_magnet_uri1); + def("parse_magnet_uri", parse_magnet_uri_wrap); }