X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FSchema%2FLoader%2FDBI%2FSQLite.pm;h=23adaf5073c869ce12556a5371ad11e6c6c20399;hb=023596033b27c52ba85a41181004cf960d84fb75;hp=a68e23de1d18e93233d5262ad0e3c5d70e8b6333;hpb=bb46cd4b8d2cf185f37b632bc339d9669267c7fb;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/lib/DBIx/Class/Schema/Loader/DBI/SQLite.pm b/lib/DBIx/Class/Schema/Loader/DBI/SQLite.pm index a68e23d..23adaf5 100644 --- a/lib/DBIx/Class/Schema/Loader/DBI/SQLite.pm +++ b/lib/DBIx/Class/Schema/Loader/DBI/SQLite.pm @@ -6,7 +6,7 @@ use base 'DBIx::Class::Schema::Loader::DBI::Component::QuotedDefault'; use mro 'c3'; use DBIx::Class::Schema::Loader::Table (); -our $VERSION = '0.07021'; +our $VERSION = '0.07036_03'; =head1 NAME @@ -36,7 +36,7 @@ sub _setup { if (not defined $self->preserve_case) { $self->preserve_case(0); } - + if ($self->db_schema) { warn <<'EOF'; db_schema is not supported on SQLite, the option is implemented only for qualify_objects testing. @@ -126,11 +126,74 @@ sub _table_fk_info { push @{ $rel->{local_columns} }, $self->_lc($fk->{from}); push @{ $rel->{remote_columns} }, $self->_lc($fk->{to}) if defined $fk->{to}; + + $rel->{attrs} ||= { + on_delete => uc $fk->{on_delete}, + on_update => uc $fk->{on_update}, + }; + warn "This is supposed to be the same rel but remote_table changed from ", $rel->{remote_table}->name, " to ", $fk->{table} if $rel->{remote_table}->name ne $fk->{table}; } $sth->finish; + + # now we need to determine whether each FK is DEFERRABLE, this can only be + # done by parsing the DDL from sqlite_master + + my $ddl = $self->dbh->selectcol_arrayref(<<"EOF", undef, $table->name, $table->name)->[0]; +select sql from sqlite_master +where name = ? and tbl_name = ? +EOF + + foreach my $fk (@rels) { + my $local_cols = '"?' . (join '"? \s* , \s* "?', map quotemeta, @{ $fk->{local_columns} }) . '"?'; + my $remote_cols = '"?' . (join '"? \s* , \s* "?', map quotemeta, @{ $fk->{remote_columns} || [] }) . '"?'; + my ($deferrable_clause) = $ddl =~ / + foreign \s+ key \s* \( \s* $local_cols \s* \) \s* references \s* (?:\S+|".+?(?{attrs}{is_deferrable} = $deferrable_clause =~ /not/i ? 0 : 1; + } + else { + # check for inline constraint if 1 local column + if (@{ $fk->{local_columns} } == 1) { + my ($local_col) = @{ $fk->{local_columns} }; + my ($remote_col) = @{ $fk->{remote_columns} || [] }; + $remote_col ||= ''; + + my ($deferrable_clause) = $ddl =~ / + "?\Q$local_col\E"? \s* (?:\w+\s*)* (?: \( \s* \d\+ (?:\s*,\s*\d+)* \s* \) )? \s* + references \s+ (?:\S+|".+?(?{attrs}{is_deferrable} = $deferrable_clause =~ /not/i ? 0 : 1; + } + else { + $fk->{attrs}{is_deferrable} = 0; + } + } + else { + $fk->{attrs}{is_deferrable} = 0; + } + } + } + return \@rels; } @@ -205,3 +268,4 @@ the same terms as Perl itself. =cut 1; +# vim:et sts=4 sw=4 tw=0: