winebuild: Allow specifying arguments to stub functions for documentation purposes.
This commit is contained in:
parent
5ac184cad5
commit
2e6f48b730
|
@ -85,7 +85,7 @@ typedef struct
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
unsigned int nb_args;
|
int nb_args;
|
||||||
enum arg_type args[MAX_ARGUMENTS];
|
enum arg_type args[MAX_ARGUMENTS];
|
||||||
} ORD_FUNCTION;
|
} ORD_FUNCTION;
|
||||||
|
|
||||||
|
|
|
@ -237,33 +237,17 @@ static int parse_spec_variable( ORDDEF *odp, DLLSPEC *spec )
|
||||||
|
|
||||||
|
|
||||||
/*******************************************************************
|
/*******************************************************************
|
||||||
* parse_spec_export
|
* parse_spec_arguments
|
||||||
*
|
*
|
||||||
* Parse an exported function definition in a .spec file.
|
* Parse the arguments of an entry point.
|
||||||
*/
|
*/
|
||||||
static int parse_spec_export( ORDDEF *odp, DLLSPEC *spec )
|
static int parse_spec_arguments( ORDDEF *odp, DLLSPEC *spec, int optional )
|
||||||
{
|
{
|
||||||
const char *token;
|
const char *token;
|
||||||
unsigned int i, arg;
|
unsigned int i, arg;
|
||||||
int is_win32 = (spec->type == SPEC_WIN32) || (odp->flags & FLAG_EXPORT32);
|
int is_win32 = (spec->type == SPEC_WIN32) || (odp->flags & FLAG_EXPORT32);
|
||||||
|
|
||||||
if (!is_win32 && odp->type == TYPE_STDCALL)
|
if (!(token = GetToken( optional ))) return optional;
|
||||||
{
|
|
||||||
error( "'stdcall' not supported for Win16\n" );
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (!is_win32 && odp->type == TYPE_THISCALL)
|
|
||||||
{
|
|
||||||
error( "'thiscall' not supported for Win16\n" );
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (is_win32 && odp->type == TYPE_PASCAL)
|
|
||||||
{
|
|
||||||
error( "'pascal' not supported for Win32\n" );
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!(token = GetToken(0))) return 0;
|
|
||||||
if (*token != '(')
|
if (*token != '(')
|
||||||
{
|
{
|
||||||
error( "Expected '(' got '%s'\n", token );
|
error( "Expected '(' got '%s'\n", token );
|
||||||
|
@ -303,13 +287,45 @@ static int parse_spec_export( ORDDEF *odp, DLLSPEC *spec )
|
||||||
}
|
}
|
||||||
|
|
||||||
odp->u.func.nb_args = i;
|
odp->u.func.nb_args = i;
|
||||||
if (odp->type == TYPE_VARARGS)
|
|
||||||
odp->flags |= FLAG_NORELAY; /* no relay debug possible for varags entry point */
|
|
||||||
if (odp->type == TYPE_THISCALL && (!i || odp->u.func.args[0] != ARG_PTR))
|
if (odp->type == TYPE_THISCALL && (!i || odp->u.func.args[0] != ARG_PTR))
|
||||||
{
|
{
|
||||||
error( "First argument of a thiscall function must be a pointer\n" );
|
error( "First argument of a thiscall function must be a pointer\n" );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************
|
||||||
|
* parse_spec_export
|
||||||
|
*
|
||||||
|
* Parse an exported function definition in a .spec file.
|
||||||
|
*/
|
||||||
|
static int parse_spec_export( ORDDEF *odp, DLLSPEC *spec )
|
||||||
|
{
|
||||||
|
const char *token;
|
||||||
|
int is_win32 = (spec->type == SPEC_WIN32) || (odp->flags & FLAG_EXPORT32);
|
||||||
|
|
||||||
|
if (!is_win32 && odp->type == TYPE_STDCALL)
|
||||||
|
{
|
||||||
|
error( "'stdcall' not supported for Win16\n" );
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (!is_win32 && odp->type == TYPE_THISCALL)
|
||||||
|
{
|
||||||
|
error( "'thiscall' not supported for Win16\n" );
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (is_win32 && odp->type == TYPE_PASCAL)
|
||||||
|
{
|
||||||
|
error( "'pascal' not supported for Win32\n" );
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!parse_spec_arguments( odp, spec, 0 )) return 0;
|
||||||
|
|
||||||
|
if (odp->type == TYPE_VARARGS)
|
||||||
|
odp->flags |= FLAG_NORELAY; /* no relay debug possible for varags entry point */
|
||||||
|
|
||||||
if (!(token = GetToken(1)))
|
if (!(token = GetToken(1)))
|
||||||
{
|
{
|
||||||
|
@ -383,14 +399,15 @@ static int parse_spec_equate( ORDDEF *odp, DLLSPEC *spec )
|
||||||
*/
|
*/
|
||||||
static int parse_spec_stub( ORDDEF *odp, DLLSPEC *spec )
|
static int parse_spec_stub( ORDDEF *odp, DLLSPEC *spec )
|
||||||
{
|
{
|
||||||
odp->u.func.nb_args = 0;
|
odp->u.func.nb_args = -1;
|
||||||
odp->link_name = xstrdup("");
|
odp->link_name = xstrdup("");
|
||||||
/* don't bother generating stubs for Winelib */
|
/* don't bother generating stubs for Winelib */
|
||||||
if (odp->flags & FLAG_CPU_MASK)
|
if (odp->flags & FLAG_CPU_MASK)
|
||||||
odp->flags &= FLAG_CPU(CPU_x86) | FLAG_CPU(CPU_x86_64);
|
odp->flags &= FLAG_CPU(CPU_x86) | FLAG_CPU(CPU_x86_64);
|
||||||
else
|
else
|
||||||
odp->flags |= FLAG_CPU(CPU_x86) | FLAG_CPU(CPU_x86_64);
|
odp->flags |= FLAG_CPU(CPU_x86) | FLAG_CPU(CPU_x86_64);
|
||||||
return 1;
|
|
||||||
|
return parse_spec_arguments( odp, spec, 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -808,7 +825,8 @@ void add_16bit_exports( DLLSPEC *spec32, DLLSPEC *spec16 )
|
||||||
odp->ordinal = -1;
|
odp->ordinal = -1;
|
||||||
odp->link_name = xstrdup( odp16->link_name );
|
odp->link_name = xstrdup( odp16->link_name );
|
||||||
odp->u.func.nb_args = odp16->u.func.nb_args;
|
odp->u.func.nb_args = odp16->u.func.nb_args;
|
||||||
memcpy( odp->u.func.args, odp16->u.func.args, odp->u.func.nb_args * sizeof(odp->u.func.args[0]) );
|
if (odp->u.func.nb_args > 0) memcpy( odp->u.func.args, odp16->u.func.args,
|
||||||
|
odp->u.func.nb_args * sizeof(odp->u.func.args[0]) );
|
||||||
}
|
}
|
||||||
|
|
||||||
assign_names( spec32 );
|
assign_names( spec32 );
|
||||||
|
|
|
@ -67,7 +67,7 @@ static inline int is_function( const ORDDEF *odp )
|
||||||
static const char *get_args_str( const ORDDEF *odp )
|
static const char *get_args_str( const ORDDEF *odp )
|
||||||
{
|
{
|
||||||
static char buffer[MAX_ARGUMENTS*2+1];
|
static char buffer[MAX_ARGUMENTS*2+1];
|
||||||
unsigned int i;
|
int i;
|
||||||
|
|
||||||
buffer[0] = 0;
|
buffer[0] = 0;
|
||||||
for (i = 0; i < odp->u.func.nb_args; i++)
|
for (i = 0; i < odp->u.func.nb_args; i++)
|
||||||
|
@ -275,7 +275,7 @@ static const char *get_relay_name( const ORDDEF *odp )
|
||||||
*/
|
*/
|
||||||
static int get_function_argsize( const ORDDEF *odp )
|
static int get_function_argsize( const ORDDEF *odp )
|
||||||
{
|
{
|
||||||
unsigned int i, argsize = 0;
|
int i, argsize = 0;
|
||||||
|
|
||||||
for (i = 0; i < odp->u.func.nb_args; i++)
|
for (i = 0; i < odp->u.func.nb_args; i++)
|
||||||
{
|
{
|
||||||
|
|
|
@ -61,7 +61,7 @@ static inline int needs_relay( const ORDDEF *odp )
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int is_float_arg( const ORDDEF *odp, unsigned int arg )
|
static int is_float_arg( const ORDDEF *odp, int arg )
|
||||||
{
|
{
|
||||||
if (arg >= odp->u.func.nb_args) return 0;
|
if (arg >= odp->u.func.nb_args) return 0;
|
||||||
return (odp->u.func.args[arg] == ARG_FLOAT || odp->u.func.args[arg] == ARG_DOUBLE);
|
return (odp->u.func.args[arg] == ARG_FLOAT || odp->u.func.args[arg] == ARG_DOUBLE);
|
||||||
|
@ -89,8 +89,8 @@ int has_relays( DLLSPEC *spec )
|
||||||
*/
|
*/
|
||||||
static void output_relay_debug( DLLSPEC *spec )
|
static void output_relay_debug( DLLSPEC *spec )
|
||||||
{
|
{
|
||||||
int i;
|
int i, j;
|
||||||
unsigned int j, pos, args, flags;
|
unsigned int pos, args, flags;
|
||||||
|
|
||||||
/* first the table of entry point offsets */
|
/* first the table of entry point offsets */
|
||||||
|
|
||||||
|
|
|
@ -892,7 +892,7 @@ unsigned int get_ptr_size(void)
|
||||||
/* return the total size in bytes of the arguments on the stack */
|
/* return the total size in bytes of the arguments on the stack */
|
||||||
unsigned int get_args_size( const ORDDEF *odp )
|
unsigned int get_args_size( const ORDDEF *odp )
|
||||||
{
|
{
|
||||||
unsigned int i, size;
|
int i, size;
|
||||||
|
|
||||||
for (i = size = 0; i < odp->u.func.nb_args; i++)
|
for (i = size = 0; i < odp->u.func.nb_args; i++)
|
||||||
{
|
{
|
||||||
|
|
|
@ -245,7 +245,7 @@ syntax is the following:
|
||||||
.RI [ flags ]\ exportname \ [ symbolname ]
|
.RI [ flags ]\ exportname \ [ symbolname ]
|
||||||
.br
|
.br
|
||||||
.IB ordinal\ stub
|
.IB ordinal\ stub
|
||||||
.RI [ flags ]\ exportname
|
.RI [ flags ]\ exportname \ [\ \fB( args... \fB)\fR\ ]
|
||||||
.br
|
.br
|
||||||
.IB ordinal\ equate
|
.IB ordinal\ equate
|
||||||
.RI [ flags ]\ exportname\ data
|
.RI [ flags ]\ exportname\ data
|
||||||
|
@ -453,7 +453,7 @@ is not specified, it is assumed to be identical to
|
||||||
Syntax:
|
Syntax:
|
||||||
.br
|
.br
|
||||||
.IB ordinal\ stub
|
.IB ordinal\ stub
|
||||||
.RI [ flags ]\ exportname
|
.RI [ flags ]\ exportname \ [\ \fB( args... \fB)\fR\ ]
|
||||||
.PP
|
.PP
|
||||||
This declaration defines a stub function. It makes the name and
|
This declaration defines a stub function. It makes the name and
|
||||||
ordinal available for dynamic linking, but will terminate execution
|
ordinal available for dynamic linking, but will terminate execution
|
||||||
|
|
Loading…
Reference in New Issue