2 class SQL::Translator::Types {
3 use MooseX::Types::Moose qw(ArrayRef CodeRef Int Maybe Str Undef);
4 use MooseX::Types -declare, [qw(Column Constraint ForeignKey Index PrimaryKey Procedure Schema Sequence Table Trigger View DBIHandle ColumnSize Parser Producer Translator)];
6 class_type Column, { class => 'SQL::Translator::Object::Column' };
7 class_type Constraint, { class => 'SQL::Translator::Object::Constraint' };
8 class_type ForeignKey, { class => 'SQL::Translator::Object::ForeignKey' };
9 class_type Index, { class => 'SQL::Translator::Object::Index' };
10 class_type PrimaryKey, { class => 'SQL::Translator::Object::PrimaryKey' };
11 class_type Procedure, { class => 'SQL::Translator::Object::Procedure' };
12 class_type Schema, { class => 'SQL::Translator::Object::Schema' };
13 class_type Sequence, { class=> 'SQL::Translator::Object::Sequence' };
14 class_type Table, { class => 'SQL::Translator::Object::Table' };
15 class_type Trigger, { class => 'SQL::Translator::Object::Trigger' };
16 class_type View, { class => 'SQL::Translator::Object::View' };
18 class_type Parser, { class => 'SQL::Translator::Parser' };
19 class_type Producer, { class => 'SQL::Translator::Producer' };
20 class_type Translator, { class => 'SQL::Translator' };
22 subtype ColumnSize, as ArrayRef[Int];
24 from Int, via { [ $_ ] },
25 from Str, via { [ split /,/ ] },
26 from Undef, via { [ 0 ] };
28 subtype DBIHandle, as 'DBI::db';
32 via(\&_coerce_dbihandle_from_str),
34 via(\&_coerce_dbihandle_from_arrayref);
36 via(\&_coerce_dbihandle_from_coderef);
38 sub coerce_dbihandle_from_str { }
39 sub coerce_dbihandle_from_arrayref { }
40 sub coerce_dbihandle_from_coderef { }