Acme-Mitey-Cards
view release on metacpan or search on metacpan
lib/Acme/Mitey/Cards/Set.pm.mite.pm view on Meta::CPAN
);
};
$ok;
}
)
or croak "Type check failed in constructor: %s should be %s",
"cards", "CardArray";
$self->{"cards"} = $args->{"cards"};
}
# Call BUILD methods
$self->BUILDALL($args) if ( !$no_build and @{ $meta->{BUILD} || [] } );
# Unrecognized parameters
my @unknown = grep not(/\Acards\z/), keys %{$args};
@unknown
and croak(
"Unexpected keys in constructor: " . join( q[, ], sort @unknown ) );
return $self;
}
# Used by constructor to call BUILD methods
sub BUILDALL {
my $class = ref( $_[0] );
my $meta = ( $Mite::META{$class} ||= $class->__META__ );
$_->(@_) for @{ $meta->{BUILD} || [] };
}
# Destructor should call DEMOLISH methods
sub DESTROY {
my $self = shift;
my $class = ref($self) || $self;
my $meta = ( $Mite::META{$class} ||= $class->__META__ );
my $in_global_destruction =
defined ${^GLOBAL_PHASE}
? ${^GLOBAL_PHASE} eq 'DESTRUCT'
: Devel::GlobalDestruction::in_global_destruction();
for my $demolisher ( @{ $meta->{DEMOLISH} || [] } ) {
my $e = do {
local ( $?, $@ );
eval { $demolisher->( $self, $in_global_destruction ) };
$@;
};
no warnings 'misc'; # avoid (in cleanup) warnings
die $e if $e; # rethrow
}
return;
}
my $__XS = !$ENV{PERL_ONLY}
&& eval { require Class::XSAccessor; Class::XSAccessor->VERSION("1.19") };
# Accessors for cards
# has declaration, file lib/Acme/Mitey/Cards/Set.pm, line 11
sub cards {
@_ == 1 or croak('Reader "cards" usage: $self->cards()');
(
exists( $_[0]{"cards"} ) ? $_[0]{"cards"} : (
$_[0]{"cards"} = do {
my $default_value = $_[0]->_build_cards;
do {
package Acme::Mitey::Cards::Mite;
( ref($default_value) eq 'ARRAY' ) and do {
my $ok = 1;
for my $i ( @{$default_value} ) {
( $ok = 0, last )
unless (
do {
use Scalar::Util ();
Scalar::Util::blessed($i)
and
$i->isa(q[Acme::Mitey::Cards::Card]);
}
);
};
$ok;
}
}
or croak( "Type check failed in default: %s should be %s",
"cards", "CardArray" );
$default_value;
}
)
);
}
# See UNIVERSAL
sub DOES {
my ( $self, $role ) = @_;
our %DOES;
return $DOES{$role} if exists $DOES{$role};
return 1 if $role eq __PACKAGE__;
if ( $INC{'Moose/Util.pm'}
and my $meta = Moose::Util::find_meta( ref $self or $self ) )
{
$meta->can('does_role') and $meta->does_role($role) and return 1;
}
return $self->SUPER::DOES($role);
}
# Alias for Moose/Moo-compatibility
sub does {
shift->DOES(@_);
}
# Method signatures
our %SIGNATURE_FOR;
$SIGNATURE_FOR{"count"} = sub {
my $__NEXT__ = shift;
my ( %tmp, $tmp, @head );
@_ == 1
or
croak( "Wrong number of parameters in signature for %s: got %d, %s",
"count", scalar(@_), "expected exactly 1 parameters" );
@head = splice( @_, 0, 1 );
# Parameter invocant (type: Defined)
( defined( $head[0] ) )
or croak( "Type check failed in signature for count: %s should be %s",
"\$_[0]", "Defined" );
do { @_ = ( @head, @_ ); goto $__NEXT__ };
};
$SIGNATURE_FOR{"take"} = sub {
my $__NEXT__ = shift;
my ( %tmp, $tmp, @head );
@_ == 2
or
croak( "Wrong number of parameters in signature for %s: got %d, %s",
"take", scalar(@_), "expected exactly 2 parameters" );
@head = splice( @_, 0, 1 );
# Parameter invocant (type: Defined)
( run in 1.421 second using v1.01-cache-2.11-cpan-5a3173703d6 )