forked from premiere/premiere-libtorrent
fix python bindings
This commit is contained in:
parent
a0678240f3
commit
49b24d4cd0
|
@ -182,9 +182,14 @@ dict dht_put_item(dht_put_alert const& alert)
|
||||||
void bind_alert()
|
void bind_alert()
|
||||||
{
|
{
|
||||||
using boost::noncopyable;
|
using boost::noncopyable;
|
||||||
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
|
typedef boost::shared_ptr<alert> alert_holder;
|
||||||
|
#else
|
||||||
|
typedef alert alert_holder;
|
||||||
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
scope alert_scope = class_<alert, boost::shared_ptr<alert>, noncopyable >("alert", no_init)
|
scope alert_scope = class_<alert, alert_holder, noncopyable >("alert", no_init)
|
||||||
.def("message", &alert::message)
|
.def("message", &alert::message)
|
||||||
.def("what", &alert::what)
|
.def("what", &alert::what)
|
||||||
.def("category", &alert::category)
|
.def("category", &alert::category)
|
||||||
|
|
|
@ -98,9 +98,8 @@ namespace
|
||||||
#endif // TORRENT_DISABLE_EXTENSIONS
|
#endif // TORRENT_DISABLE_EXTENSIONS
|
||||||
}
|
}
|
||||||
|
|
||||||
void session_set_settings(lt::session& ses, dict const& sett_dict)
|
void make_settings_pack(lt::settings_pack& p, dict const& sett_dict)
|
||||||
{
|
{
|
||||||
settings_pack p;
|
|
||||||
list iterkeys = (list)sett_dict.iterkeys();
|
list iterkeys = (list)sett_dict.iterkeys();
|
||||||
for (int i = 0; i < boost::python::len(iterkeys); i++)
|
for (int i = 0; i < boost::python::len(iterkeys); i++)
|
||||||
{
|
{
|
||||||
|
@ -127,9 +126,20 @@ namespace
|
||||||
}
|
}
|
||||||
TORRENT_CATCH(...) {}
|
TORRENT_CATCH(...) {}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
boost::shared_ptr<lt::session> make_session(boost::python::dict sett, int flags)
|
||||||
|
{
|
||||||
|
settings_pack p;
|
||||||
|
make_settings_pack(p, sett);
|
||||||
|
return boost::make_shared<lt::session>(p, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
void session_set_settings(lt::session& ses, dict const& sett_dict)
|
||||||
|
{
|
||||||
|
settings_pack p;
|
||||||
|
make_settings_pack(p, sett_dict);
|
||||||
allow_threading_guard guard;
|
allow_threading_guard guard;
|
||||||
|
|
||||||
ses.apply_settings(p);
|
ses.apply_settings(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -377,10 +387,21 @@ namespace
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
alert const* wait_for_alert(lt::session& s, int ms)
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
|
boost::shared_ptr<alert const>
|
||||||
|
#else
|
||||||
|
alert const*
|
||||||
|
#endif
|
||||||
|
wait_for_alert(lt::session& s, int ms)
|
||||||
{
|
{
|
||||||
allow_threading_guard guard;
|
allow_threading_guard guard;
|
||||||
return s.wait_for_alert(milliseconds(ms));
|
alert const* a = s.wait_for_alert(milliseconds(ms));
|
||||||
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
|
if (a == NULL) return boost::shared_ptr<alert>();
|
||||||
|
return boost::shared_ptr<alert>(a->clone().release());
|
||||||
|
#else
|
||||||
|
return a;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
list get_torrents(lt::session& s)
|
list get_torrents(lt::session& s)
|
||||||
|
@ -472,7 +493,6 @@ namespace
|
||||||
|
|
||||||
return object(boost::shared_ptr<alert>(a.release()));
|
return object(boost::shared_ptr<alert>(a.release()));
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
list pop_alerts(lt::session& ses)
|
list pop_alerts(lt::session& ses)
|
||||||
{
|
{
|
||||||
|
@ -486,10 +506,28 @@ namespace
|
||||||
for (std::vector<alert*>::iterator i = alerts.begin()
|
for (std::vector<alert*>::iterator i = alerts.begin()
|
||||||
, end(alerts.end()); i != end; ++i)
|
, end(alerts.end()); i != end; ++i)
|
||||||
{
|
{
|
||||||
ret.append(boost::shared_ptr<alert>(*i));
|
ret.append(boost::shared_ptr<alert>((*i)->clone().release()));
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
list pop_alerts(lt::session& ses)
|
||||||
|
{
|
||||||
|
std::vector<alert*> alerts;
|
||||||
|
{
|
||||||
|
allow_threading_guard guard;
|
||||||
|
ses.pop_alerts(&alerts);
|
||||||
|
}
|
||||||
|
|
||||||
|
list ret;
|
||||||
|
for (std::vector<alert*>::iterator i = alerts.begin()
|
||||||
|
, end(alerts.end()); i != end; ++i)
|
||||||
|
{
|
||||||
|
ret.append(boost::python::ptr(*i));
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void load_state(lt::session& ses, entry const& st)
|
void load_state(lt::session& ses, entry const& st)
|
||||||
{
|
{
|
||||||
|
@ -694,10 +732,11 @@ void bind_session()
|
||||||
;
|
;
|
||||||
|
|
||||||
class_<lt::session, boost::noncopyable>("session", no_init)
|
class_<lt::session, boost::noncopyable>("session", no_init)
|
||||||
.def(
|
.def("__init__", boost::python::make_constructor(&make_session
|
||||||
init<settings_pack const&, int>((
|
, default_call_policies()
|
||||||
arg("settings")
|
, (arg("settings")
|
||||||
, arg("flags")=lt::session::start_default_features | lt::session::add_default_plugins))
|
, arg("flags")=lt::session::start_default_features
|
||||||
|
| lt::session::add_default_plugins))
|
||||||
)
|
)
|
||||||
#ifndef TORRENT_NO_DEPRECATE
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
.def(
|
.def(
|
||||||
|
@ -762,7 +801,11 @@ void bind_session()
|
||||||
.def("load_state", &load_state)
|
.def("load_state", &load_state)
|
||||||
.def("save_state", &save_state, (arg("entry"), arg("flags") = 0xffffffff))
|
.def("save_state", &save_state, (arg("entry"), arg("flags") = 0xffffffff))
|
||||||
.def("pop_alerts", &pop_alerts)
|
.def("pop_alerts", &pop_alerts)
|
||||||
.def("wait_for_alert", &wait_for_alert, return_internal_reference<>())
|
.def("wait_for_alert", &wait_for_alert
|
||||||
|
#ifdef TORRENT_NO_DEPRECATE
|
||||||
|
, return_internal_reference<>()
|
||||||
|
#endif
|
||||||
|
)
|
||||||
.def("add_extension", &add_extension)
|
.def("add_extension", &add_extension)
|
||||||
#ifndef TORRENT_NO_DEPRECATE
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
.def("pop_alert", &pop_alert)
|
.def("pop_alert", &pop_alert)
|
||||||
|
@ -869,8 +912,6 @@ void bind_session()
|
||||||
;
|
;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
register_ptr_to_python<boost::shared_ptr<alert> >();
|
|
||||||
|
|
||||||
typedef void (*mem_preset2)(settings_pack& s);
|
typedef void (*mem_preset2)(settings_pack& s);
|
||||||
typedef void (*perf_preset2)(settings_pack& s);
|
typedef void (*perf_preset2)(settings_pack& s);
|
||||||
|
|
||||||
|
|
|
@ -213,12 +213,12 @@ void bind_torrent_info()
|
||||||
|
|
||||||
class_<torrent_info, boost::shared_ptr<torrent_info> >("torrent_info", no_init)
|
class_<torrent_info, boost::shared_ptr<torrent_info> >("torrent_info", no_init)
|
||||||
.def(init<sha1_hash const&, int>((arg("info_hash"), arg("flags") = 0)))
|
.def(init<sha1_hash const&, int>((arg("info_hash"), arg("flags") = 0)))
|
||||||
|
.def("__init__", make_constructor(&bencoded_constructor0))
|
||||||
|
.def("__init__", make_constructor(&bencoded_constructor1))
|
||||||
.def("__init__", make_constructor(&buffer_constructor0))
|
.def("__init__", make_constructor(&buffer_constructor0))
|
||||||
.def("__init__", make_constructor(&buffer_constructor1))
|
.def("__init__", make_constructor(&buffer_constructor1))
|
||||||
.def("__init__", make_constructor(&file_constructor0))
|
.def("__init__", make_constructor(&file_constructor0))
|
||||||
.def("__init__", make_constructor(&file_constructor1))
|
.def("__init__", make_constructor(&file_constructor1))
|
||||||
.def("__init__", make_constructor(&bencoded_constructor0))
|
|
||||||
.def("__init__", make_constructor(&bencoded_constructor1))
|
|
||||||
.def(init<torrent_info const&>((arg("ti"))))
|
.def(init<torrent_info const&>((arg("ti"))))
|
||||||
|
|
||||||
#if TORRENT_USE_WSTRING && !defined TORRENT_NO_DEPRECATE
|
#if TORRENT_USE_WSTRING && !defined TORRENT_NO_DEPRECATE
|
||||||
|
|
|
@ -28,10 +28,7 @@ class test_alerts(unittest.TestCase):
|
||||||
|
|
||||||
def test_alert(self):
|
def test_alert(self):
|
||||||
|
|
||||||
ses = lt.session()
|
ses = lt.session({'alert_mask': lt.alert.category_t.all_categories})
|
||||||
sett = lt.session_settings()
|
|
||||||
sett.alert_mask = 0xffffffff
|
|
||||||
ses.set_alert_mask(0xfffffff)
|
|
||||||
shutil.copy(os.path.join('..', '..', 'test', 'test_torrents', 'base.torrent'), '.')
|
shutil.copy(os.path.join('..', '..', 'test', 'test_torrents', 'base.torrent'), '.')
|
||||||
ti = lt.torrent_info('base.torrent');
|
ti = lt.torrent_info('base.torrent');
|
||||||
h = ses.add_torrent({'ti': ti, 'save_path': '.'})
|
h = ses.add_torrent({'ti': ti, 'save_path': '.'})
|
||||||
|
|
Loading…
Reference in New Issue