Server IP : 149.255.58.128 / Your IP : 216.73.216.30
System : Linux cloud516.thundercloud.uk 5.14.0-427.26.1.el9_4.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Jul 17 15:51:13 EDT 2024 x86_64
PHP Version : 8.2.28
Disable Function : allow_url_include, apache_child_terminate, apache_setenv, exec, passthru, pcntl_exec, posix_kill, posix_mkfifo, posix_getpwuid, posix_setpgid, posix_setsid, posix_setuid, posix_setgid, posix_seteuid, posix_setegid, posix_uname, proc_close, proc_get_status, proc_open, proc_terminate, shell_exec, show_source, system
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Upload Files :
Command :
Current File : /usr/local/lib64/perl5/5.32/Template/Plugin//Assert.pm
#============================================================= -*-Perl-*-
#
# Template::Plugin::Assert
#
# DESCRIPTION
# Template Toolkit plugin module which allows you to assert that
# items fetches from the stash are defined.
#
# AUTHOR
# Andy Wardley <abw@wardley.org>
#
# COPYRIGHT
# Copyright (C) 2008-2022 Andy Wardley. All Rights Reserved.
#
# This module is free software; you can redistribute it and/or
# modify it under the same terms as Perl itself.
#
#============================================================================
package Template::Plugin::Assert;
use base 'Template::Plugin';
use strict;
use warnings;
use Template::Exception;
our $VERSION = '3.100';
our $MONAD = 'Template::Monad::Assert';
our $EXCEPTION = 'Template::Exception';
our $AUTOLOAD;
sub load {
my $class = shift;
my $context = shift;
my $stash = $context->stash;
my $vmethod = sub {
$MONAD->new($stash, shift);
};
# define .assert vmethods for hash and list objects
$context->define_vmethod( hash => assert => $vmethod );
$context->define_vmethod( list => assert => $vmethod );
return $class;
}
sub new {
my ($class, $context, @args) = @_;
# create an assert plugin object which will handle simple variable
# lookups.
return bless { _CONTEXT => $context }, $class;
}
sub AUTOLOAD {
my ($self, @args) = @_;
my $item = $AUTOLOAD;
$item =~ s/.*:://;
return if $item eq 'DESTROY';
# lookup the named values
my $stash = $self->{ _CONTEXT }->stash;
my $value = $stash->dotop($stash, $item, \@args);
if (! defined $value) {
die $EXCEPTION->new( assert => "undefined value for $item" );
}
return $value;
}
package Template::Monad::Assert;
our $EXCEPTION = 'Template::Exception';
our $AUTOLOAD;
sub new {
my ($class, $stash, $this) = @_;
bless [$stash, $this], $class;
}
sub AUTOLOAD {
my ($self, @args) = @_;
my ($stash, $this) = @$self;
my $item = $AUTOLOAD;
$item =~ s/.*:://;
return if $item eq 'DESTROY';
my $value = $stash->dotop($stash, $item, \@args);
if (! defined $value) {
die $EXCEPTION->new( assert => "undefined value for $item" );
}
return $value;
}
1;
__END__
=head1 NAME
Template::Plugin::Assert - trap undefined values
=head1 SYNOPSIS
[% USE assert %]
# throws error if any undefined values are returned
[% object.assert.method %]
[% hash.assert.key %]
[% list.assert.item %]
=head1 DESCRIPTION
This plugin defines the C<assert> virtual method that can be used
to automatically throw errors when undefined values are used.
For example, consider this dotop:
[% user.name %]
If C<user.name> is an undefined value then TT will silently ignore the
fact and print nothing. If you C<USE> the C<assert> plugin then you
can add the C<assert> vmethod between the C<user> and C<name> elements,
like so:
[% user.assert.name %]
Now, if C<user.name> is an undefined value, an exception will be thrown:
assert error - undefined value for name
=head1 AUTHOR
Andy Wardley E<lt>abw@wardley.orgE<gt> L<http://wardley.org/>
=head1 COPYRIGHT
Copyright (C) 2008-2022 Andy Wardley. All Rights Reserved.
This module is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.
=head1 SEE ALSO
L<Template::Plugin>
=cut
# Local Variables:
# mode: perl
# perl-indent-level: 4
# indent-tabs-mode: nil
# End:
#
# vim: expandtab shiftwidth=4:
Name |
Size |
Last Modified |
Owner / Group |
Permissions |
Options |
.. | -- | February 06 2024 22:25:04 | 0 / root | 0755 | |
| | | | | |
Assert.pm | 3.426 KB | July 26 2022 06:42:11 | 0 / root | 0444 | |
Datafile.pm | 4.4 KB | July 26 2022 06:42:21 | 0 / root | 0444 | |
Date.pm | 11.219 KB | July 26 2022 07:09:42 | 0 / root | 0444 | |
Directory.pm | 10.898 KB | July 26 2022 06:43:06 | 0 / root | 0444 | |
Dumper.pm | 3.655 KB | July 25 2022 18:57:15 | 0 / root | 0444 | |
File.pm | 10.917 KB | July 26 2022 07:10:13 | 0 / root | 0444 | |
Filter.pm | 9.629 KB | July 26 2022 06:43:36 | 0 / root | 0444 | |
Format.pm | 1.789 KB | July 26 2022 06:43:45 | 0 / root | 0444 | |
HTML.pm | 5.87 KB | July 26 2022 06:43:59 | 0 / root | 0444 | |
Image.pm | 11.433 KB | July 26 2022 07:10:56 | 0 / root | 0444 | |
Iterator.pm | 1.954 KB | July 26 2022 06:44:16 | 0 / root | 0444 | |
Math.pm | 3.994 KB | July 26 2022 06:44:36 | 0 / root | 0444 | |
Pod.pm | 1.611 KB | July 26 2022 06:44:44 | 0 / root | 0444 | |
Procedural.pm | 3.595 KB | July 25 2022 18:57:15 | 0 / root | 0444 | |
Scalar.pm | 3.675 KB | July 26 2022 06:45:02 | 0 / root | 0444 | |
String.pm | 17.692 KB | July 26 2022 06:45:13 | 0 / root | 0444 | |
Table.pm | 12.409 KB | July 26 2022 07:13:22 | 0 / root | 0444 | |
URL.pm | 5.665 KB | July 26 2022 07:13:38 | 0 / root | 0444 | |
View.pm | 2.399 KB | July 26 2022 06:45:43 | 0 / root | 0444 | |
Wrap.pm | 3.177 KB | July 26 2022 06:45:52 | 0 / root | 0444 | |