File: Callback.pm

package info (click to toggle)
libhtml-widget-perl 1.11-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,052 kB
  • sloc: perl: 3,651; makefile: 4
file content (64 lines) | stat: -rw-r--r-- 1,056 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package HTML::Widget::Constraint::Callback;

use warnings;
use strict;
use base 'HTML::Widget::Constraint';

__PACKAGE__->mk_accessors(qw/callback/);

*cb = \&callback;

=head1 NAME

HTML::Widget::Constraint::Callback - Callback Constraint

=head1 SYNOPSIS

    my $c = $widget->constraint( 'Callback', 'foo' )->callback(sub { 
        my $value=shift;
        return 1;
    });

=head1 DESCRIPTION

A callback constraint which will only be run once for each submitted value 
of each named field.

=head1 METHODS

=head2 callback

=head2 cb

Arguments: \&callback

Define the callback to be used for validation.

L</cb> is an alias for L</callback>.

=head2 validate

perform the actual validation.

=cut

sub validate {
    my ( $self, $value ) = @_;
    my $callback = $self->callback || sub {1};
    return $callback->($value);
}

=head1 AUTHOR

Sebastian Riedel, C<sri@oook.de>

Marcus Ramberg, C<mramberg@cpan.org>

=head1 LICENSE

This library is free software, you can redistribute it and/or modify it under
the same terms as Perl itself.

=cut

1;