]> git.ipfire.org Git - thirdparty/vala.git/commitdiff
vala: Don't allow "resize" invocation on variable with unowned array type
authorRico Tzschichholz <ricotz@ubuntu.com>
Fri, 3 Jul 2020 17:33:41 +0000 (19:33 +0200)
committerRico Tzschichholz <ricotz@ubuntu.com>
Sun, 26 Jul 2020 08:38:26 +0000 (10:38 +0200)
Fixes https://gitlab.gnome.org/GNOME/vala/issues/928

tests/Makefile.am
tests/arrays/resize-unowned-invalid-2.test [new file with mode: 0644]
tests/arrays/resize-unowned-invalid-3.test [new file with mode: 0644]
tests/arrays/resize-unowned-invalid.test [new file with mode: 0644]
tests/arrays/resize.vala [new file with mode: 0644]
vala/valamemberaccess.vala

index 114a2af66a68e8b1af5518514c621d752dde2a0b..ce55ed22b12d8c654d608c49fabc6ccf765ae23d 100644 (file)
@@ -100,6 +100,10 @@ TESTS = \
        arrays/struct-field-initializer.vala \
        arrays/struct-namespaced-initializer.vala \
        arrays/incompatible-integer-elements.test \
+       arrays/resize.vala \
+       arrays/resize-unowned-invalid.test \
+       arrays/resize-unowned-invalid-2.test \
+       arrays/resize-unowned-invalid-3.test \
        arrays/slice-invalid-start.test \
        arrays/slice-invalid-stop.test \
        arrays/slice-no-array.test \
diff --git a/tests/arrays/resize-unowned-invalid-2.test b/tests/arrays/resize-unowned-invalid-2.test
new file mode 100644 (file)
index 0000000..be1ab49
--- /dev/null
@@ -0,0 +1,10 @@
+Invalid Code
+
+void bar (string[] foo) {
+       foo.resize (42);
+}
+
+void main () {
+       var foo = new string[23];
+       bar (foo);
+}
diff --git a/tests/arrays/resize-unowned-invalid-3.test b/tests/arrays/resize-unowned-invalid-3.test
new file mode 100644 (file)
index 0000000..b76d4b7
--- /dev/null
@@ -0,0 +1,9 @@
+Invalid Code
+
+unowned string[] foo;
+
+void main () {
+       var bar = new string[23];
+       foo = bar;
+       foo.resize (42);
+}
diff --git a/tests/arrays/resize-unowned-invalid.test b/tests/arrays/resize-unowned-invalid.test
new file mode 100644 (file)
index 0000000..b9d7aea
--- /dev/null
@@ -0,0 +1,7 @@
+Invalid Code
+
+void main () {
+       var foo = new string[23];
+       unowned string[] bar = foo;
+       bar.resize (42);
+}
diff --git a/tests/arrays/resize.vala b/tests/arrays/resize.vala
new file mode 100644 (file)
index 0000000..0ed1bc1
--- /dev/null
@@ -0,0 +1,29 @@
+void bar (ref string[] foo) {
+       foo.resize (42);
+}
+
+void manam (out string[] foo) {
+       foo = new string[23];
+       foo.resize (42);
+}
+
+string[] boo;
+
+void main () {
+       {
+               var foo = new string[23];
+               foo.resize (42);
+       }
+       {
+               var foo = new string[23];
+               bar (ref foo);
+       }
+       {
+               string[] foo;
+               manam (out foo);
+       }
+       {
+               boo = new string[23];
+               boo.resize (42);
+       }
+}
index 58caf2edd6b5f4cfa75e2c09abc43fd0993f3a60..1c25f5fba3a40c995d45eb9b6d0e456413511f69 100644 (file)
@@ -458,11 +458,15 @@ public class Vala.MemberAccess : Expression {
                                }
                        }
 
-                       if (symbol_reference is ArrayResizeMethod && inner.value_type is ArrayType) {
-                               unowned ArrayType? value_array_type = inner.value_type as ArrayType;
-                               if (value_array_type != null && value_array_type.inline_allocated) {
+                       if (symbol_reference is ArrayResizeMethod && inner.symbol_reference is Variable) {
+                               // require the real type with its original value_owned attritubte
+                               var inner_type = context.analyzer.get_value_type_for_symbol (inner.symbol_reference, true) as ArrayType;
+                               if (inner_type != null && inner_type.inline_allocated) {
                                        Report.error (source_reference, "`resize' is not supported for arrays with fixed length");
                                        error = true;
+                               } else if (inner_type != null && !inner_type.value_owned) {
+                                       Report.error (source_reference, "`resize' is not allowed for unowned array references");
+                                       error = true;
                                }
                        }
                }