From: Jason Ekstrand Date: Sat, 13 Feb 2016 04:41:19 +0000 (-0800) Subject: nir/print: Better function argument printing X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f86f3c90aa6918e741e505217e1f766c025229e4;p=mesa.git nir/print: Better function argument printing Since we aren't going to put the function parameters or the return variable in the list of locals, it won't get a proper declaration. This changes nir_print to print the type along with each parameter or return variable. Reviewed-by: Jordan Justen --- diff --git a/src/compiler/nir/nir_print.c b/src/compiler/nir/nir_print.c index 85799d64ec8..bdfbd2600c0 100644 --- a/src/compiler/nir/nir_print.c +++ b/src/compiler/nir/nir_print.c @@ -379,6 +379,14 @@ print_var(nir_variable *var, print_state *state) fprintf(fp, "%s", get_var_name(var, state)); } +static void +print_arg(nir_variable *var, print_state *state) +{ + FILE *fp = state->fp; + glsl_print_type(var->type, fp); + fprintf(fp, " %s", get_var_name(var, state)); +} + static void print_deref_var(nir_deref_var *deref, print_state *state) { @@ -938,14 +946,14 @@ print_function_impl(nir_function_impl *impl, print_state *state) if (i != 0) fprintf(fp, ", "); - print_var(impl->params[i], state); + print_arg(impl->params[i], state); } if (impl->return_var != NULL) { if (impl->num_params != 0) fprintf(fp, ", "); fprintf(fp, "returning "); - print_var(impl->return_var, state); + print_arg(impl->return_var, state); } fprintf(fp, "{\n");