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=ed40b02beb2890f8c5228732248018688df9d5c9;hp=3a0974b2088c414aa43cdab0cdb873e3fea8efd7;hb=d9183506af8ce9cd1339fceb19d941f293efb17b;hpb=b2b90ec28d4f51ef6e86e5acc2abb1dc92446147 diff --git a/lib/Catalyst/Utils.pm b/lib/Catalyst/Utils.pm index 3a0974b..ed40b02 100644 --- a/lib/Catalyst/Utils.pm +++ b/lib/Catalyst/Utils.pm @@ -6,6 +6,7 @@ use File::Spec; use HTTP::Request; use Path::Class; use URI; +use Class::Inspector; =head1 NAME @@ -210,9 +211,32 @@ sub request { return $request; } +=head2 ensure_class_loaded($class_name) + +Loads the class unless it already has been loaded. + +=cut + +sub ensure_class_loaded { + my $class = shift; + + return if Class::Inspector->loaded( $class ); # if a symbol entry exists we don't load again + + # this hack is so we don't overwrite $@ if the load did not generate an error + my $error; + { + local $@; + eval "require $class"; + $error = $@; + } + die $error if $error; +} + + =head1 AUTHOR Sebastian Riedel, C +Yuval Kogman, C =head1 COPYRIGHT