����JFIF��x�x����'
Server IP : 78.140.185.180 / Your IP : 3.19.76.4 Web Server : LiteSpeed System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : builderbox ( 1072) PHP Version : 7.3.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /usr/share/perl5/vendor_perl/Specio/Constraint/ |
Upload File : |
package Specio::Constraint::Intersection; use strict; use warnings; our $VERSION = '0.42'; use List::Util qw( all ); use Role::Tiny::With; use Specio::OO; use Storable qw( dclone ); use Specio::Constraint::Role::Interface; with 'Specio::Constraint::Role::Interface'; { ## no critic (Subroutines::ProtectPrivateSubs) my $attrs = dclone( Specio::Constraint::Role::Interface::_attrs() ); ## use critic for my $name (qw( _constraint _inline_generator )) { delete $attrs->{$name}{predicate}; $attrs->{$name}{init_arg} = undef; $attrs->{$name}{lazy} = 1; $attrs->{$name}{builder} = $name =~ /^_/ ? '_build' . $name : '_build_' . $name; } delete $attrs->{parent}; delete $attrs->{name}{predicate}; $attrs->{name}{lazy} = 1; $attrs->{name}{builder} = '_build_name'; $attrs->{of} = { isa => 'ArrayRef', required => 1, }; ## no critic (Subroutines::ProhibitUnusedPrivateSubroutines) sub _attrs { return $attrs; } } sub parent {undef} ## no critic (Subroutines::ProhibitUnusedPrivateSubroutines) sub _has_parent {0} sub _has_name { my $self = shift; return defined $self->name; } sub _build_name { my $self = shift; return unless all { $_->_has_name } @{ $self->of }; return join q{ & }, map { $_->name } @{ $self->of }; } ## no critic (Subroutines::ProhibitUnusedPrivateSubroutines) sub _has_constraint { my $self = shift; return !$self->_has_inline_generator; } ## use critic sub _build_constraint { return $_[0]->_optimized_constraint; } sub _build_optimized_constraint { my $self = shift; ## no critic (Subroutines::ProtectPrivateSubs) my @c = map { $_->_optimized_constraint } @{ $self->of }; return sub { return all { $_->( $_[0] ) } @c; }; } sub _has_inline_generator { my $self = shift; ## no critic (Subroutines::ProtectPrivateSubs) return all { $_->_has_inline_generator } @{ $self->of }; } sub _build_inline_generator { my $self = shift; return sub { return '(' . ( join q{ && }, map { sprintf( '( %s )', $_->_inline_generator->( $_, $_[1] ) ) } @{ $self->of } ) . ')'; } } sub _build_inline_environment { my $self = shift; my %env; for my $type ( @{ $self->of } ) { %env = ( %env, %{ $type->inline_environment }, ); } return \%env; } __PACKAGE__->_ooify; 1; # ABSTRACT: A class for intersection constraints __END__ =pod =encoding UTF-8 =head1 NAME Specio::Constraint::Intersection - A class for intersection constraints =head1 VERSION version 0.42 =head1 SYNOPSIS my $type = Specio::Constraint::Untion->new(...); =head1 DESCRIPTION This is a specialized type constraint class for intersections, which will allow a value which matches each one of several distinct types. =for Pod::Coverage parent =head1 API This class provides all of the same methods as L<Specio::Constraint::Simple>, with a few differences: =head2 Specio::Constraint::Intersection->new( ... ) The C<parent> parameter is ignored if it passed, as it is always C<undef> The C<inline_generator> and C<constraint> parameters are also ignored. This class provides its own default inline generator subroutine reference. Finally, this class requires an additional parameter, C<of>. This must be an arrayref of type objects. =head2 $union->of Returns an array reference of the individual types which makes up this intersection. =head1 ROLES This class does the L<Specio::Constraint::Role::Interface> and L<Specio::Role::Inlinable> roles. =head1 SUPPORT Bugs may be submitted at L<https://github.com/houseabsolute/Specio/issues>. I am also usually active on IRC as 'autarch' on C<irc://irc.perl.org>. =head1 SOURCE The source code repository for Specio can be found at L<https://github.com/houseabsolute/Specio>. =head1 AUTHOR Dave Rolsky <autarch@urth.org> =head1 COPYRIGHT AND LICENSE This software is Copyright (c) 2012 - 2017 by Dave Rolsky. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible) The full text of the license can be found in the F<LICENSE> file included with this distribution. =cut