File: Is.pm

package info (click to toggle)
libsyntax-operator-is-perl 0.02-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 128 kB
  • sloc: perl: 108; makefile: 3
file content (140 lines) | stat: -rw-r--r-- 3,552 bytes parent folder | download
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
#  You may distribute under the terms of either the GNU General Public License
#  or the Artistic License (the same terms as Perl itself)
#
#  (C) Paul Evans, 2024 -- leonerd@leonerd.org.uk

package Syntax::Operator::Is 0.02;

use v5.14;
use warnings;

use Carp;

require XSLoader;
XSLoader::load( __PACKAGE__, our $VERSION );

=head1 NAME

C<Syntax::Operator::Is> - match operator using L<Data::Checks> constraints

=head1 SYNOPSIS

On Perl v5.38 or later:

   use v5.38;
   use Syntax::Operator::Is;

   use Data::Checks qw( Num Object );

   my $x = ...;

   if($x is Num) {
      say "x can be used as a number";
   }
   elsif($x is Object) {
      say "x can be used as an object";
   }

Or via L<Syntax::Keyword::Match> on Perl v5.14 or later:

   use v5.14;
   use Syntax::Operator::Is;
   use Syntax::Keyword::Match;

   use Data::Checks qw( Num Object );

   my $x = ...;

   match($x : is) {
      case(Num)    { say "x can be used as a number"; }
      case(Object) { say "x can be used as an object"; }
   }

=head1 DESCRIPTION

This module provides an infix operator that checks if a given value matches a
value constraint provided by L<Data::Checks>.

Support for custom infix operators was added in the Perl 5.37.x development
cycle and is available from development release v5.37.7 onwards, and therefore
in Perl v5.38 onwards. The documentation of L<XS::Parse::Infix>
describes the situation in more detail.

While Perl versions before this do not support custom infix operators, they
can still be used via C<XS::Parse::Infix> and hence L<XS::Parse::Keyword>.
Custom keywords which attempt to parse operator syntax may be able to use
these. One such module is L<Syntax::Keyword::Match>; see the SYNOPSIS example
given above.

=head2 Operator Name vs C<Test::More> / C<Test2::V0>

This module provides a named operator called C<is>. The same name is used by
both L<Test::More> and L<Test2::V0> as a unit test assertion function. Since
each has to be imported by request, this does not cause issues for code that
does not try to use both of them at once. Most real use-cases will not be unit
test scripts, and most unit test scripts will not need to use this operator.

In situations where you need to use this C<is> operator and one of the testing
modules at the same time (for example, during a unit test of some
check-related code), note that because of the way infix operator plugins work,
the named operator will always take precedence and thus you will need to call
the C<is()> testing function by its fully-qualified name:

   use Test2::V0;
   use Syntax::Operator::Is;

   Test2::V0::is( 1 is Num, builtin::true, '1 is Num' );

Alternatively, use the ability of L<XS::Parse::Infix> to import the operator
with a different name and avoid the collision.

   use Test2::V0;
   use Syntax::Operator::Is is => { -as => "is_checked" };

   is( 1 is_checked Num, builtin::true, '1 is Num' );

=cut

sub import
{
   my $pkg = shift;
   $pkg->apply( 1, @_ );
}

sub unimport
{
   my $pkg = shift;
   $pkg->apply( 0, @_ );
}

sub apply
{
   my $pkg = shift;
   my ( $on, @syms ) = @_;

   @syms or @syms = qw( is );

   $pkg->XS::Parse::Infix::apply_infix( $on, \@syms, qw( is ) );

   croak "Unrecognised import symbols @syms" if @syms;
}

=head1 OPERATORS

=head2 is

   my $ok = $value is $Constraint;

Yields true if the given value is accepted by the given constraint checker.
Yields false but should not otherwise throw an exception if the value is
rejected.

=cut

=head1 AUTHOR

Paul Evans <leonerd@leonerd.org.uk>

=cut

0x55AA;