-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 { }
+
+}