diff options
author | David Mitchell <davem@iabyn.com> | 2013-05-17 17:38:00 +0100 |
---|---|---|
committer | David Mitchell <davem@iabyn.com> | 2013-06-02 22:28:49 +0100 |
commit | 02d5137b98854dd95a1eb9d4bee9d44d656f2c16 (patch) | |
tree | 8266e5bc1d8aa4bcd7ee41c139e3e485d63721a3 /regexp.h | |
parent | 3a74e0e282cd5c2593f9477923d3bcb1f32ece37 (diff) | |
download | perl-02d5137b98854dd95a1eb9d4bee9d44d656f2c16.tar.gz |
make more use of regmatch_info struct.
regmatch_info is a small struct that is currently directly allocated as a
local var in Perl_regexec_flags(), and has a few fields that maintain part
of the state of the current pattern match. It is passed as an arg to
various functions that regexec_flags() calls, such as regtry().
In some ways its a rival to PL_reg_state, which also maintains state for
the current match, but which is a global variable (whose state needs
saving and restoring whenever the regex engine goes reentrant). It makes
more sense to store state in the regmatch_info struct, and as a first step
in moving more state to there, this commit makes more use of
regmatch_info.
In particular, it makes Perl_re_intuit_start() also allocate such a
struct, so that now *both* the main execution entry points to the regex
engine make use of it. It's also now passed as an arg to more of the static
functions that these two op-level ones call.
Two changes of special note. First, whether S_find_byclass() got called
with a null reginfo pointer of not indicated whether it had been called
from Perl_regexec_flags() (with a valid reginfo pointer), or from
Perl_re_intuit_start() (null pointer). Since they both pass non-null
reginfo pointers now, instead we add an extra field, reginfo->intuit that
indicates who's the top-level caller.
Secondly, to allow in future for various macros to uniformly refer to
values like reginfo->foo, where the structure is actually allocated as a
local var in Perl_regexec_flags(), we change the reginfo from being the
struct itself to being a pointer to the struct, (so Perl_regexec_flags
itself now uses reginfo->foo too rather than reginfo.foo).
In summary, all the above is essentially window dressing that makes no
functional changes to the code, but will facilitate future changes.
Diffstat (limited to 'regexp.h')
-rw-r--r-- | regexp.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -581,6 +581,7 @@ typedef struct { SV *sv; char *ganch; char *cutpoint; + bool intuit; /* re_intuit_start() is the top-level caller */ bool is_utf8_pat; bool warned; /* we have issued a recursion warning; no need for more */ } regmatch_info; |