diff options
author | John (J5) Palmieri <johnp@redhat.com> | 2005-05-01 19:34:58 +0000 |
---|---|---|
committer | John (J5) Palmieri <johnp@redhat.com> | 2005-05-01 19:34:58 +0000 |
commit | ac3b8d0a70f5fee2595ac37182354986f657d333 (patch) | |
tree | bdca3bd202fe5a879ab1f2e9ce7cea420718572b /python/decorators.py | |
parent | eb8bfeb8f2f5c4e6b09043988fc9ab9d178e5276 (diff) |
* python/dbus_bindings.pyx.in:
- added new type classes for hinting to the marashaler what type
to send over the wire
- added int16 and uint16 marshalers
- Fixed a bug in the type constants that caused int32 to go out
as uint16 over the wire
* python/dbus.py: split up into different files and renamed _dbus.py
* python/__init__.py, python/_util.py, python/decorators.py,
python/exceptions.py, python/proxies.py, python/services.py,
python/types.py: new files split off from dbus.py
* python/Makefile.am: Add new files, remove dbus.py and
install all python files to <python module dir>/dbus
* python/examples/*: Added #!/usr/bin/env python to the top of
every example. Patch provided by Tatavarty Kalyan
Diffstat (limited to 'python/decorators.py')
-rw-r--r-- | python/decorators.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/python/decorators.py b/python/decorators.py new file mode 100644 index 00000000..4be6e207 --- /dev/null +++ b/python/decorators.py @@ -0,0 +1,37 @@ +import _util +import inspect + + +def method(dbus_interface): + _util._validate_interface_or_name(dbus_interface) + + def decorator(func): + func._dbus_is_method = True + func._dbus_interface = dbus_interface + func._dbus_args = inspect.getargspec(func)[0] + func._dbus_args.pop(0) + return func + + return decorator + +def signal(dbus_interface): + _util._validate_interface_or_name(dbus_interface) + def decorator(func): + def emit_signal(self, *args, **keywords): + func(self, *args, **keywords) + message = dbus_bindings.Signal(self._object_path, dbus_interface, func.__name__) + iter = message.get_iter(True) + for arg in args: + iter.append(arg) + + self._connection.send(message) + + emit_signal._dbus_is_signal = True + emit_signal._dbus_interface = dbus_interface + emit_signal.__name__ = func.__name__ + emit_signal._dbus_args = inspect.getargspec(func)[0] + emit_signal._dbus_args.pop(0) + return emit_signal + + return decorator + |