X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FModel%2FDBIC%2FSchema.pm;h=30518fefda97e4818f73d4e47e4a6c7d481de321;hb=6d9e2623d6b25c6b85e2df1fd940a2490712d9f0;hp=993c02c49d5aada4850d0fcd52b2622db2fd1c63;hpb=7bd33abf92b0dfcfdd086532511e941868754d8b;p=catagits%2FCatalyst-Model-DBIC-Schema.git diff --git a/lib/Catalyst/Model/DBIC/Schema.pm b/lib/Catalyst/Model/DBIC/Schema.pm index 993c02c..30518fe 100644 --- a/lib/Catalyst/Model/DBIC/Schema.pm +++ b/lib/Catalyst/Model/DBIC/Schema.pm @@ -5,14 +5,13 @@ use mro 'c3'; extends 'Catalyst::Model'; with 'CatalystX::Component::Traits'; -our $VERSION = '0.26'; +our $VERSION = '0.27'; +$VERSION = eval $VERSION; use namespace::autoclean; use Carp::Clan '^Catalyst::Model::DBIC::Schema'; use Data::Dumper; use DBIx::Class (); -use Moose::Autobox; -use Class::Inspector (); use Catalyst::Model::DBIC::Schema::Types qw/ConnectInfo LoadedClass/; @@ -200,6 +199,8 @@ for more info. =head1 CONFIG PARAMETERS +Any options in your config not listed here are passed to your schema. + =head2 schema_class This is the classname of your L Schema. It needs @@ -263,6 +264,7 @@ Or using L: on_connect_do some SQL statement on_connect_do another SQL statement + user_defined_schema_accessor foo or @@ -276,14 +278,14 @@ Or using L: Model::MyDB: schema_class: MyDB + traits: Caching connect_info: dsn: dbi:Oracle:mydb user: mtfnpy password: mypass LongReadLen: 1000000 LongTruncOk: 1 - on_connect_do: [ "alter session set nls_date_format = 'YYYY-MM-DD HH24:MI:SS'" ] - cursor_class: 'DBIx::Class::Cursor::Cached' + on_connect_call: 'datetime_setup' quote_char: '"' The old arrayref style with hashrefs for L then L options is also @@ -467,7 +469,7 @@ has _default_cursor_class => ( ); sub BUILD { - my $self = shift; + my ($self, $args) = @_; my $class = $self->_original_class_name; my $schema_class = $self->schema_class; @@ -503,7 +505,7 @@ sub BUILD { $self->schema($self->composed_schema->clone); - $self->_pass_options_to_schema; + $self->_pass_options_to_schema($args); $self->schema->storage_type($self->storage_type) if $self->storage_type; @@ -590,8 +592,8 @@ sub _build_model_name { sub _delegates { my $self = shift; -# XXX change this to CMOP once CAG is updated - my @schema_methods = @{ Class::Inspector->methods($self->schema_class) }; + my $schema_meta = Class::MOP::Class->initialize($self->schema_class); + my @schema_methods = $schema_meta->get_all_method_names; # combine with any already added by other schemas my @handles = eval { @@ -599,7 +601,7 @@ sub _delegates { }; # now kill the attribute, otherwise add_attribute in BUILD will not do the right -# thing. May be a Moose bug. +# thing (it clears the handles for some reason.) May be a Moose bug. eval { $self->meta->remove_attribute('schema') }; my %schema_methods; @@ -619,16 +621,18 @@ sub _delegates { } sub _pass_options_to_schema { - my $self = shift; + my ($self, $args) = @_; + + my @attributes = map { + $_->init_arg || () + } $self->meta->get_all_attributes; - my @attributes = map $_->name, $self->meta->get_all_attributes; my %attributes; @attributes{@attributes} = (); - for my $opt (keys %$self) { + for my $opt (keys %$args) { if (not exists $attributes{$opt}) { - die "Invalid schema option: $opt" unless $self->schema->can($opt); - + next unless $self->schema->can($opt); $self->schema->$opt($self->{$opt}); } } @@ -662,9 +666,11 @@ Brandon L Black C caelum: Rafael Kitover C +Dan Dascalescu C + =head1 COPYRIGHT -This program is free software, you can redistribute it and/or modify it +This program is free software. You can redistribute it and/or modify it under the same terms as Perl itself. =cut