X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst%2FUtils.pm;h=db890638bf7bced60370795430d4a7fe3319fe4d;hp=babcfa3c8115a1308cb4da6ef756b200add543f9;hb=cbe627b901f8e459035a76d423229694e1fefbff;hpb=ec4d72594fb7a701c2f36e85ecf9a680ca1abba2 diff --git a/lib/Catalyst/Utils.pm b/lib/Catalyst/Utils.pm index babcfa3..db89063 100644 --- a/lib/Catalyst/Utils.pm +++ b/lib/Catalyst/Utils.pm @@ -12,6 +12,7 @@ use String::RewritePrefix; use Class::Load (); use namespace::clean; use Devel::InnerPackage; +use Moose::Util; =head1 NAME @@ -509,6 +510,7 @@ Used to add components at runtime: into The Catalyst package to inject into (e.g. My::App) component The component package to inject + traits (Optional) ArrayRef of Ls that the componet should consume. as An optional moniker to use as the package name for the derived component For example: @@ -532,6 +534,11 @@ B This is basically a core version of L. If you can now use this safely instead. Going forward changes required to make this work will be synchronized with the core method. +B The 'traits' option is unique to the L version of this feature. + +B These injected components really need to be a L and a L +based class. + =cut sub inject_component { @@ -560,6 +567,7 @@ sub inject_component { unless ( Class::Load::is_class_loaded $component_package ) { eval "package $component_package; use base qw/$component/; 1;" or croak "Unable to build component package for \"$component_package\": $@"; + Moose::Util::apply_all_roles($component_package, @{$given{traits}}) if $given{traits}; (my $file = "$component_package.pm") =~ s{::}{/}g; $INC{$file} ||= 1; }