From: Justin Hunter Date: Tue, 11 Aug 2009 21:30:25 +0000 (-0700) Subject: add ColumnSize subtype and its coercions X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=a8eeeefc5595b051163cc5914ee04564701b3bfd;p=dbsrgits%2FSQL-Translator-2.0-ish.git add ColumnSize subtype and its coercions --- diff --git a/lib/SQL/Translator/Types.pm b/lib/SQL/Translator/Types.pm index fad7979..780cda1 100644 --- a/lib/SQL/Translator/Types.pm +++ b/lib/SQL/Translator/Types.pm @@ -1,35 +1,41 @@ -package SQL::Translator::Types; -use MooseX::Types::Moose qw(ArrayRef CodeRef Str); -use MooseX::Types -declare, [qw(Column Constraint ForeignKey Index PrimaryKey Procedure Schema Sequence Table Trigger View DBIHandle Parser Producer)]; +use MooseX::Declare; +class SQL::Translator::Types { + use MooseX::Types::Moose qw(ArrayRef CodeRef Int Maybe Str Undef); + use MooseX::Types -declare, [qw(Column Constraint ForeignKey Index PrimaryKey Procedure Schema Sequence Table Trigger View DBIHandle ColumnSize Parser Producer)]; + + class_type Column, { class => 'SQL::Translator::Object::Column' }; + class_type Constraint, { class => 'SQL::Translator::Object::Constraint' }; + class_type ForeignKey, { class => 'SQL::Translator::Object::ForeignKey' }; + class_type Index, { class => 'SQL::Translator::Object::Index' }; + class_type PrimaryKey, { class => 'SQL::Translator::Object::PrimaryKey' }; + class_type Procedure, { class => 'SQL::Translator::Object::Procedure' }; + class_type Schema, { class => 'SQL::Translator::Object::Schema' }; + class_type Sequence, { class=> 'SQL::Translator::Object::Sequence' }; + class_type Table, { class => 'SQL::Translator::Object::Table' }; + class_type Trigger, { class => 'SQL::Translator::Object::Trigger' }; + class_type View, { class => 'SQL::Translator::Object::View' }; + + class_type Parser, { class => 'SQL::Translator::Parser' }; + class_type Producer, { class => 'SQL::Translator::Producer' }; -class_type Column, { class => 'SQL::Translator::Object::Column' }; -class_type Constraint, { class => 'SQL::Translator::Object::Constraint' }; -class_type ForeignKey, { class => 'SQL::Translator::Object::ForeignKey' }; -class_type Index, { class => 'SQL::Translator::Object::Index' }; -class_type PrimaryKey, { class => 'SQL::Translator::Object::PrimaryKey' }; -class_type Procedure, { class => 'SQL::Translator::Object::Procedure' }; -class_type Schema, { class => 'SQL::Translator::Object::Schema' }; -class_type Sequence, { class=> 'SQL::Translator::Object::Sequence' }; -class_type Table, { class => 'SQL::Translator::Object::Table' }; -class_type Trigger, { class => 'SQL::Translator::Object::Trigger' }; -class_type View, { class => 'SQL::Translator::Object::View' }; + subtype ColumnSize, as ArrayRef[Int]; + coerce ColumnSize, + from Int, via { [ $_ ] }, + from Str, via { [ split /,/ ] }, + from Undef, via { [ 0 ] }; -class_type Parser, { class => 'SQL::Translator::Parser' }; -class_type Producer, { class => 'SQL::Translator::Producer' }; - -subtype DBIHandle, as 'DBI::db'; - -coerce DBIHandle, - from Str, - via(\&_coerce_dbihandle_from_str), - from ArrayRef, - via(\&_coerce_dbihandle_from_arrayref); - from CodeRef, - via(\&_coerce_dbihandle_from_coderef); - - -sub coerce_dbihandle_from_str { } -sub coerce_dbihandle_from_arrayref { } -sub coerce_dbihandle_from_coderef { } - -1; + subtype DBIHandle, as 'DBI::db'; + + coerce DBIHandle, + from Str, + via(\&_coerce_dbihandle_from_str), + from ArrayRef, + via(\&_coerce_dbihandle_from_arrayref); + from CodeRef, + via(\&_coerce_dbihandle_from_coderef); + + sub coerce_dbihandle_from_str { } + sub coerce_dbihandle_from_arrayref { } + sub coerce_dbihandle_from_coderef { } + +}