X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Fnum_exp.c;h=7d168c1a9782569cf80512ab397eaf712f5c4850;hb=refs%2Fheads%2Fmaster;hp=944b876a4176ad6b38106bc57d033119d1882779;hpb=d2e0af1718294569a84c3c15616c74e4d55ea579;p=m6w6%2Fext-psi diff --git a/src/types/num_exp.c b/src/types/num_exp.c index 944b876..7d168c1 100644 --- a/src/types/num_exp.c +++ b/src/types/num_exp.c @@ -35,6 +35,7 @@ #include "context.h" #include "call.h" #include "calc.h" +#include "debug.h" struct psi_num_exp *psi_num_exp_init_ternary(token_t op, struct psi_num_exp *cond, struct psi_num_exp *truthy, @@ -373,7 +374,6 @@ struct psi_plist *psi_num_exp_tokens(struct psi_num_exp *exp, psi_plist_top(list, &ntoken); ntoken = psi_token_init(PSI_T_COLON, ":", 1, ntoken->col+ntoken->text->len, ntoken->line, ntoken->file); list = psi_plist_add(list, &ntoken); - list = psi_plist_add(list, &ntoken); list = psi_num_exp_tokens(exp->data.t.falsy, list); break; @@ -540,7 +540,19 @@ bool psi_num_exp_validate(struct psi_data *data, struct psi_num_exp *exp, switch (exp->op) { case PSI_T_NUMBER: - return psi_number_validate(data, exp->data.n, scope); + if (!psi_number_validate(data, exp->data.n, scope)) { + smart_str str = {0}; + struct psi_dump dump = {{.hn = &str}, + .fun = (psi_dump_cb) psi_smart_str_printf}; + + psi_num_exp_dump(&dump, exp); + smart_str_0(&str); + data->error(data, exp->token, PSI_WARNING, + "Invalid numeric expression: '%s'", + str.s->val); + return false; + } + return true; case PSI_T_CAST: return psi_num_exp_validate(data, exp->data.c.num, scope)