X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FSQL%2FTranslator%2FObject%2FColumn.pm;h=80aea11d096ea6ea9719ef7c3f7abc472f919a92;hb=815822d5f3e5685d46adcbb7fbaf296f27006ee6;hp=dea77914830034ad8df5c42224285c1bc3dfbafe;hpb=ebf2721d0450ee3a6c73b89e5d7c00d8af3d1105;p=dbsrgits%2FSQL-Translator-2.0-ish.git diff --git a/lib/SQL/Translator/Object/Column.pm b/lib/SQL/Translator/Object/Column.pm index dea7791..80aea11 100644 --- a/lib/SQL/Translator/Object/Column.pm +++ b/lib/SQL/Translator/Object/Column.pm @@ -1,57 +1,83 @@ use MooseX::Declare; -class SQL::Translator::Object::Column extends SQL::Translator::Object { - use MooseX::Types::Moose qw(ArrayRef Bool HashRef Int Maybe Str); +class SQL::Translator::Object::Column extends SQL::Translator::Object is dirty { + use MooseX::Types::Moose qw(Bool Int Maybe ScalarRef Str); use MooseX::MultiMethods; - use SQL::Translator::Types qw(ColumnSize Constraint Table Trigger); + use SQL::Translator::Types qw(Bit Constraint Table Trigger); + clean; + + use overload + '""' => sub { shift->name }, + 'bool' => sub { $_[0]->name || $_[0] }, + fallback => 1, + ; has 'table' => ( is => 'rw', isa => Table, - required => 1, weak_ref => 1, ); has 'name' => ( is => 'rw', isa => Str, - required => 1 + required => 1, +# trigger => sub { my ($self, $new, $old) = @_; if (defined $old) { $self->table->remove_column($old); $self->table->add_column($self) } } ); has 'data_type' => ( is => 'rw', isa => Str, - required => 1 + required => 1, + default => '', + trigger => sub { my ($self, $new, $old) = @_; $self->is_auto_increment(1) if $new =~ /^serial$/i; }, ); has 'sql_data_type' => ( is => 'rw', isa => Int, - required => 1 + required => 1, + default => 0 ); - has 'size' => ( + has 'length' => ( is => 'rw', - isa => ColumnSize, - coerce => 1, - auto_deref => 1, + isa => Int, + default => 0, + lazy => 1, + predicate => 'has_length', + ); + + has 'precision' => ( + is => 'rw', + isa => Int, + default => 0, + lazy => 1, + predicate => 'has_precision', ); has 'is_nullable' => ( is => 'rw', - isa => Bool, + isa => Bit, required => 1, default => 1 ); + + has 'is_unique' => ( + is => 'rw', + isa => Bool, + default => 0, + ); has 'default_value' => ( is => 'rw', - isa => Maybe[Str], + isa => Maybe[ScalarRef|Str], ); has 'is_auto_increment' => ( is => 'rw', - isa => Bool, + isa => Bit, required => 1, + coerce => 1, default => 0 ); @@ -77,6 +103,11 @@ class SQL::Translator::Object::Column extends SQL::Translator::Object { isa => Trigger, ); + has '_order' => ( + is => 'rw', + isa => Int, + ); + around size(@args) { $self->$orig(@args) if @args; my @sizes = $self->$orig; @@ -84,6 +115,36 @@ class SQL::Translator::Object::Column extends SQL::Translator::Object { : join ',', @sizes; } - method order { } - method is_unique { } + method full_name { $self->table->name . '.' . $self->name } + method schema { $self->table->schema } + + before name($name?) { die "Can't use column name $name" if defined $name && $self->table->exists_column($name) && $name ne $self->name } + + multi method size(Str $size) { my ($length, $precision) = split /,/, $size; $self->length($length); $self->precision($precision) if $precision; $self->size } + multi method size(Int $length, Int $precision) { $self->length($length); $self->precision($precision); $self->size } + multi method size(ArrayRef $size) { $self->length($size->[0]); $self->precision($size->[1]) if @$size == 2; $self->size } + + multi method size { + return $self->has_precision + ? wantarray + ? ($self->length, $self->precision) + : join ',', ($self->length, $self->precision) + : $self->length; + } + + multi method order(Int $order) { $self->_order($order); } + multi method order { + my $order = $self->_order; + unless (defined $order && $order) { + my $columns = Tie::IxHash->new( map { $_->name => $_ } $self->table->get_columns ); + $order = ($columns->Indices($self->name) + 1) || 0; + $self->_order($order); + } + return $order; + } + + method BUILD(HashRef $args) { + die "Cannot use column name $args->{name}" if $args->{name} eq ''; + $self->size($args->{size}) if $args->{size}; + } }