mirror of
https://gitlab.freedesktop.org/dbus/dbus.git
synced 2025-12-27 20:50:11 +01:00
* python/dbus_bindings.pyx: Tweak 'raise AssertionError' to assert().
Add checking for the end of struct character when marshalling a
struct in MessageIter.append_strict.
* python/examples/example-service.py,
python/examples/gconf-proxy-service.py,
python/examples/gconf-proxy-service2.py: Update to use gobject
mainloop directly rather than appearing to depend on gtk.
* python/test/test-client.py, python/test/test-server.py: Remove
obsolete and broken test scripts for old bindings. We have up to date
and working tests in test/python/.
39 lines
1.3 KiB
Python
39 lines
1.3 KiB
Python
#!/usr/bin/env python
|
|
#FIXME: doesn't work with the new bindings
|
|
import dbus
|
|
|
|
import gobject
|
|
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, message, 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...")
|
|
|
|
mainloop = gobject.MainLoop()
|
|
mainloop.run()
|