diff options
| author | Seth Nickell <seth@gnome.org> | 2003-09-26 10:27:59 +0000 | 
|---|---|---|
| committer | Seth Nickell <seth@gnome.org> | 2003-09-26 10:27:59 +0000 | 
| commit | c5cf3857b114d0008a6d8191abf389064b5a66fc (patch) | |
| tree | e89751f02010ba858424769d2cb9f501ea51099c /python/dbus.py | |
| parent | 9f2ff915a181585ddeaca079a7cfe057d10a3aed (diff) | |
2003-09-26  Seth Nickell  <seth@gnome.org>
	* python/dbus.py:
	* python/examples/example-signals.py:
	Start implementing some notions of signals. The API
	is really terrible, but they sort of work (with the
	exception of being able to filter by service, and to
	transmit signals *as* a particular service). Need to
	figure out how to make messages come from the service
	we registered :-(
	* python/dbus_bindings.pyx.in:
	Removed duplicate message_handler callbacks.
Diffstat (limited to 'python/dbus.py')
| -rw-r--r-- | python/dbus.py | 55 | 
1 files changed, 52 insertions, 3 deletions
| diff --git a/python/dbus.py b/python/dbus.py index d09b3fec..c7ab5dd3 100644 --- a/python/dbus.py +++ b/python/dbus.py @@ -56,6 +56,8 @@ class Bus:      def __init__(self, bus_type=TYPE_SESSION, glib_mainloop=True):          self._connection = dbus_bindings.bus_get(bus_type) +        self._connection.add_filter(self._signal_func) +        self._match_rule_to_receivers = { }          if (glib_mainloop):              self._connection.setup_with_g_main() @@ -65,10 +67,46 @@ class Bus:          """          return RemoteService(self._connection, service_name) +    def add_signal_receiver(self, receiver, interface=None, service=None, path=None): +        match_rule = self._get_match_rule(interface, service, path) +         +        if (not self._match_rule_to_receivers.has_key(match_rule)): +            self._match_rule_to_receivers[match_rule] = [ ] +        self._match_rule_to_receivers[match_rule].append(receiver) +         +        dbus_bindings.bus_add_match(self._connection, match_rule) +              def get_connection(self):          """Get the dbus_bindings.Connection object associated with this Bus"""          return self._connection +    def _get_match_rule(self, interface, service, path): +##        if (interface): +##            match_rule = match_rule + ",interface='%s'" % (interface) +##        if (service): +##            match_rule = match_rule + ",service='%s'" % (service) +##        if (path): +##            match_rule = match_rule + ",path='%s'" % (path) +        # FIXME: use the service here too!!! +        return "type='signal',interface='%s',path='%s'" % (interface, path) +     +    def _signal_func(self, connection, message): +        if (message.get_type() != dbus_bindings.MESSAGE_TYPE_SIGNAL): +            return +         +        interface = message.get_interface() +        service   = message.get_sender() +        path      = message.get_path() +        member    = message.get_member() + +        match_rule = self._get_match_rule(interface, service, path) + +        if (self._match_rule_to_receivers.has_key(match_rule)): +            receivers = self._match_rule_to_receivers[match_rule] +            args = [interface, member, service, path] +            for receiver in receivers: +                receiver(*args) +          class RemoteObject:      """A remote Object. @@ -144,6 +182,10 @@ class Service:          """Get the Bus this Service is on"""          return self._bus +    def get_service_name(self): +        """Get the name of this service""" +        return self._service_name +  class Object:      """A base class for exporting your own Objects across the Bus. @@ -161,6 +203,12 @@ class Object:          self._connection.register_object_path(object_path, self._unregister_cb, self._message_cb) +    def broadcast_signal(self, interface, signal_name): +        message = dbus_bindings.Signal(self._object_path, interface, signal_name) +        #FIXME: need to set_sender, but it always disconnects when we do this +        #message.set_sender(self._service.get_service_name()) +        self._connection.send(message) +      def _unregister_cb(self, connection):          print ("Unregister") @@ -173,9 +221,10 @@ class Object:              retval = target_method(*args)          except Exception, e:              if e.__module__ == '__main__': -                error_name = e.__class__ +                # FIXME: is it right to use .__name__ here? +                error_name = e.__class__.__name__              else: -                error_name = e.__module__ + '.' + str(e.__class__) +                error_name = e.__module__ + '.' + str(e.__class__.__name__)              error_contents = str(e)              reply = dbus_bindings.Error(message, error_name, error_contents)          else: @@ -193,7 +242,7 @@ class Object:                  print ('WARNING: registering DBus Object methods, already have a method named %s' % (method.__name__))              method_dict[method.__name__] = method          return method_dict -         +  class RemoteService:      """A remote service providing objects. | 
