2004-05-29 Seth Nickell <seth@gnome.org>
authorSeth Nickell <seth@gnome.org>
Sun, 30 May 2004 02:26:48 +0000 (02:26 +0000)
committerSeth Nickell <seth@gnome.org>
Sun, 30 May 2004 02:26:48 +0000 (02:26 +0000)
* 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.

ChangeLog
python/dbus.py
python/examples/Makefile.am
python/examples/gconf-proxy-client.py [new file with mode: 0644]
python/examples/gconf-proxy-service.py [new file with mode: 0644]

index d9207ac..de69198 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,6 +1,21 @@
 2004-05-29  Seth Nickell  <seth@gnome.org>
 
        * 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.
+       
+2004-05-29  Seth Nickell  <seth@gnome.org>
+
+       * python/dbus.py:
        * python/examples/example-client.py:
        * python/examples/example-service.py:
        * python/examples/list-system-services.py:
index 583c554..2c405c7 100644 (file)
@@ -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.
 
index 743c520..8eab412 100644 (file)
@@ -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 (file)
index 0000000..f9c6309
--- /dev/null
@@ -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 (file)
index 0000000..b5842e8
--- /dev/null
@@ -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()