Commit 0ec617e0 authored by Rob Shearman's avatar Rob Shearman Committed by Alexandre Julliard

widl: Convert assign_stub_out_args to using typegen_detect_type and fix the…

widl: Convert assign_stub_out_args to using typegen_detect_type and fix the non-conformant array case.
parent f6b53be0
......@@ -3900,15 +3900,16 @@ void assign_stub_out_args( FILE *file, int indent, const var_t *func, const char
{
print_file(file, indent, "%s%s", local_var_prefix, var->name);
if (is_context_handle(var->type))
switch (typegen_detect_type(var->type, var->attrs, TDT_IGNORE_STRINGS))
{
case TGT_CTXT_HANDLE_POINTER:
fprintf(file, " = NdrContextHandleInitialize(\n");
print_file(file, indent + 1, "&__frame->_StubMsg,\n");
print_file(file, indent + 1, "(PFORMAT_STRING)&__MIDL_TypeFormatString.Format[%d]);\n",
var->type->typestring_offset);
}
else if (is_array(var->type) &&
type_array_has_conformance(var->type))
break;
case TGT_ARRAY:
if (type_array_has_conformance(var->type))
{
unsigned int size, align = 0;
type_t *type = var->type;
......@@ -3926,7 +3927,9 @@ void assign_stub_out_args( FILE *file, int indent, const var_t *func, const char
fprintf(file, "%u);\n", size);
}
else
{
fprintf(file, " = &%s_W%u;\n", local_var_prefix, i++);
break;
case TGT_POINTER:
fprintf(file, " = &%s_W%u;\n", local_var_prefix, i);
switch (typegen_detect_type(type_pointer_get_ref(var->type), var->attrs, TDT_IGNORE_STRINGS))
{
......@@ -3949,6 +3952,9 @@ void assign_stub_out_args( FILE *file, int indent, const var_t *func, const char
break;
}
i++;
break;
default:
break;
}
sep = 1;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment