widl: Output sizing information for arrays in the generated marshaling code.
diff --git a/tools/widl/typegen.c b/tools/widl/typegen.c
index 1346729..33eecbc 100644
--- a/tools/widl/typegen.c
+++ b/tools/widl/typegen.c
@@ -448,11 +448,31 @@
                     if (!has_length && !has_size)
                         array_type = "FixedArray";
                     else if (has_length && !has_size)
+                    {
+                        print_file(file, indent, "_StubMsg.Offset = (unsigned long)0;\n"); /* FIXME */
+                        print_file(file, indent, "_StubMsg.ActualCount = (unsigned long)");
+                        write_expr(file, length_is, 1);
+                        fprintf(file, ";\n\n");
                         array_type = "VaryingArray";
+                    }
                     else if (!has_length && has_size)
+                    {
+                        print_file(file, indent, "_StubMsg.MaxCount = (unsigned long)");
+                        write_expr(file, size_is ? size_is : var->array, 1);
+                        fprintf(file, ";\n\n");
                         array_type = "ConformantArray";
+                    }
                     else
+                    {
+                        print_file(file, indent, "_StubMsg.MaxCount = (unsigned long)");
+                        write_expr(file, size_is ? size_is : var->array, 1);
+                        fprintf(file, ";\n");
+                        print_file(file, indent, "_StubMsg.Offset = (unsigned long)0;\n"); /* FIXME */
+                        print_file(file, indent, "_StubMsg.ActualCount = (unsigned long)");
+                        write_expr(file, length_is, 1);
+                        fprintf(file, ";\n\n");
                         array_type = "ConformantVaryingArray";
+                    }
                 }
 
                 print_file(file, indent,