From 2e8a06bb8fa49b5b2163450654819fd26593cee4 Mon Sep 17 00:00:00 2001 From: Seth Nickell Date: Sun, 30 May 2004 02:26:48 +0000 Subject: 2004-05-29 Seth Nickell * python/dbus.py: Add ObjectTree class which allows implementation of trees of "virtual" objects. Basically the python wrapper for "register_fallback". * python/examples/Makefile.am * python/examples/gconf-proxy-client.py: * python/examples/gconf-proxy-service.py: Implement a simple GConf proxy service that supports get/set on string and int GConf keys using the ObjectTree. --- python/dbus.py | 52 +++++++++++++++++++++++++++++++++- python/examples/Makefile.am | 2 ++ python/examples/gconf-proxy-client.py | 11 +++++++ python/examples/gconf-proxy-service.py | 48 +++++++++++++++++++++++++++++++ 4 files changed, 112 insertions(+), 1 deletion(-) create mode 100644 python/examples/gconf-proxy-client.py create mode 100644 python/examples/gconf-proxy-service.py (limited to 'python') diff --git a/python/dbus.py b/python/dbus.py index 583c5548..2c405c73 100644 --- a/python/dbus.py +++ b/python/dbus.py @@ -240,7 +240,7 @@ class Object: def _unregister_cb(self, connection): print ("Unregister") - + def _message_cb(self, connection, message): target_method_name = message.get_member() target_method = self._method_name_to_method[target_method_name] @@ -272,6 +272,56 @@ class Object: method_dict[method.__name__] = method return method_dict +class ObjectTree: + """An object tree allows you to register a handler for a tree of object paths. + This means that literal Python objects do not need to be created for each object + over the bus, but you can have a virtual tree of objects handled by a single + Python object. + """ + + def __init__(self, base_path, service): + self._base_path = base_path + self._service = service + self._bus = service.get_bus() + self._connection = self._bus.get_connection() + + self._connection.register_fallback(base_path, self._unregister_cb, self._message_cb) + + def object_method_called(self, object_path, method_name, argument_list): + """Override this method. Called with, object_path, the relative path of the object + under the base_path, the name of the method invoked, and a list of arguments + """ + raise NotImplementedException, "object_method_called() must be overriden" + + def _unregister_cb(self, connection): + print ("Unregister") + + def _message_cb(self, connection, message): + target_object_full_path = message.get_path() + assert(self._base_path == target_object_full_path[:len(self._base_path)]) + target_object_path = target_object_full_path[len(self._base_path):] + + target_method_name = message.get_member() + args = message.get_args_list() + + try: + retval = self.object_method_called(target_object_path, target_method_name, args) + except Exception, e: + if e.__module__ == '__main__': + # FIXME: is it right to use .__name__ here? + error_name = e.__class__.__name__ + else: + error_name = e.__module__ + '.' + str(e.__class__.__name__) + error_contents = str(e) + reply = dbus_bindings.Error(message, error_name, error_contents) + else: + reply = dbus_bindings.MethodReturn(message) + if retval != None: + iter = reply.get_iter() + iter.append(retval) + + self._connection.send(reply) + class RemoteService: """A remote service providing objects. diff --git a/python/examples/Makefile.am b/python/examples/Makefile.am index 743c520e..8eab412e 100644 --- a/python/examples/Makefile.am +++ b/python/examples/Makefile.am @@ -4,6 +4,8 @@ EXTRA_DIST = \ example-service.py \ example-client.py \ example-signal.py \ + gconf-proxy-client.py \ + gconf-proxy-service.py \ list-system-services.py \ $(NULL) diff --git a/python/examples/gconf-proxy-client.py b/python/examples/gconf-proxy-client.py new file mode 100644 index 00000000..f9c63097 --- /dev/null +++ b/python/examples/gconf-proxy-client.py @@ -0,0 +1,11 @@ +import dbus + +gconf_key = "/desktop/gnome/file_views/icon_theme" + +bus = dbus.SessionBus() +gconf_service = bus.get_service("org.gnome.GConf") +gconf_key_object = gconf_service.get_object("/org/gnome/GConf" + gconf_key, "org.gnome.GConf") + +value = gconf_key_object.getString() + +print ("Value of GConf key %s is %s" % (gconf_key, value)) diff --git a/python/examples/gconf-proxy-service.py b/python/examples/gconf-proxy-service.py new file mode 100644 index 00000000..b5842e80 --- /dev/null +++ b/python/examples/gconf-proxy-service.py @@ -0,0 +1,48 @@ +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)) + + return_value = None + + if "getString" == method_name: + assert(len(argument_list) == 0) + return_value = self.client.get_string (object_path) + + elif "setString" == method_name: + assert(len(argument_list) == 1) + self.client.set_string(object_path, argument_list[0]) + + elif "getInt" == method_name: + assert(len(argument_list) == 0) + return_value = self.client.get_int(object_path) + + elif "setInt" == method_name: + assert(len(argument_list) == 1) + self.client.set_int(object_path, argument_list[0]) + + return return_value + +gconf_service = GConfService() + +print ("GConf Proxy service started.") +print ("Run 'gconf-proxy-client.py' to fetch a GConf key through the proxy...") + +gtk.main() -- cgit