]> git.ipfire.org Git - thirdparty/vala.git/commitdiff
codegen: Pass lambda expression of variable initializer to signal connect
authorRico Tzschichholz <ricotz@ubuntu.com>
Thu, 31 Jan 2019 19:09:07 +0000 (20:09 +0100)
committerRico Tzschichholz <ricotz@ubuntu.com>
Sun, 3 Feb 2019 13:17:36 +0000 (14:17 +0100)
codegen/valagsignalmodule.vala
tests/Makefile.am
tests/objects/signals-lambda-delegate.vala [new file with mode: 0644]

index 3d0d19c2ccc93b329f4d5b4c40d9643544d5fa47..80f02f849ac2ff2103915e86a4c577d79dae6953 100644 (file)
@@ -595,11 +595,14 @@ public class Vala.GSignalModule : GObjectModule {
                string connect_func;
 
                DelegateType? dt = null;
-               var p = handler.symbol_reference as Parameter;
-               if (p != null) {
-                       dt = p.variable_type as DelegateType;
+               if (handler.symbol_reference is Variable) {
+                       dt = ((Variable) handler.symbol_reference).variable_type as DelegateType;
                        if (dt != null && !context.experimental) {
-                               Report.warning (dt.source_reference, "Connecting delegates to signals is experimental");
+                               Report.warning (handler.source_reference, "Connecting delegates to signals is experimental");
+                       }
+                       // Use actual lambda expression if available for proper target/destroy handling
+                       if (((Variable) handler.symbol_reference).initializer is LambdaExpression) {
+                               handler = ((Variable) handler.symbol_reference).initializer;
                        }
                }
                var m = handler.symbol_reference as Method;
index 27f18f030c53606f08ead1af126aa92396b6c753..cfbe1f4a63625e9062f880a6f79540c319d871b1 100644 (file)
@@ -287,6 +287,7 @@ TESTS = \
        objects/signals.vala \
        objects/signals-delegate.vala \
        objects/signals-delegate-parameter.vala \
+       objects/signals-lambda-delegate.vala \
        objects/singleton.vala \
        objects/test-025.vala \
        objects/test-026.vala \
diff --git a/tests/objects/signals-lambda-delegate.vala b/tests/objects/signals-lambda-delegate.vala
new file mode 100644 (file)
index 0000000..5a8a343
--- /dev/null
@@ -0,0 +1,39 @@
+class Foo : Object {
+       public signal void bar (string s);
+       public signal void baz (string s);
+}
+
+delegate void FooFunc (Foo foo, string s);
+
+void main () {
+       var foo = new Foo ();
+       ulong bar_id = 0U;
+       ulong baz_id = 0U;
+       {
+               FooFunc callback = (f,s) => {
+                       assert (s == "bar" || s == "baz");
+
+                       if (s == "bar") {
+                               assert (bar_id > 0U);
+                               f.disconnect (bar_id);
+                               bar_id = 0U;
+                       }
+
+                       if (s == "baz") {
+                               assert (baz_id > 0U);
+                               f.disconnect (baz_id);
+                               baz_id = 0U;
+                       }
+               };
+
+               bar_id = foo.bar.connect (callback);
+               baz_id = foo.baz.connect (callback);
+       }
+       {
+               foo.bar ("bar");
+               assert (bar_id == 0U);
+
+               foo.baz ("baz");
+               assert (baz_id == 0U);
+       }
+}