X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FRequest%2FREST.pm;h=e7128ca8fac33ad92341e62fad0997b74b24d568;hb=e527bba30dcea5108b0fb77416fcb4e8ee1e5a38;hp=4684b64ab7974288d58e12dbd10f7ac3b6b658f0;hpb=96a61a601b093754a99bb61b57e41dbfc3228ad7;p=catagits%2FCatalyst-Action-REST.git diff --git a/lib/Catalyst/Request/REST.pm b/lib/Catalyst/Request/REST.pm index 4684b64..e7128ca 100644 --- a/lib/Catalyst/Request/REST.pm +++ b/lib/Catalyst/Request/REST.pm @@ -7,7 +7,7 @@ use namespace::autoclean; extends 'Catalyst::Request'; with 'Catalyst::TraitFor::Request::REST'; -our $VERSION = '0.84'; +our $VERSION = '0.87'; $VERSION = eval $VERSION; # Please don't take this as a recommended way to do things. @@ -24,13 +24,18 @@ sub _insert_self_into { 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 $meta = Moose::Meta::Class->create_anon_class( - superclasses => [$req_class], - roles => ['Catalyst::TraitFor::Request::REST'], - cache => 1 - ); - $meta->add_method(meta => sub { $meta }); - $app->request_class($meta->name); + 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'], + cache => 1 + ); + $meta->_add_meta_method('meta'); + $app->request_class($meta->name); + } } __PACKAGE__->meta->make_immutable;