mirror of
https://git.deluge-torrent.org/deluge
synced 2025-08-02 22:48:40 +00:00
dbus fallback
This commit is contained in:
parent
f2f1739760
commit
0eb837ba18
1 changed files with 39 additions and 24 deletions
|
@ -18,28 +18,43 @@
|
||||||
# 51 Franklin Street, Fifth Floor
|
# 51 Franklin Street, Fifth Floor
|
||||||
# Boston, MA 02110-1301, USA.
|
# Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
import dbus, dbus.service
|
|
||||||
dbus_version = getattr(dbus, 'version', (0,0,0))
|
# Code for dbus_importing borrowed from Listen (http://listen-project.org)
|
||||||
if dbus_version >= (0,41,0) and dbus_version < (0,80,0):
|
# I couldn't figure out how to use dbus without breaking on versions past
|
||||||
dbus.SessionBus()
|
# 0.80.0. I finally found a solution by reading the source code from the
|
||||||
import dbus.glib
|
# Listen project.
|
||||||
elif dbus_version >= (0,80,0):
|
try:
|
||||||
from dbus.mainloop.glib import DBusGMainLoop
|
import dbus, dbus.service
|
||||||
DBusGMainLoop(set_as_default=True)
|
dbus_version = getattr(dbus, 'version', (0,0,0))
|
||||||
dbus.SessionBus()
|
if dbus_version >= (0,41,0) and dbus_version < (0,80,0):
|
||||||
|
dbus.SessionBus()
|
||||||
|
import dbus.glib
|
||||||
|
elif dbus_version >= (0,80,0):
|
||||||
|
from dbus.mainloop.glib import DBusGMainLoop
|
||||||
|
DBusGMainLoop(set_as_default=True)
|
||||||
|
dbus.SessionBus()
|
||||||
|
else:
|
||||||
|
pass
|
||||||
|
except: dbus_imported = False
|
||||||
|
else: dbus_imported = True
|
||||||
|
|
||||||
|
if dbus_imported:
|
||||||
|
class Manager(dbus.service.Object):
|
||||||
|
def __init__(self, interface, object_path='/org/deluge_torrent/DelugeObject'):
|
||||||
|
self.interface = interface
|
||||||
|
self.bus = dbus.SessionBus()
|
||||||
|
bus_name = dbus.service.BusName("org.deluge_torrent.Deluge", bus=self.bus)
|
||||||
|
dbus.service.Object.__init__(self, bus_name, object_path)
|
||||||
|
|
||||||
|
## external_add_torrent should only be called from outside the class
|
||||||
|
@dbus.service.method('org.deluge_torrent.Deluge')
|
||||||
|
def external_add_torrent(self, torrent_file):
|
||||||
|
self.interface.external_add_torrent(torrent_file)
|
||||||
else:
|
else:
|
||||||
pass
|
# This is a fallback class in case dbus is not available
|
||||||
|
class Manager:
|
||||||
class Manager(dbus.service.Object):
|
def __init__(self, interface, object_path=None):
|
||||||
def __init__(self, interface, object_path='/org/deluge_torrent/DelugeObject'):
|
self.interface = interface
|
||||||
self.interface = interface
|
|
||||||
self.bus = dbus.SessionBus()
|
def external_add_torrent(self, torrent_file):
|
||||||
bus_name = dbus.service.BusName("org.deluge_torrent.Deluge", bus=self.bus)
|
print "I can't do anything with this."
|
||||||
dbus.service.Object.__init__(self, bus_name, object_path)
|
|
||||||
|
|
||||||
## external_add_torrent should only be called from outside the class
|
|
||||||
@dbus.service.method('org.deluge_torrent.Deluge')
|
|
||||||
def external_add_torrent(self, torrent_file):
|
|
||||||
self.interface.external_add_torrent(torrent_file)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue