NAME

HTML::Mason::Parser - Mason Component Parser

SYNOPSIS

my $p = new HTML::Mason::Parser (...params...);

DESCRIPTION

A Parser object translates components into Perl subroutines. Parsers are typically embedded within (and used by) Interp objects.

PARAMETERS FOR new() CONSTRUCTOR

ignore_warnings_expr

Regular expression indicating which warnings to ignore when compiling subroutines. Any warning that is not ignored will prevent the component from being compiled and executed. For example:

ignore_warnings_expr =>
    'Global symbol.*requires explicit package'

Undefined by default, meaning that all warnings are fatal.

preamble

A piece of Perl code to insert at the beginning of every compiled subroutine. Blank by default, but ApacheHandler adds the line

use vars qw($r);

to suppress strict warnings about uses of global $r (the Apache request object).

postamble

A piece of Perl code to insert at the end of every compiled subroutine. Blank by default.

source_refer_predicate

Reference to a subroutine that decides whether a given component should be compiled with "source references" in Admin. The subroutine takes two arguments: first, the total number of characters in the component source; second, the number of characters devoted to plain text. For example, this component:

% my $noun = "World";
Hello, <% $noun %>!
How are ya?

Has 51 total bytes, 19 of which are plain text. This allows you to adjust the trade-off between the memory savings of source references and the performance advantage of in-line plain text. For example, to choose only components with at least 50% plain text:

source_refer_predicate =>
    sub { return $_[1] / $_[0] >= 0.5 }

The current default is

sub { return $_[1] >= 500 }

i.e. any component with at least 500 characters. This is an experimental setting and may change.

taint_check

This flag allows Mason to work when taint checking is on (e.g. PerlTaintCheck or -T flag). If true, Mason will pass all component source and filenames through a dummy regular expression match to untaint them. In the future this option may become more sophisticated to allow stricter checks. Default is false.

use_strict

Indicates whether to use strict in compiled subroutines. Default is true.

AUTHOR

Jonathan Swartz, swartz@transbay.net

SEE ALSO

HTML::Mason, HTML::Mason::Interp, HTML::Mason::ApacheHandler, HTML::Mason::Admin