t-rex has asked for the wisdom of the Perl Monks concerning the following question:

I have come across a regex while debugging some code and while I have understood part of it , i need to understand entirely in order to accommodate new changes in requirement.

$inp =~ s/<%([^=].*?)%>/eval $1/ges #this is one $inp =~ s/<%=(.*?)%>/eval $1/ges #this is the second

Now when i have 2 input strings one :

<% my $test=''; if (@{$ctxt{'params'}}) { $test= 'index=1011' 'asln=' . join(' ',@{$ctxt{'params'}})."\n". } $test; %>

second input string

<% $ctxt{'common_params'}; %>

My understanding of the above regex is when it encounters "<%" it substitutes the value of the variable eg: it assigns test variable with value index and asln , but i fail to understand what is eval doing here ? and what about $1 ? can anyone explain me ?

Replies are listed 'Best First'.
Re: regex understanding help
by Eily (Monsignor) on Jan 10, 2017 at 10:10 UTC

    Parentheses in a regular expression capture whatever is matched by their content. This means that the part of the string that was matched is accessible in one of the special variables $1, $2, $3. So in your case, $1 simply means the content of the <% %> pattern. For more information you can read perlretut.

    For the eval part, the documentation states:

    EXPR is parsed and executed as if it were a little Perl program
    [...]
    This form is typically used to delay parsing and subsequent execution of the text of EXPR until run time.

    So the aim of the eval is to turn the content of the <% %> pattern into a "little perl program", and obtain its last value.

    There is a catch though, there is not one, but two evals in your code because a replacement operation is of the form s/REGEX/STRING/. So the thing on the right side is a string (simple text), not code to be executed. Among the three options on the replacement operator (g, e and s), the e means "execute", or simply eval.

    So in a nutshell: this operation $inp =~ s/<%([^=].*?)%>/eval $1/ges takes whatever is inside a <% %> pattern (except if the content starts with an equal sign), and executes it as a little perl program, before replacing the pattern by the last value in that program. In your example, the last value is $test.

Re: regex understanding help
by kcott (Archbishop) on Jan 10, 2017 at 11:40 UTC

    G'day t-rex,

    That looks like Template Toolkit data.

    It can be used for a number of things. A typical usage is to embed Perl code in HTML.

    Here's a quick and dirty example of what's going on. First, without the eval:

    $ perl -E 'my $x = "Ken"; say "<p><%\$x%></p>" =~ s/<%(.*)%>/$1/er' <p>$x</p>

    Now, with it added:

    $ perl -E 'my $x = "Ken"; say "<p><%\$x%></p>" =~ s/<%(.*)%>/eval $1/e +r' <p>Ken</p>

    So, that started with Perl code (\$x), inside a Template Toolkit wrapper (<%...%>), inside HTML (<p>...</p>). The result is pure HTML: <p>Ken</p>

    However, all that work is normally done by Template Toolkit: you shouldn't need to process that data yourself.

    — Ken