X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Fdecl_enum_item.c;h=c403d97113626e134d8ed0f98e74b992e7ef5a17;hb=370510d04a5e22140e1e7f90f5d1f0002e6dbee6;hp=5f664b01b2e388615872fba03e538efde924c76a;hpb=9bcb1df0786a8193d65949c857baaba2f4296e84;p=m6w6%2Fext-psi diff --git a/src/types/decl_enum_item.c b/src/types/decl_enum_item.c index 5f664b0..c403d97 100644 --- a/src/types/decl_enum_item.c +++ b/src/types/decl_enum_item.c @@ -44,8 +44,22 @@ void psi_decl_enum_item_free(struct psi_decl_enum_item **i_ptr) if (i->token) { free(i->token); } - if (i->num && i->num != &i->inc) { - psi_num_exp_free(&i->num); + if (i->num) { + if (i->num == &i->inc) { + switch (i->inc.op) { + case PSI_T_NUMBER: + psi_number_free(&i->inc.data.n); + break; + case PSI_T_PLUS: + psi_num_exp_free(&i->inc.data.b.lhs); + psi_num_exp_free(&i->inc.data.b.rhs); + break; + default: + assert(0); + } + } else { + psi_num_exp_free(&i->num); + } } free(i->name); free(i); @@ -66,14 +80,19 @@ bool psi_decl_enum_item_validate(struct psi_data *data, { if (!item->num) { if (seq) { - item->inc.type = PSI_T_INT64; - item->inc.data.ival.i64 = 1; + int64_t one = 1; + item->inc.op = PSI_T_PLUS; - item->inc.operand = item->prev->num ? : &item->prev->inc; + item->inc.data.b.lhs = psi_num_exp_init_unary(PSI_T_LPAREN, + psi_num_exp_copy(item->prev->num)); + item->inc.data.b.rhs = psi_num_exp_init_num( + psi_number_init(PSI_T_INT64, &one, 0)); item->num = &item->inc; } else { - item->inc.type = PSI_T_INT64; - item->inc.data.ival.i64 = 0; + int64_t nil = 0; + + item->inc.op = PSI_T_NUMBER; + item->inc.data.n = psi_number_init(PSI_T_INT64, &nil, 0); item->num = &item->inc; } } @@ -82,7 +101,7 @@ bool psi_decl_enum_item_validate(struct psi_data *data, return false; } - item->val = psi_long_num_exp(item->num, NULL); + item->val = psi_long_num_exp(item->num, NULL, NULL); return true; }