2 class SQL::Translator::Object::Column extends SQL::Translator::Object is dirty {
3 use MooseX::Types::Moose qw(Bool Int Maybe ScalarRef Str);
4 use MooseX::MultiMethods;
5 use SQL::Translator::Types qw(Bit Constraint Table Trigger);
9 '""' => sub { shift->name },
10 'bool' => sub { $_[0]->name || $_[0] },
24 # trigger => sub { my ($self, $new, $old) = @_; if (defined $old) { $self->table->remove_column($old); $self->table->add_column($self) } }
32 trigger => sub { my ($self, $new, $old) = @_; $self->is_auto_increment(1) if $new =~ /^serial$/i; },
35 has 'sql_data_type' => (
47 predicate => 'has_length',
55 predicate => 'has_precision',
58 has 'is_nullable' => (
71 has 'default_value' => (
73 isa => Maybe[ScalarRef|Str],
76 has 'is_auto_increment' => (
84 has 'is_primary_key' => (
90 has 'is_foreign_key' => (
96 has 'foreign_key_reference' => (
107 $self->$orig(@args) if @args;
108 my @sizes = $self->$orig;
109 return wantarray ? @sizes
113 method full_name { $self->table->name . '.' . $self->name }
114 method schema { $self->table->schema }
119 before name($name?) { die "Can't use column name $name" if defined $name && $self->table->exists_column($name) && $name ne $self->name }
121 multi method size(Str $size) { my ($length, $precision) = split /,/, $size; $self->length($length); $self->precision($precision) if $precision; $self->size }
122 multi method size(Int $length, Int $precision) { $self->length($length); $self->precision($precision); $self->size }
123 multi method size(ArrayRef $size) { $self->length($size->[0]); $self->precision($size->[1]) if @$size == 2; $self->size }
126 return $self->has_precision
128 ? ($self->length, $self->precision)
129 : join ',', ($self->length, $self->precision)
133 method BUILD(HashRef $args) {
134 die "Cannot use column name $args->{name}" if $args->{name} eq '';
135 $self->size($args->{size}) if $args->{size}