X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftypes%2Fdecl_enum_item.c;h=b20595b6849f4f7d4338462983f261d7eea8cf31;hb=44bd65fe60fb83fa4c3bbb0d4c679d2b70a096df;hp=ad78dddb41dc0a88579ede901579501abc1b2b45;hpb=42f44eb5bf4ecd36e26e051fada79d861d0f92d2;p=m6w6%2Fext-psi diff --git a/src/types/decl_enum_item.c b/src/types/decl_enum_item.c index ad78ddd..b20595b 100644 --- a/src/types/decl_enum_item.c +++ b/src/types/decl_enum_item.c @@ -23,14 +23,18 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *******************************************************************************/ -#include "php_psi_stdinc.h" +#ifdef HAVE_CONFIG_H +# include "config.h" +#else +# include "php_config.h" +#endif #include "data.h" -struct psi_decl_enum_item *psi_decl_enum_item_init(const char *name, +struct psi_decl_enum_item *psi_decl_enum_item_init(zend_string *name, struct psi_num_exp *num) { - struct psi_decl_enum_item *i = calloc(1, sizeof(*i)); - i->name = strdup(name); + struct psi_decl_enum_item *i = pecalloc(1, sizeof(*i), 1); + i->name = zend_string_copy(name); i->num = num; return i; } @@ -41,9 +45,7 @@ void psi_decl_enum_item_free(struct psi_decl_enum_item **i_ptr) struct psi_decl_enum_item *i = *i_ptr; *i_ptr = NULL; - if (i->token) { - free(i->token); - } + psi_token_free(&i->token); if (i->num) { if (i->num == &i->inc) { switch (i->inc.op) { @@ -61,23 +63,25 @@ void psi_decl_enum_item_free(struct psi_decl_enum_item **i_ptr) psi_num_exp_free(&i->num); } } - free(i->name); + zend_string_release(i->name); free(i); } } -void psi_decl_enum_item_dump(int fd, struct psi_decl_enum_item *item) +void psi_decl_enum_item_dump(struct psi_dump *dump, struct psi_decl_enum_item *item) { - dprintf(fd, "%s", item->name); + PSI_DUMP(dump, "%s", item->name->val); if (item->num && item->num != &item->inc) { - dprintf(fd, " = "); - psi_num_exp_dump(fd, item->num); + PSI_DUMP(dump, " = "); + psi_num_exp_dump(dump, item->num); } } bool psi_decl_enum_item_validate(struct psi_data *data, struct psi_decl_enum *enm, struct psi_decl_enum_item *item, size_t seq) { + struct psi_validate_scope scope = {0}; + if (!item->num) { if (seq) { int64_t one = 1; @@ -86,22 +90,23 @@ bool psi_decl_enum_item_validate(struct psi_data *data, 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)); + psi_number_init(PSI_T_INT64, &one, 0)); item->num = &item->inc; } else { int64_t nil = 0; item->inc.op = PSI_T_NUMBER; - item->inc.data.n = psi_number_init(PSI_T_INT64, &nil); + item->inc.data.n = psi_number_init(PSI_T_INT64, &nil, 0); item->num = &item->inc; } } - if (!psi_num_exp_validate(data, item->num, NULL, NULL, NULL, NULL, enm)) { + scope.current_enum = enm; + if (!psi_num_exp_validate(data, item->num, &scope)) { return false; } - item->val = psi_long_num_exp(item->num, NULL, NULL); + item->val = psi_num_exp_get_long(item->num, NULL, NULL); return true; }