NAME
Types::DualVar - type constraint for dualvars
SYNOPSIS
package MyClass {
use Moo;
use Types::Common::Numeric qw( PositiveInt );
use Types::DualVar qw( DualVar );
has attr => (
is => 'ro',
isa => DualVar->numifies_to(PositiveInt),
required => 1,
);
}
use Scalar::Util qw( dualvar );
# This is okay.
#
my $obj1 = MyClass->new(
attr => dualvar(2, "-1"),
);
# This is not okay.
#
my $obj2 = MyClass->new(
attr => dualvar(0, "666"),
);
# This is not okay.
#
my $obj3 = MyClass->new(
attr => 42,
);
DESCRIPTION
Types::DualVar is a type library for Moo, Moose, Mouse, or none of the above which offers just one type: DualVar.
DualVar corresponds to the isdual()
function from Scalar::Util.
The DualVar type is extended with the stringifies_to
and numifies_to
methods as documented in Type::Tiny::ConstrainedObject.
BUGS
Please report any bugs to http://rt.cpan.org/Dist/Display.html?Queue=Types-DualVar.
SEE ALSO
Type::Tiny::Manual, Scalar::Util.
AUTHOR
Toby Inkster <tobyink@cpan.org>.
COPYRIGHT AND LICENCE
This software is copyright (c) 2019 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.
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.