X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=789c6ab9f987b41334456a1761e787f5c9e36946;hb=822fe9544767709e6d75eda2b0cbcfb46bb494dd;hp=4c3fb7087d58f778ae542e2883fb87589ce4ffe1;hpb=4aff785ce6f9059a371c0d85dfd8c259a26c98c6;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 4c3fb70..789c6ab 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -2,7 +2,8 @@ package Catalyst::Base; use strict; use base qw/Class::Data::Inheritable Class::Accessor::Fast/; -use Catalyst::Utils; + +use Catalyst::Exception; use NEXT; __PACKAGE__->mk_classdata($_) for qw/_attr_cache _action_cache _config/; @@ -70,12 +71,11 @@ component loader with config() support and a process() method placeholder. sub new { my ( $self, $c ) = @_; - my $class = ref $self || $self; - my $appname = Catalyst::Utils::class2appclass($class); - my $suffix = Catalyst::Utils::class2classsuffix($class); - my $appconfig = $appname->config->{$suffix} || {}; - my $config = { %{ $self->config }, %{$appconfig} }; - return $self->NEXT::new($config); + + # Temporary fix, some components does not pass context to constructor + my $arguments = ( ref( $_[-1] ) eq 'HASH' ) ? $_[-1] : {}; + + return $self->NEXT::new( { %{ $self->config }, %{ $arguments } } ); } # remember to leave blank lines between the consecutive =item's @@ -106,7 +106,10 @@ sub config { =cut sub process { - die( ( ref $_[0] || $_[0] ) . " did not override Catalyst::Base::process" ); + + Catalyst::Exception->throw( + message => ( ref $_[0] || $_[0] ) . " did not override Catalyst::Base::process" + ); } =item FETCH_CODE_ATTRIBUTES