mirror of
https://gitlab.freedesktop.org/dbus/dbus.git
synced 2025-12-22 16:00:10 +01:00
* python/dbus.py: Add a nicer-but-less-flexible alternate API for handling calls to virtual objects in dbus.ObjectTree. Screw up the argument order to the dbus.Object constructor for consistency with dbus.ObjectTree (and to make dbus_methods optional for future extension) * python/examples/Makefile.am: * python/examples/gconf-proxy-service.py: * python/examples/gconf-proxy-service2.py: Alternate implementation of gconf-proxy-service using the nicer dbus.ObjectTree API. * python/examples/example-service.py: * python/tests/test-server.py Reverse the argument order to deal with dbus.Object constructor changes.
36 lines
1.2 KiB
Python
36 lines
1.2 KiB
Python
import dbus
|
|
|
|
import gtk
|
|
import gconf
|
|
|
|
class GConfService(dbus.Service):
|
|
|
|
def __init__(self):
|
|
dbus.Service.__init__(self, "org.gnome.GConf", dbus.SessionBus())
|
|
|
|
gconf_object_tree = self.GConfObjectTree(self)
|
|
|
|
class GConfObjectTree(dbus.ObjectTree):
|
|
def __init__(self, service):
|
|
dbus.ObjectTree.__init__(self, "/org/gnome/GConf", service)
|
|
|
|
self.client = gconf.client_get_default()
|
|
|
|
def object_method_called(self, object_path, method_name, argument_list):
|
|
print ("Method %s called on GConf key %s" % (method_name, object_path))
|
|
|
|
if "getString" == method_name:
|
|
return self.client.get_string(object_path)
|
|
elif "setString" == method_name:
|
|
self.client.set_int(object_path, argument_list[0])
|
|
elif "getInt" == method_name:
|
|
return self.client.get_int(object_path)
|
|
elif "setInt" == method_name:
|
|
self.client.set_int(object_path, argument_list[0])
|
|
|
|
gconf_service = GConfService()
|
|
|
|
print ("GConf Proxy service started.")
|
|
print ("Run 'gconf-proxy-client.py' to fetch a GConf key through the proxy...")
|
|
|
|
gtk.main()
|