From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

use 5.008001;
use strict;
BEGIN {
$Error::TypeTiny::WrongNumberOfParameters::AUTHORITY = 'cpan:TOBYINK';
$Error::TypeTiny::WrongNumberOfParameters::VERSION = '2.008001';
}
$Error::TypeTiny::WrongNumberOfParameters::VERSION =~ tr/_//d;
our @ISA = 'Error::TypeTiny';
sub minimum { $_[0]{minimum} }
sub maximum { $_[0]{maximum} }
sub got { $_[0]{got} }
sub target { $_[0]{target} }
sub has_minimum { exists $_[0]{minimum} }
sub has_maximum { exists $_[0]{maximum} }
sub has_target { exists $_[0]{target} }
sub _build_message {
my $e = shift;
my $base = 'Wrong number of parameters';
if ( $e->has_target ) {
$base .= sprintf( ' to %s', $e->target );
}
if ( $e->has_minimum and $e->has_maximum and $e->minimum == $e->maximum ) {
return sprintf(
"%s; got %d; expected %d",
$base,
$e->got,
$e->minimum,
);
}
elsif ( $e->has_minimum and $e->has_maximum and $e->minimum < $e->maximum ) {
return sprintf(
"%s; got %d; expected %d to %d",
$base,
$e->got,
$e->minimum,
$e->maximum,
);
}
elsif ( $e->has_minimum ) {
return sprintf(
"%s; got %d; expected at least %d",
$base,
$e->got,
$e->minimum,
);
}
elsif ( $e->has_maximum ) {
return sprintf(
"%s; got %d; expected at most %d",
$base,
$e->got,
$e->maximum,
);
}
else {
return sprintf(
"%s; got %d",
$base,
$e->got,
);
}
} #/ sub _build_message
1;
__END__
=pod
=encoding utf-8
=head1 NAME
Error::TypeTiny::WrongNumberOfParameters - exception for Type::Params
=head1 STATUS
This module is covered by the
L<Type-Tiny stability policy|Type::Tiny::Manual::Policies/"STABILITY">.
=head1 DESCRIPTION
Thrown when a Type::Params compiled check is called with the wrong number
of parameters.
Also thrown by various parameterizable type constraints under similar
circumstances. For example, the C<< HashRef[Int] >> makes sense, but
C<< HashRef[Int, {}] >> does not.
This package inherits from L<Error::TypeTiny>; see that for most
documentation. Major differences are listed below:
=head2 Attributes
=over
=item C<minimum>
The minimum expected number of parameters.
=item C<maximum>
The maximum expected number of parameters.
=item C<got>
The number of parameters actually passed to the compiled check.
=item C<target>
A short string describing what there was the wrong number of parameters for.
=back
=head2 Methods
=over
=item C<has_minimum>, C<has_maximum>, C<has_target>
Predicate methods.
=back
=head1 BUGS
Please report any bugs to
=head1 SEE ALSO
L<Error::TypeTiny>.
=head1 AUTHOR
Toby Inkster E<lt>tobyink@cpan.orgE<gt>.
=head1 COPYRIGHT AND LICENCE
This software is copyright (c) 2013-2014, 2017-2025 by Toby Inkster.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=head1 DISCLAIMER OF WARRANTIES
THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.