widl: Split pointer writing into a separate function.

This commit is contained in:
Robert Shearman 2006-02-07 12:30:07 +01:00 committed by Alexandre Julliard
parent 9f0c45b7e7
commit 4c8370f97e
1 changed files with 14 additions and 11 deletions

View File

@ -1097,6 +1097,18 @@ static size_t write_struct_tfs(FILE *file, const type_t *type,
} }
} }
static void write_pointer_only_tfs(FILE *file, const attr_t *attrs, size_t offset, size_t *typeformat_offset)
{
int pointer_type = get_attrv(attrs, ATTR_POINTERTYPE);
if (!pointer_type) pointer_type = RPC_FC_RP;
print_file(file, 2, "0x%x, 0x00, /* %s */\n",
pointer_type,
pointer_type == RPC_FC_FP ? "FC_FP" : (pointer_type == RPC_FC_UP ? "FC_UP" : "FC_RP"));
print_file(file, 2, "NdrShort(0x%x), /* %d */\n", offset, offset);
*typeformat_offset += 4;
}
static size_t write_union_tfs(FILE *file, const attr_t *attrs, static size_t write_union_tfs(FILE *file, const attr_t *attrs,
const type_t *type, const char *name, const type_t *type, const char *name,
size_t *typeformat_offset) size_t *typeformat_offset)
@ -1113,8 +1125,6 @@ static size_t write_typeformatstring_var(FILE *file, int indent,
while (TRUE) while (TRUE)
{ {
int pointer_type;
if (is_string_type(var->attrs, ptr_level, var->array)) if (is_string_type(var->attrs, ptr_level, var->array))
return write_string_tfs(file, var->attrs, type, var->array, var->name, typeformat_offset); return write_string_tfs(file, var->attrs, type, var->array, var->name, typeformat_offset);
@ -1158,7 +1168,7 @@ static size_t write_typeformatstring_var(FILE *file, int indent,
else if (ptr_level == 1 && !type_has_ref(type)) else if (ptr_level == 1 && !type_has_ref(type))
{ {
size_t start_offset = *typeformat_offset; size_t start_offset = *typeformat_offset;
pointer_type = get_attrv(var->attrs, ATTR_POINTERTYPE); int pointer_type = get_attrv(var->attrs, ATTR_POINTERTYPE);
if (!pointer_type) pointer_type = RPC_FC_RP; if (!pointer_type) pointer_type = RPC_FC_RP;
/* special case for pointers to base types */ /* special case for pointers to base types */
@ -1196,16 +1206,9 @@ static size_t write_typeformatstring_var(FILE *file, int indent,
assert(ptr_level > 0); assert(ptr_level > 0);
pointer_type = get_attrv(var->attrs, ATTR_POINTERTYPE);
if (!pointer_type) pointer_type = RPC_FC_RP;
if (file) if (file)
fprintf(file, "/* %2u */\n", *typeformat_offset); fprintf(file, "/* %2u */\n", *typeformat_offset);
print_file(file, indent, "0x%x, 0x00, /* %s */\n", write_pointer_only_tfs(file, var->attrs, 2, typeformat_offset);
pointer_type,
pointer_type == RPC_FC_FP ? "FC_FP" : (pointer_type == RPC_FC_UP ? "FC_UP" : "FC_RP"));
print_file(file, indent, "NdrShort(0x2), /* 2 */\n");
*typeformat_offset += 4;
ptr_level--; ptr_level--;
} }