X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FRequest%2FREST.pm;h=0fcd31cd09a250eb21724b77ce823ca63386097d;hb=f789417d081b4d519ded07eec046c0b01661e25d;hp=be37d0a21c90c49e163299b0625245f53ec67a4b;hpb=ab8ab47a739539677817d6a7493b888c7a7815f6;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Request/REST.pm b/lib/Catalyst/Request/REST.pm index be37d0a..0fcd31c 100644 --- a/lib/Catalyst/Request/REST.pm +++ b/lib/Catalyst/Request/REST.pm @@ -1,4 +1,5 @@ package Catalyst::Request::REST; + use Moose; use Catalyst::Utils; @@ -7,9 +8,6 @@ use namespace::autoclean; extends 'Catalyst::Request'; with 'Catalyst::TraitFor::Request::REST'; -our $VERSION = '0.85'; -$VERSION = eval $VERSION; - # Please don't take this as a recommended way to do things. # The code below is grotty, badly factored and mostly here for back # compat.. @@ -23,22 +21,28 @@ sub _insert_self_into { my $req_class = $app->request_class; return if $req_class->isa($class); my $req_class_meta = Moose->init_meta( for_class => $req_class ); - return if $req_class_meta->does_role('Catalyst::TraitFor::Request::REST'); + my $role = $class->_related_role; + return if $req_class_meta->does_role($role); if ($req_class eq 'Catalyst::Request') { $app->request_class($class); } else { my $meta = Moose::Meta::Class->create_anon_class( superclasses => [$req_class], - roles => ['Catalyst::TraitFor::Request::REST'], + roles => [$role], cache => 1 ); - $meta->add_method(meta => sub { $meta }); + $meta->_add_meta_method('meta'); $app->request_class($meta->name); } } +sub _related_role { 'Catalyst::TraitFor::Request::REST' } + __PACKAGE__->meta->make_immutable; + +1; + __END__ =head1 NAME