package Data::MultiValued::AttributeTrait::Ranges; use Moose::Role; use namespace::autoclean; use Data::MultiValued::Ranges; with 'Data::MultiValued::AttributeTrait'; # ABSTRACT: attribute traits for attributes holding ranged values =head1 SYNOPSIS package My::Class; use Moose; use Data::MultiValued::AttributeTrait::Ranges; has stuff => ( is => 'rw', isa => 'Int', traits => ['MultiValued::Ranges'], predicate => 'has_stuff', multi_accessor => 'stuff_tagged', multi_predicate => 'has_stuff_tagged', ); =head1 DESCRIPTION This role consumes L and specialises it to use L as multi-value storage: =head2 C Returns C<'Data::MultiValued::Ranges'>. =head2 C Returns C<('from', 'to')>. =head2 C Returns C<('at')>. =head2 C my @ranges = $obj->meta->get_attribute('my_attr')->all_ranges($obj); Returns a list of 2-element arrayrefs, each arrayref describing the extremes of a range. Something like: [ [undef,10], [10,20], [20,undef] ] =cut sub multivalue_storage_class { 'Data::MultiValued::Ranges' }; sub opts_to_pass_set { qw(from to) } sub opts_to_pass_get { qw(at) } sub all_ranges { my ($self,$instance) = @_; my $storage = $self->get_full_storage($instance); return unless $storage; return $storage->_storage->all_ranges; } package Moose::Meta::Attribute::Custom::Trait::MultiValued::Ranges;{ sub register_implementation { 'Data::MultiValued::AttributeTrait::Ranges' } } 1;