]> git.ipfire.org Git - thirdparty/vala.git/commitdiff
vala: Warn about usage of override to implement abstract interface methods e9c5f4ab09b9ca66241e863b7d333ecc6bb4c38c
authorRico Tzschichholz <ricotz@ubuntu.com>
Sun, 5 Apr 2020 12:45:34 +0000 (14:45 +0200)
committerRico Tzschichholz <ricotz@ubuntu.com>
Sun, 5 Apr 2020 14:08:18 +0000 (16:08 +0200)
Fixes criticals in GAsyncModule.visit_method()

    vala_symbol_get_parent_symbol: assertion 'self != NULL' failed

which were introduced with 12db9b7eeb1f53975010d89839d554b5fcf99831

tests/Makefile.am
tests/objects/interface-abstract-async-override.vala [new file with mode: 0644]
vala/valamethod.vala

index f87bcf2ba3d5d54abd94c5bfec6486156487aac3..cca6a292730e78f006e087ad8fb66066281bf641 100644 (file)
@@ -376,6 +376,7 @@ TESTS = \
        objects/interface-base-access.vala \
        objects/interface-inner-types.vala \
        objects/interfaces.vala \
+       objects/interface-abstract-async-override.vala \
        objects/interface-generics.vala \
        objects/interface-property-base-access.vala \
        objects/interface-property-base-impl.vala \
diff --git a/tests/objects/interface-abstract-async-override.vala b/tests/objects/interface-abstract-async-override.vala
new file mode 100644 (file)
index 0000000..2af7f4b
--- /dev/null
@@ -0,0 +1,23 @@
+interface IFoo : Object {
+       public abstract async int foo ();
+}
+
+class Bar : Object, IFoo {
+       public override async int foo () {
+               return 42;
+       }
+}
+
+MainLoop loop;
+
+void main () {
+       loop = new MainLoop ();
+
+       IFoo bar = new Bar ();
+       bar.foo.begin ((o,r) => {
+               assert (((IFoo) o).foo.end (r) == 42);
+               loop.quit ();
+       });
+       loop.run ();
+}
+
index 81788830905e09fba5ccde4f0aad280ccbdfb617..35e0cc810875e12b8c73e478e2706f58a77ecbfb 100644 (file)
@@ -929,6 +929,9 @@ public class Vala.Method : Subroutine, Callable {
                                Report.error (source_reference, "A struct member `%s' cannot be marked as override, virtual, or abstract".printf (get_full_name ()));
                                return false;
                        }
+               } else if (overrides && base_method == null && base_interface_method != null && base_interface_method.is_abstract) {
+                       Report.warning (source_reference, "`override' not required to implement `abstract' interface method `%s'".printf (base_interface_method.get_full_name ()));
+                       overrides = false;
                } else if (overrides && base_method == null && base_interface_method == null) {
                        Report.error (source_reference, "`%s': no suitable method found to override".printf (get_full_name ()));
                } else if ((is_abstract || is_virtual || overrides) && access == SymbolAccessibility.PRIVATE) {