fix issue with order being wrong
[dbsrgits/SQL-Translator-2.0-ish.git] / lib / SQL / Translator / Types.pm
1 use MooseX::Declare;
2 class SQL::Translator::Types {
3     use MooseX::Types::Moose qw(ArrayRef CodeRef HashRef Int Maybe Str Undef);
4     use MooseX::Types -declare, [qw(Column Constraint ForeignKey Index PrimaryKey Procedure Schema Sequence Table Trigger View
5                                     Bit DBIHandle MatchType Parser Producer Translator DBICSchema)];
6
7     class_type DBICSchema, { class => 'DBIx::Class::Schema' };
8     
9     class_type Column, { class => 'SQL::Translator::Object::Column' };
10     class_type Constraint, { class => 'SQL::Translator::Object::Constraint' };
11     class_type ForeignKey, { class => 'SQL::Translator::Object::ForeignKey' };
12     class_type Index, { class => 'SQL::Translator::Object::Index' };
13     class_type PrimaryKey, { class => 'SQL::Translator::Object::PrimaryKey' };
14     class_type Procedure, { class => 'SQL::Translator::Object::Procedure' };
15     class_type Schema, { class => 'SQL::Translator::Object::Schema' };
16     class_type Sequence, { class=> 'SQL::Translator::Object::Sequence' };
17     class_type Table, { class => 'SQL::Translator::Object::Table' };
18     class_type Trigger, { class => 'SQL::Translator::Object::Trigger' };
19     class_type View, { class => 'SQL::Translator::Object::View' };
20     
21     class_type Parser, { class => 'SQL::Translator::Parser' };
22     class_type Producer, { class => 'SQL::Translator::Producer' };
23     class_type Translator, { class => 'SQL::Translator' };
24
25     coerce Column, from HashRef, via { SQL::Translator::Object::Column->new($_) };
26     coerce Constraint, from HashRef, via { SQL::Translator::Object::Constraint->new($_) };
27     coerce ForeignKey, from HashRef, via { SQL::Translator::Object::ForeignKey->new($_) };
28     coerce Index, from HashRef, via { SQL::Translator::Object::Index->new($_) };
29     coerce PrimaryKey, from HashRef, via { SQL::Translator::Object::PrimaryKey->new($_) };
30     coerce Procedure, from HashRef, via { SQL::Translator::Object::Procedure->new($_) };
31     coerce Schema, from HashRef, via { SQL::Translator::Object::Schema->new($_) };
32     coerce Sequence, from HashRef, via { SQL::Translator::Object::Sequence->new($_) };
33     coerce Table, from HashRef, via { SQL::Translator::Object::Table->new($_) };
34     coerce Trigger, from HashRef, via { SQL::Translator::Object::Trigger->new($_) };
35     coerce View, from HashRef, via { SQL::Translator::Object::View->new($_) };
36
37     coerce ArrayRef, from Str, via { [ $_ ] };
38
39     subtype MatchType, as Str, where { /^(full|partial|simple)$/ || $_ eq '' };
40     coerce MatchType, from Str, via { lc $_ };
41
42     subtype Bit, as Int, where { $_ == 1 || $_ == 0 };
43     coerce Bit,
44         from Undef, via { 0 },
45         from Str,  via { $_ eq '1' ? 1 : 0 };
46
47     subtype DBIHandle, as 'DBI::db';
48     
49     coerce DBIHandle,
50         from Str,
51         via(\&_coerce_dbihandle_from_str),
52         from ArrayRef,
53         via(\&_coerce_dbihandle_from_arrayref);
54         from CodeRef,
55         via(\&_coerce_dbihandle_from_coderef);
56     
57     sub coerce_dbihandle_from_str { }
58     sub coerce_dbihandle_from_arrayref { }
59     sub coerce_dbihandle_from_coderef { }
60     
61 }