Commit fc533ddf authored by Steve Lhomme's avatar Steve Lhomme Committed by Alexandre Julliard

widl: Precompute qualified type names, and use them for C++ interfaces.

This is what MIDL does and avoid mismatching and even fixes some compiling issues. Signed-off-by: 's avatarRémi Bernon <rbernon@codeweavers.com> Signed-off-by: 's avatarJacek Caban <jacek@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent a7805374
...@@ -465,13 +465,13 @@ void write_type_left(FILE *h, const decl_spec_t *ds, enum name_type name_type, i ...@@ -465,13 +465,13 @@ void write_type_left(FILE *h, const decl_spec_t *ds, enum name_type name_type, i
case TYPE_INTERFACE: case TYPE_INTERFACE:
case TYPE_MODULE: case TYPE_MODULE:
case TYPE_COCLASS: case TYPE_COCLASS:
fprintf(h, "%s", name); fprintf(h, "%s", type_get_qualified_name(t, name_type));
break; break;
case TYPE_RUNTIMECLASS: case TYPE_RUNTIMECLASS:
fprintf(h, "%s", type_get_name(type_runtimeclass_get_default_iface(t), name_type)); fprintf(h, "%s", type_get_name(type_runtimeclass_get_default_iface(t), name_type));
break; break;
case TYPE_DELEGATE: case TYPE_DELEGATE:
fprintf(h, "%s", type_get_name(type_delegate_get_iface(t), name_type)); fprintf(h, "%s", type_get_qualified_name(type_delegate_get_iface(t), name_type));
break; break;
case TYPE_VOID: case TYPE_VOID:
fprintf(h, "void"); fprintf(h, "void");
......
...@@ -2073,9 +2073,15 @@ type_t *reg_type(type_t *type, const char *name, struct namespace *namespace, in ...@@ -2073,9 +2073,15 @@ type_t *reg_type(type_t *type, const char *name, struct namespace *namespace, in
nt = xmalloc(sizeof(struct rtype)); nt = xmalloc(sizeof(struct rtype));
nt->name = name; nt->name = name;
if (is_global_namespace(namespace)) if (is_global_namespace(namespace))
{
type->c_name = name; type->c_name = name;
type->qualified_name = name;
}
else else
{
type->c_name = format_namespace(namespace, "__x_", "_C", name, use_abi_namespace ? "ABI" : NULL); type->c_name = format_namespace(namespace, "__x_", "_C", name, use_abi_namespace ? "ABI" : NULL);
type->qualified_name = format_namespace(namespace, "", "::", name, use_abi_namespace ? "ABI" : NULL);
}
nt->type = type; nt->type = type;
nt->t = t; nt->t = t;
nt->next = namespace->type_hash[hash]; nt->next = namespace->type_hash[hash];
......
...@@ -51,6 +51,7 @@ type_t *make_type(enum type_type type) ...@@ -51,6 +51,7 @@ type_t *make_type(enum type_type type)
t->attrs = NULL; t->attrs = NULL;
t->c_name = NULL; t->c_name = NULL;
t->signature = NULL; t->signature = NULL;
t->qualified_name = NULL;
memset(&t->details, 0, sizeof(t->details)); memset(&t->details, 0, sizeof(t->details));
t->typestring_offset = 0; t->typestring_offset = 0;
t->ptrdesc = 0; t->ptrdesc = 0;
...@@ -91,6 +92,19 @@ const char *type_get_name(const type_t *type, enum name_type name_type) ...@@ -91,6 +92,19 @@ const char *type_get_name(const type_t *type, enum name_type name_type)
return NULL; return NULL;
} }
const char *type_get_qualified_name(const type_t *type, enum name_type name_type)
{
switch(name_type) {
case NAME_DEFAULT:
return type->qualified_name;
case NAME_C:
return type->c_name;
}
assert(0);
return NULL;
}
static size_t append_namespace(char **buf, size_t *len, size_t pos, struct namespace *namespace, const char *separator, const char *abi_prefix) static size_t append_namespace(char **buf, size_t *len, size_t pos, struct namespace *namespace, const char *separator, const char *abi_prefix)
{ {
int nested = namespace && !is_global_namespace(namespace); int nested = namespace && !is_global_namespace(namespace);
...@@ -820,6 +834,7 @@ static void compute_delegate_iface_names(type_t *delegate, type_t *type, typeref ...@@ -820,6 +834,7 @@ static void compute_delegate_iface_names(type_t *delegate, type_t *type, typeref
iface->name = strmake("I%s", delegate->name); iface->name = strmake("I%s", delegate->name);
if (type) iface->c_name = format_parameterized_type_c_name(type, params, "I"); if (type) iface->c_name = format_parameterized_type_c_name(type, params, "I");
else iface->c_name = format_namespace(delegate->namespace, "__x_", "_C", iface->name, use_abi_namespace ? "ABI" : NULL); else iface->c_name = format_namespace(delegate->namespace, "__x_", "_C", iface->name, use_abi_namespace ? "ABI" : NULL);
iface->qualified_name = format_namespace(delegate->namespace, "", "::", iface->name, use_abi_namespace ? "ABI" : NULL);
} }
type_t *type_delegate_declare(char *name, struct namespace *namespace) type_t *type_delegate_declare(char *name, struct namespace *namespace)
......
...@@ -75,6 +75,7 @@ type_t *type_parameterized_type_specialize_declare(type_t *type, typeref_list_t ...@@ -75,6 +75,7 @@ type_t *type_parameterized_type_specialize_declare(type_t *type, typeref_list_t
type_t *type_parameterized_type_specialize_define(type_t *type); type_t *type_parameterized_type_specialize_define(type_t *type);
int type_is_equal(const type_t *type1, const type_t *type2); int type_is_equal(const type_t *type1, const type_t *type2);
const char *type_get_name(const type_t *type, enum name_type name_type); const char *type_get_name(const type_t *type, enum name_type name_type);
const char *type_get_qualified_name(const type_t *type, enum name_type name_type);
char *gen_name(void); char *gen_name(void);
extern int is_attr(const attr_list_t *list, enum attr_type t); extern int is_attr(const attr_list_t *list, enum attr_type t);
......
...@@ -503,6 +503,7 @@ struct _type_t { ...@@ -503,6 +503,7 @@ struct _type_t {
} details; } details;
const char *c_name; const char *c_name;
const char *signature; const char *signature;
const char *qualified_name;
unsigned int typestring_offset; unsigned int typestring_offset;
unsigned int ptrdesc; /* used for complex structs */ unsigned int ptrdesc; /* used for complex structs */
int typelib_idx; int typelib_idx;
......
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