From dcf94e9dd8767b08205c3e5d887a23f54d56e479 Mon Sep 17 00:00:00 2001 From: Daniel Zaoui Date: Thu, 13 Mar 2014 08:32:56 +0200 Subject: [PATCH] Eolian/Generator: fix generation of headers for const params. When a parameter of a property is const for get but not for set, the .eo file indicates it by setting a flag 'const' for this parameter. The generation was checking this flag for C files generation but not for H files. --- src/bin/eolian/eo1_generator.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/bin/eolian/eo1_generator.c b/src/bin/eolian/eo1_generator.c index 7ca7628411..a50a8fde29 100644 --- a/src/bin/eolian/eo1_generator.c +++ b/src/bin/eolian/eo1_generator.c @@ -195,6 +195,7 @@ eo1_fundef_generate(const char *classname, Eolian_Function func, Eolian_Function Eina_Bool add_star = EINA_FALSE; Eolian_Parameter_Dir pdir; eolian_parameter_information_get((Eolian_Function_Parameter)data, &pdir, &ptype, &pname, &pdesc); + Eina_Bool is_const = eolian_parameter_get_const_attribute_get(data); if (ftype == GET) { add_star = EINA_TRUE; pdir = EOLIAN_OUT_PARAM; @@ -210,7 +211,9 @@ eo1_fundef_generate(const char *classname, Eolian_Function func, Eolian_Function if (eina_strbuf_length_get(str_par)) eina_strbuf_append(str_par, ", "); eina_strbuf_append(str_par, pname); - eina_strbuf_append_printf(str_typecheck, ", EO_TYPECHECK(%s%s%s, %s)", ptype, had_star?"":" ", add_star?"*":"", pname); + eina_strbuf_append_printf(str_typecheck, ", EO_TYPECHECK(%s%s%s%s, %s)", + is_const?"const ":"", + ptype, had_star?"":" ", add_star?"*":"", pname); } const char* rettype = eolian_function_return_type_get(func, ftype);