X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Ftypes%2Fnumber.c;h=b45e00ea2fe4126890ba97ac89b07823d4c2f26f;hp=057bd9fb8d3d2a2629c9d95185378235cb6a5600;hb=35ae2559447092572209f8b237460ceb551293ff;hpb=c101a4de2983791d5892e60d765b73b6b3ccf6f8 diff --git a/src/types/number.c b/src/types/number.c index 057bd9f..b45e00e 100644 --- a/src/types/number.c +++ b/src/types/number.c @@ -86,6 +86,9 @@ struct psi_number *psi_number_init(token_t t, void *num, unsigned flags) case PSI_T_FUNCTION: exp->data.call = num; break; + case PSI_T_SIZEOF: + exp->data.dtyp = num; + break; default: assert(0); } @@ -130,6 +133,9 @@ struct psi_number *psi_number_copy(struct psi_number *exp) case PSI_T_FUNCTION: num->data.call = psi_cpp_macro_call_copy(num->data.call); break; + case PSI_T_SIZEOF: + num->data.dtyp = psi_decl_type_copy(num->data.dtyp); + break; default: assert(0); } @@ -173,6 +179,9 @@ void psi_number_free(struct psi_number **exp_ptr) case PSI_T_NAME: psi_decl_var_free(&exp->data.dvar); break; + case PSI_T_SIZEOF: + psi_decl_type_free(&exp->data.dtyp); + break; default: assert(0); } @@ -224,6 +233,9 @@ void psi_number_dump(int fd, struct psi_number *exp) case PSI_T_QUOTED_CHAR: dprintf(fd, "%s", exp->data.numb); break; + case PSI_T_FUNCTION: + psi_cpp_macro_call_dump(fd, exp->data.call); + break; case PSI_T_CONST: dprintf(fd, "%s", exp->data.cnst->name); break; @@ -233,6 +245,9 @@ void psi_number_dump(int fd, struct psi_number *exp) case PSI_T_NAME: psi_decl_var_dump(fd, exp->data.dvar); break; + case PSI_T_SIZEOF: + psi_decl_type_dump(fd, exp->data.dtyp, 0); + break; default: assert(0); } @@ -478,6 +493,16 @@ bool psi_number_validate(struct psi_data *data, struct psi_number *exp, exp->data.dvar->name); return false; + case PSI_T_SIZEOF: + if (psi_decl_type_validate(data, exp->data.dtyp, 0, NULL)) { + struct psi_decl_type *dtyp = exp->data.dtyp; + + exp->type = PSI_T_UINT64; + exp->data.ival.u64 = psi_decl_type_get_size(dtyp, NULL); + return true; + } + break; + case PSI_T_NSNAME: while (psi_plist_get(data->consts, i++, &cnst)) { if (!strcmp(cnst->name, exp->data.numb)) { @@ -610,6 +635,10 @@ token_t psi_number_eval(struct psi_number *exp, impl_val *res, struct psi_call_f if (frame) PSI_DEBUG_PRINT(frame->context, " %" PRIi64, res->i64); return PSI_T_INT64; + case PSI_T_NUMBER: + res->i64 = atol(exp->data.numb); + return PSI_T_INT64; + case PSI_T_CONST: return psi_number_eval_constant(exp, res, frame);