]> git.ipfire.org Git - thirdparty/vala.git/commitdiff
codegen: Fix params-array in constructor for struct
authorRico Tzschichholz <ricotz@ubuntu.com>
Thu, 15 Jul 2021 10:35:41 +0000 (12:35 +0200)
committerRico Tzschichholz <ricotz@ubuntu.com>
Thu, 15 Jul 2021 10:35:41 +0000 (12:35 +0200)
Fixes https://gitlab.gnome.org/GNOME/vala/issues/1202

codegen/valaccodearraymodule.vala
tests/Makefile.am
tests/structs/constructor-params-array.vala [new file with mode: 0644]

index cb1568d77033796dc0f07c72a0bfd866509d6b9d..770b4a727f784c78102a79cac6de1281a08d6029 100644 (file)
@@ -929,7 +929,7 @@ public class Vala.CCodeArrayModule : CCodeMethodCallModule {
                        cfile.add_include ("stdarg.h");
                }
 
-               if (!(m is CreationMethod)) {
+               if (!(m is CreationMethod) || m.parent_symbol is Struct) {
                        ccode.add_declaration ("va_list", new CCodeVariableDeclarator ("_va_list_%s".printf (get_ccode_name (local))));
                        var vastart = new CCodeFunctionCall (new CCodeIdentifier ("va_start"));
                        vastart.add_argument (new CCodeIdentifier ("_va_list_%s".printf (get_ccode_name (local))));
index ca110d712f5981e221bc70b8c1c1573d22b5b6b5..cb96b0d061b2fa30d390fab75c99d43a40ab0efb 100644 (file)
@@ -343,6 +343,7 @@ TESTS = \
        structs/struct-static-field-initializer.test \
        structs/struct-static-property-initializer.test \
        structs/structs.vala \
+       structs/constructor-params-array.vala \
        structs/constructor-variadic.vala \
        structs/constructor-wrong-name.test \
        structs/default-gtype.vala \
diff --git a/tests/structs/constructor-params-array.vala b/tests/structs/constructor-params-array.vala
new file mode 100644 (file)
index 0000000..585be83
--- /dev/null
@@ -0,0 +1,16 @@
+struct Foo {
+       public string[] sa;
+
+       public Foo (params string[] strv) {
+               assert (strv.length == 3);
+               assert (strv[0] == "foo");
+               assert (strv[1] == "bar");
+               assert (strv[2] == "manam");
+               sa = strv;
+       }
+}
+
+void main () {
+       var foo = Foo ("foo", "bar", "manam");
+       assert (foo.sa[1] == "bar");
+}