X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Fmodule.c;h=e7948d8a0e9abec32534e7665797fa6109e65fdf;hp=b253e0a68d1b632d129b6f95d2969a52d95bc77b;hb=3e2cb4103d922e025ec566e11439058d44cff872;hpb=7df12c88a4e14611a2585d6e7c994c59e8d7485a diff --git a/src/module.c b/src/module.c index b253e0a..e7948d8 100644 --- a/src/module.c +++ b/src/module.c @@ -127,10 +127,17 @@ ZEND_END_ARG_INFO(); static PHP_FUNCTION(psi_validate) { zend_string *file; + struct psi_parser_input *I; struct psi_parser P; struct psi_data D = {0}; zend_long flags = 0; +#if PHP_DEBUG + if (psi_check_env("PSI_DEBUG")) { + flags |= PSI_DEBUG; + } +#endif + if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS(), "P|l", &file, &flags)) { return; } @@ -138,24 +145,17 @@ static PHP_FUNCTION(psi_validate) if (!psi_parser_init(&P, psi_error_wrapper, flags)) { RETURN_FALSE; } - if (!psi_parser_open_file(&P, file->val)) { + if (!(I = psi_parser_open_file(&P, file->val, true))) { psi_parser_dtor(&P); RETURN_FALSE; } - while (0 < psi_parser_scan(&P)) { - psi_parser_parse(&P, psi_token_alloc(&P)); - if (P.num == PSI_T_EOF) { - break; - } - } - psi_parser_parse(&P, NULL); - + psi_parser_parse(&P, I); psi_data_ctor(&D, P.error, P.flags); RETVAL_BOOL(psi_data_validate(&D, PSI_DATA(&P)) && !P.errors); psi_data_dtor(&D); - psi_parser_dtor(&P); + free(I); } ZEND_BEGIN_ARG_INFO_EX(ai_psi_validate_string, 0, 0, 1) @@ -164,10 +164,17 @@ ZEND_END_ARG_INFO(); static PHP_FUNCTION(psi_validate_string) { zend_string *string; + struct psi_parser_input *I; struct psi_parser P; struct psi_data D = {0}; zend_long flags = 0; +#if PHP_DEBUG + if (psi_check_env("PSI_DEBUG")) { + flags |= PSI_DEBUG; + } +#endif + if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS(), "S|l", &string, &flags)) { return; } @@ -175,24 +182,17 @@ static PHP_FUNCTION(psi_validate_string) if (!psi_parser_init(&P, psi_error_wrapper, flags)) { RETURN_FALSE; } - if (!psi_parser_open_string(&P, string->val, string->len)) { + if (!(I = psi_parser_open_string(&P, string->val, string->len))) { psi_parser_dtor(&P); RETURN_FALSE; } - while (0 < psi_parser_scan(&P)) { - psi_parser_parse(&P, psi_token_alloc(&P)); - if (P.num == PSI_T_EOF) { - break; - } - } - psi_parser_parse(&P, NULL); - + psi_parser_parse(&P, I); psi_data_ctor(&D, P.error, P.flags); RETVAL_BOOL(psi_data_validate(&D, PSI_DATA(&P)) && !P.errors); psi_data_dtor(&D); - psi_parser_dtor(&P); + free(I); } static PHP_MINIT_FUNCTION(psi) @@ -239,15 +239,15 @@ static PHP_MINIT_FUNCTION(psi) PSI_G(context) = psi_context_init(NULL, ops, psi_error_wrapper, flags); psi_context_build(PSI_G(context), PSI_G(directory)); - if (psi_check_env("PSI_DUMP")) { - psi_context_dump(PSI_G(context), STDOUT_FILENO); - } - return SUCCESS; } static PHP_MSHUTDOWN_FUNCTION(psi) { + if (psi_check_env("PSI_DUMP")) { + psi_context_dump(PSI_G(context), STDOUT_FILENO); + } + psi_context_free(&PSI_G(context)); UNREGISTER_INI_ENTRIES();