qcvm -printfuns; prog_section_function.nargs is now signed as fteqcc sets builtins with varargs to have -1 params

This commit is contained in:
Wolfgang (Blub) Bumiller 2012-11-30 20:20:13 +01:00
parent a9a41a786e
commit e0a7f8a484
3 changed files with 22 additions and 3 deletions

21
exec.c
View file

@ -477,7 +477,8 @@ static void prog_print_statement(qc_program *prog, prog_section_statement *st)
static qcint prog_enterfunction(qc_program *prog, prog_section_function *func)
{
qc_exec_stack st;
size_t p, parampos;
size_t parampos;
int32_t p;
/* back up locals */
st.localsp = vec_size(prog->localstack);
@ -814,6 +815,7 @@ int main(int argc, char **argv)
size_t xflags = VMXF_DEFAULT;
bool opts_printfields = false;
bool opts_printdefs = false;
bool opts_printfuns = false;
bool opts_disasm = false;
bool opts_info = false;
@ -848,6 +850,11 @@ int main(int argc, char **argv)
++argv;
opts_printdefs = true;
}
else if (!strcmp(argv[1], "-printfuns")) {
--argc;
++argv;
opts_printfuns = true;
}
else if (!strcmp(argv[1], "-printfields")) {
--argc;
++argv;
@ -926,6 +933,18 @@ int main(int argc, char **argv)
(unsigned int)prog->fields[i].offset);
}
}
else if (opts_printfuns) {
for (i = 0; i < vec_size(prog->functions); ++i) {
int32_t a;
printf("Function: %-16s taking %i parameters:",
prog_getstring(prog, prog->functions[i].name),
(unsigned int)prog->functions[i].nargs);
for (a = 0; a < prog->functions[i].nargs; ++a) {
printf(" %i", prog->functions[i].argsize[a]);
}
printf("\n");
}
}
else
{
if (fnmain > 0)

View file

@ -443,7 +443,7 @@ typedef struct {
uint32_t profile; /* Always zero (engine uses this) */
uint32_t name; /* name of function in string table */
uint32_t file; /* file of the source file */
uint32_t nargs; /* number of arguments */
int32_t nargs; /* number of arguments */
uint8_t argsize[8]; /* size of arguments (keep 8 always?) */
} prog_section_function;

2
ir.c
View file

@ -2841,7 +2841,7 @@ static bool gen_global_function(ir_builder *ir, ir_value *global)
fun.nargs = 8;
for (i = 0;i < 8; ++i) {
if (i >= fun.nargs)
if ((int32_t)i >= fun.nargs)
fun.argsize[i] = 0;
else
fun.argsize[i] = type_sizeof[irfun->params[i]];