X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FComponentised.pm;h=5841afa09898b94d776b3a78a8ad1999cfb61728;hb=915919c594620a5440f01ee2e271c102f7613cc8;hp=42dec255a5bb5bb051ff0fe9aad06df628b512fc;hpb=175e261686dfde702e3539a47707024260c877b2;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/Componentised.pm b/lib/DBIx/Class/Componentised.pm index 42dec25..5841afa 100644 --- a/lib/DBIx/Class/Componentised.pm +++ b/lib/DBIx/Class/Componentised.pm @@ -64,10 +64,14 @@ sub _load_components { # # TODO: handle ->has_many('rel', 'Class'...) instead of # ->has_many('rel', 'Some::Schema::Class'...) +# +# BUG: For some reason, packages with syntax errors are added to %INC on +# require sub ensure_class_loaded { my ($class, $f_class) = @_; return if Class::Inspector->loaded($f_class); - require $f_class; + eval "require $f_class"; # require needs a bareword or filename + $class->throw_exception($@) if ($@); } # Returns true if the specified class is installed or already loaded, false