http://qs1969.pair.com?node_id=107963


in reply to Re: Re: Re: Re: Speed, and my sanity.
in thread Speed, and my sanity.

First off I wasn't really suggesting that you use
<body bgcolor="<% $params{parse}->{BGCOLOR} %>">
The only difference between that and what your system currently uses is that you use a different syntax for tags. And there's nothing wrong with that. The above is just one way of using templates.

What I was suggesting, rather, is that your compilation phase could be turning this:

<body bgcolor="<@BGCOLOR@>">
into this:
$_out->('<body bgcolor="'); $_out->( $params{parse}->{BGCOLOR} ); $_out->('">');
This can be done by tokenizing your template, then turning everything like
<@ FOO @>
into a statement like
$_out->( $params{parse}->{FOO} );
This Perl statement can then be directly executed, and moreover you can write the Perl code to disk, then directly execute it again; this means that on subsequent requests to your template, it does not have to be reparsed.

As for whether this requires a major rewrite: it would require separating your compilation and execution phases, essentially. This is the biggest difference, because this is a mental difference: when you use the substitution operator to walk through a string and replace your template tags with other values, you are performing "compilation" and "execution" of your template at the same time. When you first compile to Perl code, then execute, you are splitting up those steps.

So it would require a rethink of a piece of your system, and yes, it would also require rewriting some of it. But it's something to think about.