From: Luca Bruno Date: Thu, 9 Feb 2012 08:39:10 +0000 (+0100) Subject: Support initializer list for structs that have a base type X-Git-Tag: 0.15.2~13 X-Git-Url: http://git.ipfire.org/gitweb/gitweb.cgi?a=commitdiff_plain;h=998105936f77997e12593b4f48342469a89c3eb6;p=thirdparty%2Fvala.git Support initializer list for structs that have a base type Fixes bug 669580. --- diff --git a/codegen/valaccodebasemodule.vala b/codegen/valaccodebasemodule.vala index 9d7395ed6..866e8b9e2 100644 --- a/codegen/valaccodebasemodule.vala +++ b/codegen/valaccodebasemodule.vala @@ -2313,6 +2313,9 @@ public abstract class Vala.CCodeBaseModule : CodeGenerator { if (list.target_type.data_type is Struct) { /* initializer is used as struct initializer */ var st = (Struct) list.target_type.data_type; + while (st.base_struct != null) { + st = st.base_struct; + } if (list.parent_node is Constant || list.parent_node is Field || list.parent_node is InitializerList) { var clist = new CCodeInitializerList (); diff --git a/tests/Makefile.am b/tests/Makefile.am index c5248d36d..9a64c1d5e 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -84,6 +84,7 @@ TESTS = \ structs/bug660426.vala \ structs/bug661945.vala \ structs/bug667890.vala \ + structs/bug669580.vala \ delegates/delegates.vala \ delegates/bug539166.vala \ delegates/bug595610.vala \ diff --git a/tests/structs/bug669580.vala b/tests/structs/bug669580.vala new file mode 100644 index 000000000..ef1308b15 --- /dev/null +++ b/tests/structs/bug669580.vala @@ -0,0 +1,10 @@ +struct Foo { + int i; +} + +struct Bar : Foo { +} + +void main() { + Bar bar = { 0 }; +} diff --git a/vala/valainitializerlist.vala b/vala/valainitializerlist.vala index b2350aee6..edd98570c 100644 --- a/vala/valainitializerlist.vala +++ b/vala/valainitializerlist.vala @@ -153,6 +153,9 @@ public class Vala.InitializerList : Expression { } else if (target_type.data_type is Struct) { /* initializer is used as struct initializer */ var st = (Struct) target_type.data_type; + while (st.base_struct != null) { + st = st.base_struct; + } var field_it = st.get_fields ().iterator (); foreach (Expression e in get_initializers ()) {