X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FRelationship%2FBelongsTo.pm;h=050c1e4af0f409dfef93d2e6e08c362e5b7cca7b;hb=ed7ab0f4ce1a9118ea6285ee562ef003085a6b64;hp=471a417fc82c9b3a9b1d8ed3d125c283a3b24fbb;hpb=7803e57ad8daee28020676140ea6894c31e3112e;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Relationship/BelongsTo.pm b/lib/DBIx/Class/Relationship/BelongsTo.pm index 471a417..050c1e4 100644 --- a/lib/DBIx/Class/Relationship/BelongsTo.pm +++ b/lib/DBIx/Class/Relationship/BelongsTo.pm @@ -6,6 +6,7 @@ package # hide from PAUSE use strict; use warnings; +use Try::Tiny; our %_pod_inherit_config = ( @@ -24,10 +25,10 @@ sub belongs_to { # no join condition or just a column name if (!ref $cond) { $class->ensure_class_loaded($f_class); - my %f_primaries = map { $_ => 1 } eval { $f_class->_pri_cols }; - $class->throw_exception( - "Can't infer join condition for ${rel} on ${class}: $@" - ) if $@; + my %f_primaries = map { $_ => 1 } try { $f_class->_pri_cols } + catch { + $class->throw_exception( "Can't infer join condition for ${rel} on ${class}: $_"); + }; my ($pri, $too_many) = keys %f_primaries; $class->throw_exception(