X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FConstructor.pm;h=f2e78b9251aa0193b7278d0e35d4809fd76200dc;hb=d2bc7045e78e5bc547e32133e48d2f994d158491;hp=f44079b64cbed5282c387e65e29732dcfabf24f2;hpb=28f7f7d31e0d17c5362935ac52f7e67a189ddf0f;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/CDBICompat/Constructor.pm b/lib/DBIx/Class/CDBICompat/Constructor.pm index f44079b..f2e78b9 100644 --- a/lib/DBIx/Class/CDBICompat/Constructor.pm +++ b/lib/DBIx/Class/CDBICompat/Constructor.pm @@ -1,22 +1,32 @@ package # hide from PAUSE DBIx::Class::CDBICompat::Constructor; +use base qw(DBIx::Class::CDBICompat::ImaDBI); + +use Sub::Name(); + use strict; use warnings; +use Carp; + +__PACKAGE__->set_sql(Retrieve => <<''); +SELECT __ESSENTIAL__ +FROM __TABLE__ +WHERE %s + sub add_constructor { - my ($class, $meth, $sql) = @_; - $class = ref $class if ref $class; - no strict 'refs'; - - my %attrs; - $attrs{rows} = $1 if $sql =~ s/LIMIT\s+(.*)\s+$//i; - $attrs{order_by} = $1 if $sql =~ s/ORDER BY\s+(.*)//i; - - *{"${class}::${meth}"} = - sub { - my ($class, @args) = @_; - return $class->search_literal($sql, @args, \%attrs); + my ($class, $method, $fragment) = @_; + return croak("constructors needs a name") unless $method; + + no strict 'refs'; + my $meth = "$class\::$method"; + return carp("$method already exists in $class") + if *$meth{CODE}; + + *$meth = Sub::Name::subname $meth => sub { + my $self = shift; + $self->sth_to_objects($self->sql_Retrieve($fragment), \@_); }; }