X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Fmodule.c;h=778f396b7e9cc6a5fd8bacffdad85bb096018005;hp=1db2adff529377b922a848f262fbf71e6a680449;hb=42f44eb5bf4ecd36e26e051fada79d861d0f92d2;hpb=1b6db76e3005344b33ab45b00e7e61386a33932a diff --git a/src/module.c b/src/module.c index 1db2adf..778f396 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,17 +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; } - psi_parser_parse(&P); + 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) @@ -157,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; } @@ -168,17 +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; } - psi_parser_parse(&P); + 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)