MirBSD manpage: re(3p)


re(3p)          Perl Programmers Reference Guide           re(3p)

NAME

     re - Perl pragma to alter regular expression behaviour

SYNOPSIS

         use re 'taint';
         ($x) = ($^X =~ /^(.*)$/s);     # $x is tainted here

         $pat = '(?{ $foo = 1 })';
         use re 'eval';
         /foo${pat}bar/;                # won't fail (when not under -T switch)

         {
             no re 'taint';             # the default
             ($x) = ($^X =~ /^(.*)$/s); # $x is not tainted here

             no re 'eval';              # the default
             /foo${pat}bar/;            # disallowed (with or without -T switch)
         }

         use re 'debug';                # NOT lexically scoped (as others are)
         /^(.*)$/s;                     # output debugging info during
                                        #     compile and run time

         use re 'debugcolor';           # same as 'debug', but with colored output
         ...

     (We use $^X in these examples because it's tainted by
     default.)

DESCRIPTION

     When "use re 'taint'" is in effect, and a tainted string is
     the target of a regex, the regex memories (or values
     returned by the m// operator in list context) are tainted.
     This feature is useful when regex operations on tainted data
     aren't meant to extract safe substrings, but to perform
     other transformations.

     When "use re 'eval'" is in effect, a regex is allowed to
     contain "(?{ ... })" zero-width assertions even if regular
     expression contains variable interpolation.  That is nor-
     mally disallowed, since it is a potential security risk.
     Note that this pragma is ignored when the regular expression
     is obtained from tainted data, i.e.  evaluation is always
     disallowed with tainted regular expressions.  See "(?{ code
     })" in perlre.

     For the purpose of this pragma, interpolation of precompiled
     regular expressions (i.e., the result of "qr//") is not con-
     sidered variable interpolation.  Thus:

         /foo${pat}bar/

perl v5.8.8                2005-02-05                           1

re(3p)          Perl Programmers Reference Guide           re(3p)

     is allowed if $pat is a precompiled regular expression, even
     if $pat contains "(?{ ... })" assertions.

     When "use re 'debug'" is in effect, perl emits debugging
     messages when compiling and using regular expressions.  The
     output is the same as that obtained by running a
     "-DDEBUGGING"-enabled perl interpreter with the -Dr switch.
     It may be quite voluminous depending on the complexity of
     the match.  Using "debugcolor" instead of "debug" enables a
     form of output that can be used to get a colorful display on
     terminals that understand termcap color sequences.  Set
     $ENV{PERL_RE_TC} to a comma-separated list of "termcap" pro-
     perties to use for highlighting strings on/off, pre-point
     part on/off. See "Debugging regular expressions" in perlde-
     bug for additional info.

     The directive "use re 'debug'" is not lexically scoped, as
     the other directives are.  It has both compile-time and run-
     time effects.

     See "Pragmatic Modules" in perlmodlib.

perl v5.8.8                2005-02-05                           2

Generated on 2022-12-24 01:00:14 by $MirOS: src/scripts/roff2htm,v 1.113 2022/12/21 23:14:31 tg Exp $ — This product includes material provided by mirabilos.

These manual pages and other documentation are copyrighted by their respective writers; their sources are available at the project’s CVSweb, AnonCVS and other mirrors. The rest is Copyright © 2002–2022 MirBSD.

This manual page’s HTML representation is supposed to be valid XHTML/1.1; if not, please send a bug report — diffs preferred.

Kontakt / Impressum & Datenschutzerklärung