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.