use MooseX::Declare;
-class SQL::Translator::Object::Column {
- use MooseX::Types::Moose qw(Bool HashRef Int Maybe Str);
- use SQL::Translator::Types qw(Trigger);
- extends 'SQL::Translator::Object';
+class SQL::Translator::Object::Column extends SQL::Translator::Object {
+ use MooseX::Types::Moose qw(Bool Int Maybe Str);
+ use MooseX::MultiMethods;
+ use SQL::Translator::Types qw(ColumnSize Constraint Table Trigger);
+
+ has 'table' => (
+ is => 'rw',
+ isa => Table,
+ required => 1,
+ weak_ref => 1,
+ );
has 'name' => (
is => 'rw',
has 'data_type' => (
is => 'rw',
+ isa => Str,
+ required => 1
+ );
+
+ has 'sql_data_type' => (
+ is => 'rw',
isa => Int,
required => 1
);
has 'size' => (
is => 'rw',
- isa => Maybe[Int],
- required => 1
+ isa => ColumnSize,
+ coerce => 1,
+ auto_deref => 1,
);
has 'is_nullable' => (
default => 1
);
+ has 'default_value' => (
+ is => 'rw',
+ isa => Maybe[Str],
+ );
+
has 'is_auto_increment' => (
is => 'rw',
isa => Bool,
required => 1,
default => 0
);
-
- has 'default_value' => (
- is => 'rw',
- isa => Maybe[Str],
- );
-
- has 'comments' => (
+
+ has 'is_primary_key' => (
is => 'rw',
- isa => Maybe[Str],
+ isa => Bool,
+ default => 0
);
- has 'is_primary_key' => (
+ has 'is_foreign_key' => (
is => 'rw',
isa => Bool,
default => 0
);
+
+ has 'foreign_key_reference' => (
+ is => 'rw',
+ isa => Constraint,
+ );
has 'trigger' => (
is => 'rw',
isa => Trigger,
);
- has 'extra' => (
- is => 'rw',
- isa => HashRef,
- auto_deref => 1,
- );
+ around size(@args) {
+ $self->$orig(@args) if @args;
+ my @sizes = $self->$orig;
+ return wantarray ? @sizes
+ : join ',', @sizes;
+ }
+
+ method order { }
+ method is_unique { }
}