diff options
Diffstat (limited to 'python/examples')
-rw-r--r-- | python/examples/Makefile.am | 1 | ||||
-rw-r--r-- | python/examples/example-service.py | 2 | ||||
-rw-r--r-- | python/examples/gconf-proxy-service.py | 42 | ||||
-rw-r--r-- | python/examples/gconf-proxy-service2.py | 36 |
4 files changed, 55 insertions, 26 deletions
diff --git a/python/examples/Makefile.am b/python/examples/Makefile.am index 8eab412e..4a9b8abc 100644 --- a/python/examples/Makefile.am +++ b/python/examples/Makefile.am @@ -6,6 +6,7 @@ EXTRA_DIST = \ example-signal.py \ gconf-proxy-client.py \ gconf-proxy-service.py \ + gconf-proxy-service2.py \ list-system-services.py \ $(NULL) diff --git a/python/examples/example-service.py b/python/examples/example-service.py index ceb7f11d..974f8b1d 100644 --- a/python/examples/example-service.py +++ b/python/examples/example-service.py @@ -5,7 +5,7 @@ import gtk class SomeObject(dbus.Object): def __init__(self, service): - dbus.Object.__init__(self, "/SomeObject", [self.HelloWorld], service) + dbus.Object.__init__(self, "/SomeObject", service, [self.HelloWorld]) def HelloWorld(self, hello_message): print (hello_message) diff --git a/python/examples/gconf-proxy-service.py b/python/examples/gconf-proxy-service.py index b5842e80..76e43ce8 100644 --- a/python/examples/gconf-proxy-service.py +++ b/python/examples/gconf-proxy-service.py @@ -11,35 +11,27 @@ class GConfService(dbus.Service): gconf_object_tree = self.GConfObjectTree(self) class GConfObjectTree(dbus.ObjectTree): - def __init__(self, service): - dbus.ObjectTree.__init__(self, "/org/gnome/GConf", service) + dbus.ObjectTree.__init__(self, "/org/gnome/GConf", service, dbus_methods=[ self.getString, self.setString, self.getInt, self.setInt ]) 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 + def getString(self, object_path): + print ("getString called on GConf key %s" % (object_path)) + return self.client.get_string(object_path) + + def setString(self, object_path, new_value): + print ("setString called on GConf key %s" % (object_path)) + self.client.set_string(object_path, new_value) + + def getInt(self, object_path): + print ("getInt called on GConf key %s" % (object_path)) + return self.client.get_int(object_path) + + def setInt(self, object_path, new_value): + print ("setInt called on GConf key %s" % (object_path)) + self.client.set_int(object_path, new_value) + gconf_service = GConfService() print ("GConf Proxy service started.") diff --git a/python/examples/gconf-proxy-service2.py b/python/examples/gconf-proxy-service2.py new file mode 100644 index 00000000..4cec8605 --- /dev/null +++ b/python/examples/gconf-proxy-service2.py @@ -0,0 +1,36 @@ +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)) + + if "getString" == method_name: + return self.client.get_string(object_path) + elif "setString" == method_name: + self.client.set_int(object_path, argument_list[0]) + elif "getInt" == method_name: + return self.client.get_int(object_path) + elif "setInt" == method_name: + self.client.set_int(object_path, argument_list[0]) + +gconf_service = GConfService() + +print ("GConf Proxy service started.") +print ("Run 'gconf-proxy-client.py' to fetch a GConf key through the proxy...") + +gtk.main() |