diff --git a/vlib/v/gen/c/cgen.v b/vlib/v/gen/c/cgen.v index 0e15b0cc10..0cf4c8a8a4 100644 --- a/vlib/v/gen/c/cgen.v +++ b/vlib/v/gen/c/cgen.v @@ -7353,6 +7353,11 @@ fn (mut g Gen) type_default(typ_ ast.Type) string { } else { '{' } + $if windows { + if !typ.has_flag(.shared_f) && g.inside_global_decl { + init_str = '(${g.typ(typ)}){' + } + } if sym.language in [.c, .v] { for field in info.fields { field_sym := g.table.sym(field.typ) diff --git a/vlib/v/gen/c/testdata/global_initializer.c.must_have b/vlib/v/gen/c/testdata/global_initializer_nix.c.must_have similarity index 100% rename from vlib/v/gen/c/testdata/global_initializer.c.must_have rename to vlib/v/gen/c/testdata/global_initializer_nix.c.must_have diff --git a/vlib/v/gen/c/testdata/global_initializer.vv b/vlib/v/gen/c/testdata/global_initializer_nix.vv similarity index 100% rename from vlib/v/gen/c/testdata/global_initializer.vv rename to vlib/v/gen/c/testdata/global_initializer_nix.vv diff --git a/vlib/v/gen/c/testdata/global_initializer_windows.must_have b/vlib/v/gen/c/testdata/global_initializer_windows.must_have new file mode 100644 index 0000000000..383d042d59 --- /dev/null +++ b/vlib/v/gen/c/testdata/global_initializer_windows.must_have @@ -0,0 +1 @@ +Array_fixed_main__Foo_3 g_test_foo = {(main__Foo){.foo = 0,.bar = (main___VAnonStruct1){.a = 0,.b = 0,},}, (main__Foo){.foo = 0,.bar = (main___VAnonStruct1){.a = 0,.b = 0,},}, (main__Foo){.foo = 0,.bar = (main___VAnonStruct1){.a = 0,.b = 0,},}}; // global4 \ No newline at end of file diff --git a/vlib/v/gen/c/testdata/global_initializer_windows.vv b/vlib/v/gen/c/testdata/global_initializer_windows.vv new file mode 100644 index 0000000000..6f2ad48dc3 --- /dev/null +++ b/vlib/v/gen/c/testdata/global_initializer_windows.vv @@ -0,0 +1,11 @@ +// vtest vflags: -enable-globals + +struct Foo { + foo int + bar struct { + a int + b f64 + } +} + +__global g_test_foo = [3]Foo{} diff --git a/vlib/v/tests/global_init_test.v b/vlib/v/tests/global_init_test.v new file mode 100644 index 0000000000..675b1d8a20 --- /dev/null +++ b/vlib/v/tests/global_init_test.v @@ -0,0 +1,23 @@ +@[has_globals] +module main + +interface IGameObject { +mut: + name string +} + +struct Game { +mut: + objects []IGameObject + delete_objects []IGameObject +} + +__global ( + game Game +) + +fn test_main() { + println('game: ${game}') + assert game.objects.len == 0 + assert game.delete_objects.len == 0 +}