dbus/python dbus.py,1.5,1.6

Seth Nickell seth at pdx.freedesktop.org
Sat May 29 19:26:50 PDT 2004


Update of /cvs/dbus/dbus/python
In directory pdx:/tmp/cvs-serv28412/python

Modified Files:
	dbus.py 
Log Message:
2004-05-29  Seth Nickell  <seth at 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.
	


Index: dbus.py
===================================================================
RCS file: /cvs/dbus/dbus/python/dbus.py,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -d -r1.5 -r1.6
--- a/dbus.py	29 May 2004 22:37:13 -0000	1.5
+++ b/dbus.py	30 May 2004 02:26:48 -0000	1.6
@@ -240,7 +240,7 @@
 
     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 @@
             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.
 




More information about the dbus-commit mailing list