widl: Support explicit binding handles.

This commit is contained in:
Robert Shearman 2005-12-12 12:14:03 +01:00 committed by Alexandre Julliard
parent 759e3c9fe3
commit 12159aec96
4 changed files with 98 additions and 2 deletions

View File

@ -124,6 +124,7 @@ static void write_function_stubs(type_t *iface)
{ {
func_t *func = iface->funcs; func_t *func = iface->funcs;
char *implicit_handle = get_attrp(iface->attrs, ATTR_IMPLICIT_HANDLE); char *implicit_handle = get_attrp(iface->attrs, ATTR_IMPLICIT_HANDLE);
int explicit_handle = is_attr(iface->attrs, ATTR_EXPLICIT_HANDLE);
var_t *var; var_t *var;
int method_count = 0; int method_count = 0;
unsigned int proc_offset = 0; unsigned int proc_offset = 0;
@ -132,6 +133,26 @@ static void write_function_stubs(type_t *iface)
while (func) while (func)
{ {
var_t *def = func->def; var_t *def = func->def;
var_t* explicit_handle_var;
/* check for a defined binding handle */
explicit_handle_var = get_explicit_handle_var(func);
if (explicit_handle)
{
if (!explicit_handle_var)
{
error("%s() does not define an explicit binding handle!\n", def->name);
return;
}
}
else if (implicit_handle)
{
if (explicit_handle_var)
{
error("%s() must not define a binding handle!\n", def->name);
return;
}
}
write_type(client, def->type, def, def->tname); write_type(client, def->type, def, def->tname);
fprintf(client, " "); fprintf(client, " ");
@ -157,7 +178,7 @@ static void write_function_stubs(type_t *iface)
fprintf(client, " _RetVal;\n"); fprintf(client, " _RetVal;\n");
} }
if (implicit_handle) if (implicit_handle || explicit_handle_var)
print_client("RPC_BINDING_HANDLE _Handle = 0;\n"); print_client("RPC_BINDING_HANDLE _Handle = 0;\n");
print_client("RPC_MESSAGE _RpcMessage;\n"); print_client("RPC_MESSAGE _RpcMessage;\n");
@ -181,6 +202,11 @@ static void write_function_stubs(type_t *iface)
print_client("_Handle = %s;\n", implicit_handle); print_client("_Handle = %s;\n", implicit_handle);
fprintf(client, "\n"); fprintf(client, "\n");
} }
else if (explicit_handle_var)
{
print_client("_Handle = %s;\n", explicit_handle_var->name);
fprintf(client, "\n");
}
/* emit the message buffer size */ /* emit the message buffer size */
print_client("_StubMsg.BufferLength ="); print_client("_StubMsg.BufferLength =");
@ -191,7 +217,7 @@ static void write_function_stubs(type_t *iface)
indent++; indent++;
print_client("(PMIDL_STUB_MESSAGE)&_StubMsg,\n"); print_client("(PMIDL_STUB_MESSAGE)&_StubMsg,\n");
print_client("_StubMsg.BufferLength,\n"); print_client("_StubMsg.BufferLength,\n");
if (implicit_handle) if (implicit_handle || explicit_handle_var)
print_client("_Handle);\n"); print_client("_Handle);\n");
else else
print_client("%s__MIDL_AutoBindHandle);\n", iface->name); print_client("%s__MIDL_AutoBindHandle);\n", iface->name);

View File

@ -502,6 +502,28 @@ void write_library(const char *name, attr_t *attr) {
fprintf(header, "\n"); fprintf(header, "\n");
} }
var_t* get_explicit_handle_var(func_t* func)
{
var_t* var;
if (!func->args)
return NULL;
var = func->args;
while (NEXT_LINK(var)) var = NEXT_LINK(var);
while (var)
{
if (var->type->type == RPC_FC_IGNORE)
return var;
var = PREV_LINK(var);
}
return NULL;
}
/********** INTERFACES **********/ /********** INTERFACES **********/
int is_object(attr_t *a) int is_object(attr_t *a)
@ -739,10 +761,29 @@ static void write_method_proto(type_t *iface)
static void write_function_proto(type_t *iface) static void write_function_proto(type_t *iface)
{ {
char *implicit_handle = get_attrp(iface->attrs, ATTR_IMPLICIT_HANDLE);
int explicit_handle = is_attr(iface->attrs, ATTR_EXPLICIT_HANDLE);
var_t* explicit_handle_var;
func_t *cur = iface->funcs; func_t *cur = iface->funcs;
while (NEXT_LINK(cur)) cur = NEXT_LINK(cur); while (NEXT_LINK(cur)) cur = NEXT_LINK(cur);
while (cur) { while (cur) {
var_t *def = cur->def; var_t *def = cur->def;
/* check for a defined binding handle */
explicit_handle_var = get_explicit_handle_var(cur);
if (explicit_handle) {
if (!explicit_handle_var) {
error("%s() does not define an explicit binding handle!\n", def->name);
return;
}
} else if (implicit_handle) {
if (explicit_handle_var) {
error("%s() must not define a binding handle!\n", def->name);
return;
}
}
/* FIXME: do we need to handle call_as? */ /* FIXME: do we need to handle call_as? */
write_type(header, def->type, def, def->tname); write_type(header, def->type, def, def->tname);
fprintf(header, " "); fprintf(header, " ");

View File

@ -42,5 +42,6 @@ extern void write_constdef(var_t *v);
extern void write_externdef(var_t *v); extern void write_externdef(var_t *v);
extern void write_library(const char *name, attr_t *attr); extern void write_library(const char *name, attr_t *attr);
extern void write_user_types(void); extern void write_user_types(void);
extern var_t* get_explicit_handle_var(func_t* func);
#endif #endif

View File

@ -89,8 +89,11 @@ static void write_parameters_init(func_t *func)
static void write_function_stubs(type_t *iface) static void write_function_stubs(type_t *iface)
{ {
char *implicit_handle = get_attrp(iface->attrs, ATTR_IMPLICIT_HANDLE);
int explicit_handle = is_attr(iface->attrs, ATTR_EXPLICIT_HANDLE);
func_t *func = iface->funcs; func_t *func = iface->funcs;
var_t *var; var_t *var;
var_t* explicit_handle_var;
unsigned int proc_offset = 0; unsigned int proc_offset = 0;
while (NEXT_LINK(func)) func = NEXT_LINK(func); while (NEXT_LINK(func)) func = NEXT_LINK(func);
@ -98,6 +101,25 @@ static void write_function_stubs(type_t *iface)
{ {
var_t *def = func->def; var_t *def = func->def;
/* check for a defined binding handle */
explicit_handle_var = get_explicit_handle_var(func);
if (explicit_handle)
{
if (!explicit_handle_var)
{
error("%s() does not define an explicit binding handle!\n", def->name);
return;
}
}
else if (implicit_handle)
{
if (explicit_handle_var)
{
error("%s() must not define a binding handle!\n", def->name);
return;
}
}
write_type(server, def->type, def, def->tname); write_type(server, def->type, def, def->tname);
fprintf(server, " __RPC_STUB\n"); fprintf(server, " __RPC_STUB\n");
fprintf(server, "%s_", iface->name); fprintf(server, "%s_", iface->name);
@ -152,6 +174,12 @@ static void write_function_stubs(type_t *iface)
write_parameters_init(func); write_parameters_init(func);
if (explicit_handle_var)
{
print_server("%s = _pRpcMessage->Handle;\n", explicit_handle_var->name);
fprintf(server, "\n");
}
print_server("RpcTryFinally\n"); print_server("RpcTryFinally\n");
print_server("{\n"); print_server("{\n");
indent++; indent++;