package Moose::Meta::Attribute::Native::Trait::Bool; use Moose::Role; our $VERSION = '1.25'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; use Moose::Meta::Method::Accessor::Native::Bool::not; use Moose::Meta::Method::Accessor::Native::Bool::set; use Moose::Meta::Method::Accessor::Native::Bool::toggle; use Moose::Meta::Method::Accessor::Native::Bool::unset; with 'Moose::Meta::Attribute::Native::Trait'; sub _default_is { 'rw' } sub _helper_type { 'Bool' } no Moose::Role; 1; =pod =head1 NAME Moose::Meta::Attribute::Native::Trait::Bool - Helper trait for Bool attributes =head1 SYNOPSIS package Room; use Moose; has 'is_lit' => ( traits => ['Bool'], is => 'rw', isa => 'Bool', default => 0, handles => { illuminate => 'set', darken => 'unset', flip_switch => 'toggle', is_dark => 'not', }, ); my $room = Room->new(); $room->illuminate; # same as $room->is_lit(1); $room->darken; # same as $room->is_lit(0); $room->flip_switch; # same as $room->is_lit(not $room->is_lit); return $room->is_dark; # same as !$room->is_lit =head1 DESCRIPTION This trait provides native delegation methods for boolean values. A boolean is a scalar which can be C<1>, C<0>, C<"">, or C. =head1 DEFAULT TYPE If you don't provide an C value for your attribute, it will default to C. =head1 PROVIDED METHODS None of these methods accept arguments. =over 4 =item * B Sets the value to C<1> and returns C<1>. =item * B Set the value to C<0> and returns C<0>. =item * B Toggles the value. If it's true, set to false, and vice versa. Returns the new value. =item * B Equivalent of 'not C<$value>'. =back =head1 BUGS See L for details on reporting bugs. =head1 AUTHOR Jason May =head1 COPYRIGHT AND LICENSE Copyright 2007-2010 by Infinity Interactive, Inc. L This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut