It seems the \\., which captures the \" in the target, is not possessive, and is causing the error.
The following works in the given case. Are there cases where it fails?
print "NOT MATCHED!\n" unless
/^ " (?: [^"\\]++ | (?: \\. )++ )*+ " /x ;
Update:
Playing around more, it seems that the possessives are not needed on the internals, but only that the \\. should have a quantifier:
print "NOT MATCHED!\n" unless
/^ " (?: [^"\\]+ | (?: \\. )+ )*+ " /x ;
This works on a string of length 100 million, in <2s on my machine. (I didn't try any longer strings.)
-QM
--
Quantum Mechanics: The dreams stuff is made of
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.
|