[vala] D-Bus: Support Cancellable parameter in GDBus clients
- From: Jürg Billeter <juergbi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala] D-Bus: Support Cancellable parameter in GDBus clients
- Date: Sat, 23 Oct 2010 19:23:05 +0000 (UTC)
commit f815f16434555ec8f56d0b95abf2aeea786483aa
Author: Jürg Billeter <j bitron ch>
Date: Wed Oct 20 16:51:11 2010 +0200
D-Bus: Support Cancellable parameter in GDBus clients
codegen/valagdbusclientmodule.vala | 11 +++++++++--
codegen/valagdbusservermodule.vala | 17 +++++++++++++++++
tests/dbus/async-errors.test | 14 ++++++++++++++
tests/dbus/errors.test | 12 ++++++++++++
4 files changed, 52 insertions(+), 2 deletions(-)
---
diff --git a/codegen/valagdbusclientmodule.vala b/codegen/valagdbusclientmodule.vala
index 34d158d..65bebfc 100644
--- a/codegen/valagdbusclientmodule.vala
+++ b/codegen/valagdbusclientmodule.vala
@@ -459,6 +459,8 @@ public class Vala.GDBusClientModule : GDBusModule {
ccode.add_declaration ("GUnixFDList", new CCodeVariableDeclarator ("*_fd_list"));
ccode.add_expression (new CCodeAssignment (new CCodeIdentifier ("_fd_list"), new CCodeFunctionCall (new CCodeIdentifier ("g_unix_fd_list_new"))));
+ CCodeExpression cancellable = new CCodeConstant ("NULL");
+
foreach (FormalParameter param in m.get_parameters ()) {
if (param.direction == ParameterDirection.IN) {
CCodeExpression expr = new CCodeIdentifier (param.name);
@@ -466,6 +468,11 @@ public class Vala.GDBusClientModule : GDBusModule {
expr = new CCodeUnaryExpression (CCodeUnaryOperator.POINTER_INDIRECTION, expr);
}
+ if (param.variable_type is ObjectType && param.variable_type.data_type.get_full_name () == "GLib.Cancellable") {
+ cancellable = expr;
+ continue;
+ }
+
send_dbus_value (param.variable_type, new CCodeIdentifier ("_arguments_builder"), expr, param);
}
}
@@ -497,7 +504,7 @@ public class Vala.GDBusClientModule : GDBusModule {
ccall.add_argument (new CCodeConstant ("G_DBUS_SEND_MESSAGE_FLAGS_NONE"));
ccall.add_argument (timeout);
ccall.add_argument (new CCodeConstant ("NULL"));
- ccall.add_argument (new CCodeConstant ("NULL"));
+ ccall.add_argument (cancellable);
ccall.add_argument (new CCodeIdentifier ("error"));
ccode.add_expression (new CCodeAssignment (new CCodeIdentifier ("_reply_message"), ccall));
} else if (call_type == CallType.NO_REPLY) {
@@ -520,7 +527,7 @@ public class Vala.GDBusClientModule : GDBusModule {
ccall.add_argument (new CCodeConstant ("G_DBUS_SEND_MESSAGE_FLAGS_NONE"));
ccall.add_argument (timeout);
ccall.add_argument (new CCodeConstant ("NULL"));
- ccall.add_argument (new CCodeConstant ("NULL"));
+ ccall.add_argument (cancellable);
// use wrapper as source_object wouldn't be correct otherwise
ccall.add_argument (new CCodeIdentifier (generate_async_callback_wrapper ()));
diff --git a/codegen/valagdbusservermodule.vala b/codegen/valagdbusservermodule.vala
index 10fbe54..9cb79c3 100644
--- a/codegen/valagdbusservermodule.vala
+++ b/codegen/valagdbusservermodule.vala
@@ -116,6 +116,10 @@ public class Vala.GDBusServerModule : GDBusClientModule {
continue;
}
+ if (param.variable_type is ObjectType && param.variable_type.data_type.get_full_name () == "GLib.Cancellable") {
+ continue;
+ }
+
var owned_type = param.variable_type.copy ();
owned_type.value_owned = true;
@@ -139,6 +143,11 @@ public class Vala.GDBusServerModule : GDBusClientModule {
foreach (FormalParameter param in m.get_parameters ()) {
if (param.direction == ParameterDirection.IN && !ready) {
+ if (param.variable_type is ObjectType && param.variable_type.data_type.get_full_name () == "GLib.Cancellable") {
+ ccall.add_argument (new CCodeConstant ("NULL"));
+ continue;
+ }
+
var st = param.variable_type.data_type as Struct;
if (st != null && !st.is_simple_type ()) {
ccall.add_argument (new CCodeUnaryExpression (CCodeUnaryOperator.ADDRESS_OF, new CCodeIdentifier (param.name)));
@@ -330,6 +339,10 @@ public class Vala.GDBusServerModule : GDBusClientModule {
foreach (FormalParameter param in m.get_parameters ()) {
if ((param.direction == ParameterDirection.IN && !ready) ||
(param.direction == ParameterDirection.OUT && !no_reply && (!m.coroutine || ready))) {
+ if (param.variable_type is ObjectType && param.variable_type.data_type.get_full_name () == "GLib.Cancellable") {
+ continue;
+ }
+
var owned_type = param.variable_type.copy ();
owned_type.value_owned = true;
@@ -790,6 +803,10 @@ public class Vala.GDBusServerModule : GDBusClientModule {
var out_args_info = new CCodeInitializerList ();
foreach (FormalParameter param in m.get_parameters ()) {
+ if (param.variable_type is ObjectType && param.variable_type.data_type.get_full_name () == "GLib.Cancellable") {
+ continue;
+ }
+
var info = new CCodeInitializerList ();
info.append (new CCodeConstant ("-1"));
info.append (new CCodeConstant ("\"%s\"".printf (param.name)));
diff --git a/tests/dbus/async-errors.test b/tests/dbus/async-errors.test
index c3c669f..4c9483f 100644
--- a/tests/dbus/async-errors.test
+++ b/tests/dbus/async-errors.test
@@ -8,6 +8,7 @@ interface Test : Object {
public abstract async void test_void () throws Error;
public abstract async int test_int (int i, out int j) throws Error;
public abstract async string test_string (string s, out string t) throws Error;
+ public abstract async void test_cancellable (Cancellable? cancellable = null) throws Error;
}
MainLoop main_loop;
@@ -35,6 +36,14 @@ async void run () {
} catch {
}
+ try {
+ var cancellable = new Cancellable ();
+ cancellable.cancel ();
+ yield test.test_cancellable (cancellable);
+ assert_not_reached ();
+ } catch {
+ }
+
main_loop.quit ();
}
@@ -67,6 +76,11 @@ class Test : Object {
yield;
throw new IOError.FAILED ("Operation failed");
}
+
+ public async void test_cancellable (Cancellable? cancellable = null) throws Error {
+ Idle.add (test_cancellable.callback);
+ yield;
+ }
}
MainLoop main_loop;
diff --git a/tests/dbus/errors.test b/tests/dbus/errors.test
index 826aeb3..9088fb4 100644
--- a/tests/dbus/errors.test
+++ b/tests/dbus/errors.test
@@ -8,6 +8,7 @@ interface Test : Object {
public abstract void test_void () throws Error;
public abstract int test_int (int i, out int j) throws Error;
public abstract string test_string (string s, out string t) throws Error;
+ public abstract void test_cancellable (Cancellable? cancellable = null) throws Error;
}
void main () {
@@ -35,6 +36,14 @@ void main () {
assert_not_reached ();
} catch {
}
+
+ try {
+ var cancellable = new Cancellable ();
+ cancellable.cancel ();
+ test.test_cancellable (cancellable);
+ assert_not_reached ();
+ } catch {
+ }
}
Program: server
@@ -52,6 +61,9 @@ class Test : Object {
public string test_string (string s, out string t) throws Error {
throw new IOError.FAILED ("Operation failed");
}
+
+ public void test_cancellable (Cancellable? cancellable = null) throws Error {
+ }
}
MainLoop main_loop;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]