Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add documentation link to Class::Tiny::ConstrainedAccessor #28

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 14 additions & 2 deletions lib/Class/Tiny.pm
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ sub prepare_class {
sub create_attributes {
my ( $class, $pkg, @spec ) = @_;
my %defaults = map { ref $_ eq 'HASH' ? %$_ : ( $_ => undef ) } @spec;
my @attr = grep {
my @attr = grep {
defined and !ref and /^[^\W\d]\w*$/s
or Carp::croak "Invalid accessor name '$_'"
} keys %defaults;
Expand Down Expand Up @@ -140,7 +140,7 @@ my $_PRECACHE = sub {
};

sub new {
my $class = shift;
my $class = shift;
my $valid_attrs = $ATTR_CACHE{$class} || $_PRECACHE->($class);

# handle hash ref or key/value arguments
Expand Down Expand Up @@ -458,6 +458,18 @@ and various subroutine references are cached for speed. Ensure that all
inheritance and methods are in place before creating objects. (You don't want
to be changing that once you create objects anyway, right?)

=head2 Type constraints (C<isa> relationships)

Class::Tiny does not natively apply type constraints to any attributes.
For example, there is no equivalent of the Moose C<isa> (e.g.,
C<< has 'birth_date' => ( isa => 'DateTime'); >>). You can apply constraints
manually by providing custom accessors (see L</Defining attributes>).

One shortcut is separately-distributed package
L<Class::Tiny::ConstrainedAccessor>. This package can create a custom accessor
that will apply a L<Type::Tiny>, L<MooseX::Types>, L<MooX::Types::MooseLike>,
L<MouseX::Types>, or L<Specio> type constraint.

=head1 RATIONALE

=head2 Why this instead of Object::Tiny or Class::Accessor or something else?
Expand Down
2 changes: 1 addition & 1 deletion t/alfa.t
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ subtest "both attributes set as hash ref" => sub {

subtest "constructor makes shallow copy" => sub {
my $fake = bless { foo => 23, bar => 42 }, "Fake";
my $obj = new_ok( "Alfa", [$fake] );
my $obj = new_ok( "Alfa", [$fake] );
is( ref $fake, "Fake", "object passed to constructor is original class" );
is( $obj->foo, 23, "foo is set" );
is( $obj->bar, 42, "bar is set" );
Expand Down
16 changes: 8 additions & 8 deletions t/hotel.t
Original file line number Diff line number Diff line change
Expand Up @@ -11,25 +11,25 @@ require_ok("Hotel");
subtest "attribute list" => sub {
my $attributes = [ sort Class::Tiny->get_all_attributes_for("Hotel") ];
is_deeply(
$attributes,
$attributes,
[ sort qw/foo bar wibble wobble zig zag/ ],
"attribute list correct",
) or diag explain $attributes;
};

subtest "attribute defaults" => sub {
my $def = Class::Tiny->get_all_attribute_defaults_for("Hotel");
is( keys %$def, 6, "defaults hashref size" );
is( $def->{foo}, undef, "foo default is undef" );
is( $def->{bar}, undef, "bar default is undef" );
is( $def->{wibble}, 23, "wibble default overrides" );
is( keys %$def, 6, "defaults hashref size" );
is( $def->{foo}, undef, "foo default is undef" );
is( $def->{bar}, undef, "bar default is undef" );
is( $def->{wibble}, 23, "wibble default overrides" );
};

subtest "attribute set as list" => sub {
my $obj = new_ok( "Hotel", [ foo => 42, bar => 23 ] );
is( $obj->foo, 42, "foo is set" );
is( $obj->bar, 23, "bar is set" );
is( $obj->wibble, 23, "wibble is set" );
is( $obj->foo, 42, "foo is set" );
is( $obj->bar, 23, "bar is set" );
is( $obj->wibble, 23, "wibble is set" );
is( ref $obj->wobble, 'HASH', "wobble default overrides" );
};

Expand Down
5 changes: 4 additions & 1 deletion t/lib/Foxtrot.pm
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ use warnings;
package Foxtrot;

use Class::Tiny 'foo';
use Class::Tiny { bar => 42, baz => sub { time } };
use Class::Tiny {
bar => 42,
baz => sub { time }
};

1;
6 changes: 4 additions & 2 deletions t/lib/Golf.pm
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,11 @@ use warnings;

package Golf;

use Class::Tiny qw/foo bar/, {
use Class::Tiny qw/foo bar/,
{
wibble => 42,
wobble => sub { [] },
}, qw/zig zag/;
},
qw/zig zag/;

1;
9 changes: 5 additions & 4 deletions t/lib/TestUtils.pm
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
use 5.006;
use strict;
use warnings;

package TestUtils;

use Carp;

use Exporter;
our @ISA = qw/Exporter/;
our @ISA = qw/Exporter/;
our @EXPORT = qw(
exception
exception
);

# If we have Test::FailWarnings, use it
Expand All @@ -17,9 +18,9 @@ BEGIN {
}

sub exception(&) {
my $code = shift;
my $code = shift;
my $success = eval { $code->(); 1 };
my $err = $@;
my $err = $@;
return '' if $success;
croak "Execution died, but the error was lost" unless $@;
return $@;
Expand Down