1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
"""
Different versions of the Python DBus bindings return different types
to represent integers, strings, lists, etc. Older versions return
builtin Python types: C{int}, C{str}, C{list}, etc. Newer versions
return DBus-specific wrappers: C{Int16}, C{String}, C{Array}, etc.
Failures occur when DBus types are used because bpickle doesn't know
that an C{Int16} is really an C{int} and that an C{Array} is really a
C{list}.
L{install} and L{uninstall} can install and remove extensions that
make bpickle work with DBus types.
"""
import dbus
from landscape.lib import bpickle
def install():
"""Install bpickle extensions for DBus types."""
for type, function in get_dbus_types():
bpickle.dumps_table[type] = function
def uninstall():
"""Uninstall bpickle extensions for DBus types."""
for type, function in get_dbus_types():
del bpickle.dumps_table[type]
def dumps_utf8string(obj):
"""
Convert the specified L{dbus.types.UTF8String} to bpickle's
representation for C{unicode} data.
"""
return "u%s:%s" % (len(obj), obj)
def dumps_double(obj):
"""
Convert a dbus.types.Double into a floating point representation.
"""
return "f%r;" % float(obj)
def get_dbus_types():
"""
Generator yields C{(type, bpickle_function)} for available DBus
types.
"""
for (type_name, function) in [("Boolean", bpickle.dumps_bool),
("Int16", bpickle.dumps_int),
("UInt16", bpickle.dumps_int),
("Int32", bpickle.dumps_int),
("UInt32", bpickle.dumps_int),
("Int64", bpickle.dumps_int),
("UInt64", bpickle.dumps_int),
("Double", dumps_double),
("Array", bpickle.dumps_list),
("Dictionary", bpickle.dumps_dict),
("String", bpickle.dumps_unicode),
("UTF8String", dumps_utf8string),]:
type = getattr(dbus.types, type_name, None)
if type is not None:
yield type, function
|