## name Basic passing.
## failures 0
## cut

print "this is not $literal";
print qq{this is not $literal};
print "this is not literal\n";
print qq{this is not literal\n};

#-----------------------------------------------------------------------------

## name Basic failure.
## failures 5
## cut

print 'this is not $literal';
print q{this is not $literal};
print 'this is not literal\n';
print q{this is not literal\n};
print 'this is not @literal';

#-----------------------------------------------------------------------------

## name Readonly constant from Modules::ProhibitAutomaticExportation.
## failures 1
## cut

Readonly::Scalar my $EXPL => q{Use '@EXPORT_OK' or '%EXPORT_TAGS' instead};

#-----------------------------------------------------------------------------

## name OK to escape backslashes.
## failures 0
## cut

print 'it is ok to escape a backslash: \\t'
print q{it is ok to escape a backslash: \\t}
print 'you can do it multiple times: \\\\\\t'
print q{you can do it multiple times: \\\\\\t}

#-----------------------------------------------------------------------------

## name OK to escape quotes.
## failures 0
## cut

print 'you can also escape a quote: \''
print q{you can also escape a quote: \'}
print 'you can escape a quote preceded by backslashes: \\\\\''
print q{you can escape a quote preceded by backslashes: \\\\\'}

#-----------------------------------------------------------------------------

## name Valid escapes should not hide invalid ones.
## failures 4
## cut

print 'it is ok to escape a backslash: \\t but not a tee: \t'
print q{it is ok to escape a backslash: \\t but not a tee: \t}
print 'you can also escape a quote: \' but not a tee: \t'
print q{you can also escape a quote: \' but not a tee: \t}

#-----------------------------------------------------------------------------

## name Sigil characters not looking like sigils.
## failures 0
## cut

$sigil_at_end_of_word = 'list@ scalar$';
$sigil_at_end_of_word = 'scalar$ list@';
$sigil_at_end_of_word = q(list@ scalar$);
$sigil_at_end_of_word = q(scalar$ list@);
%options = (  'foo=s@' => \@foo);  #Like with Getopt::Long
%options = ( q{foo=s@} => \@foo);  #Like with Getopt::Long
$sigil_as_delimiter = q$blah$;
$sigil_as_delimiter = q    $blah$;
$sigil_as_delimiter = q@blah@;
$sigil_as_delimiter = q    @blah@;

#-----------------------------------------------------------------------------

## name Do complain about RCS variables, if not turned on.
## failures 7
## cut

$VERSION = q<$Revision: 3547 $>;
($VERSION) = q<$Revision: 3547 $> =~ m/(\d+)/mx;
our $VERSION = substr(q/$Revision: 3547 $/, 10);
our ($VERSION) = q<$Revision: 3547 $> =~ m/(\d+)/mx;
our ($VERSION) = (q<$Revision: 3547 $> =~ m/(\d+)/mx);
our (undef, $AUTHOR, undef, undef, $VERSION) = split m/\s+/, q<$Author: clonezone $ $Revision: 3547 $>;

# Yes, silly example, but still need to check it.
if ( ($VERSION) = q<$Revision: 3547 $> =~ m/(\d+)/mx ) {}

#-----------------------------------------------------------------------------

## name Don't complain about RCS variables, if turned on.
## failures 0
## parms { rcs_keywords => 'Revision Author' }
## cut

$VERSION = q<$Revision: 3547 $>;
($VERSION) = q<$Revision: 3547 $> =~ m/(\d+)/mx;
our $VERSION = substr(q/$Revision: 3547 $/, 10);
our ($VERSION) = q<$Revision: 3547 $> =~ m/(\d+)/mx;
our ($VERSION) = (q<$Revision: 3547 $> =~ m/(\d+)/mx);
our (undef, $AUTHOR, undef, undef, $VERSION) = split m/\s+/, q<$Author: clonezone $ $Revision: 3547 $>;

# Yes, silly example, but still need to check it.
if ( ($VERSION) = q<$Revision: 3547 $> =~ m/(\d+)/mx ) {}

#-----------------------------------------------------------------------------

## name Don't complain about use overload dereferences.
## failures 0
## cut

use overload '${}' => \&scalar_deref;
use overload '@{}' => \&array_deref;
use overload '%{}' => \&hash_deref;
use overload '&{}' => \&code_deref;
use overload '*{}' => \&glob_deref;
use overload ('${}' => \&scalar_deref);
use overload ('@{}' => \&array_deref);
use overload ('%{}' => \&hash_deref);
use overload ('&{}' => \&code_deref);
use overload ('*{}' => \&glob_deref);
use overload 1.0 ('${}' => \&scalar_deref);
use overload 1.0 ('@{}' => \&array_deref);

#-----------------------------------------------------------------------------

## name Do complain about overload dereference-ish strings elsewhere.
## failures 2
## cut

use overlord '${}' => \&scalar_deref;
use overlord '@{}' => \&array_deref;

#-----------------------------------------------------------------------------

## name use vars arguments.
## failures 0
## cut

use vars '$FOO';
use vars '$FOO', '@BAR';
use vars ('$FOO');
use vars ('$FOO', '@BAR');
use vars (('$FOO'));
use vars (('$FOO', '@BAR'));
use vars ((('$FOO')));
use vars ((('$FOO', '@BAR')));
use vars qw< $FOO @BAR >;
use vars qw< $FOO @BAR >, '$BAZ';

#-----------------------------------------------------------------------------

## name Include statement failure.
## failures 1
## cut

use Generic::Module '$FOO';

#-----------------------------------------------------------------------------

##############################################################################
#      $URL: http://perlcritic.tigris.org/svn/perlcritic/branches/Perl-Critic-backlog/t/ValuesAndExpressions/RequireInterpolationOfMetachars.run $
#     $Date: 2009-08-09 16:06:04 -0500 (Sun, 09 Aug 2009) $
#   $Author: clonezone $
# $Revision: 3547 $
##############################################################################

# Local Variables:
#   mode: cperl
#   cperl-indent-level: 4
#   fill-column: 78
#   indent-tabs-mode: nil
#   c-indentation-style: bsd
# End:
# ex: set ts=8 sts=4 sw=4 tw=78 ft=perl expandtab shiftround :