[vala/0.46] vala: Set value_type of undefined member-access to avoid further criticals



commit 265af1508e5650c95073b59249eb95f738ced172
Author: Rico Tzschichholz <ricotz ubuntu com>
Date:   Sat May 9 08:17:47 2020 +0200

    vala: Set value_type of undefined member-access to avoid further criticals

 tests/Makefile.am                           | 1 +
 tests/semantic/member-access-undefined.test | 8 ++++++++
 vala/valamemberaccess.vala                  | 1 +
 3 files changed, 10 insertions(+)
---
diff --git a/tests/Makefile.am b/tests/Makefile.am
index e82dca58f..e4a79691e 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -798,6 +798,7 @@ TESTS = \
        semantic/member-access-async-callback-invalid.test \
        semantic/member-access-capture-out.test \
        semantic/member-access-protected-invalid.test \
+       semantic/member-access-undefined.test \
        semantic/method-abstract.test \
        semantic/method-abstract-body.test \
        semantic/method-async-ref-parameter.test \
diff --git a/tests/semantic/member-access-undefined.test b/tests/semantic/member-access-undefined.test
new file mode 100644
index 000000000..905269518
--- /dev/null
+++ b/tests/semantic/member-access-undefined.test
@@ -0,0 +1,8 @@
+Invalid Code
+
+void foo<T> (T actual) {
+}
+
+void main () {
+       foo (undefined);
+}
diff --git a/vala/valamemberaccess.vala b/vala/valamemberaccess.vala
index 2cb9c5781..58caf2edd 100644
--- a/vala/valamemberaccess.vala
+++ b/vala/valamemberaccess.vala
@@ -489,6 +489,7 @@ public class Vala.MemberAccess : Expression {
                        }
 
                        Report.error (source_reference, "The name `%s' does not exist in the context of 
`%s'".printf (member_name, base_type_name));
+                       value_type = new InvalidType ();
                        return false;
                } else if (symbol_reference.error) {
                        //ignore previous error


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]