2 class SQL::Translator {
4 use MooseX::Types::Moose qw(Bool HashRef Int Str Undef);
6 use SQL::Translator::Types qw(DBIHandle Parser Producer Schema);
7 use SQL::Translator::Object::Schema;
9 our $VERSION = '0.001';
10 $VERSION = eval $VERSION;
28 handles => [ qw(parse) ],
29 predicate => 'has_parser',
36 handles => [ qw(produce) ],
37 predicate => 'has_producer',
43 predicate => 'has_dbh',
50 clearer => '_clear_schema',
51 default => sub { SQL::Translator::Object::Schema->new },
54 has 'parser_args' => (
57 predicate => 'has_parser_args',
60 has 'producer_args' => (
63 predicate => 'has_producer_args',
71 has 'version' => (isa => Str, is => 'ro', default => $VERSION);
72 has 'add_drop_table' => (isa => Bool, is => 'rw', default => 0);
73 has 'no_comments' => (isa => Bool, is => 'rw', default => 0);
74 has 'show_warnings' => (isa => Bool, is => 'rw', default => 0);
75 has 'trace' => (isa => Bool, is => 'rw', default => 0);
76 has 'quote_table_names' => (isa => Bool, is => 'rw', default => 0);
77 has 'quote_field_names' => (isa => Bool, is => 'rw', default => 0);
78 has 'filename' => (isa => Str, is => 'rw');
80 has '_producer_mapping' => (
83 default => sub { { MySQL => 'SQL::MySQL', SQLite => 'SQL::SQLite', PostgreSQL => 'SQL::PostgreSQL', XML => 'XML', YAML => 'YAML' } }
91 method _build__parser {
92 my $class = 'SQL::Translator::Parser';
94 Class::MOP::load_class($class);
98 $parser = $class->new({ translator => $self, dbh => $self->dbh });
100 $parser = $class->new({ translator => $self, type => $self->parser || '' });
106 method _build__producer {
107 my $mapping = $self->_producer_mapping;
109 my $class = 'SQL::Translator::Producer';
110 my $role = $class . '::' . $mapping->{$self->producer};
112 Class::MOP::load_class($class);
113 Class::MOP::load_class($role);
115 my $producer = $class->new({ translator => $self });
116 $role->meta->apply($producer);
121 method translate(:$data, :$producer?, :$producer_args?, :$parser?, :$parser_args?) {
124 $self->_clear_schema if defined $parser;
125 $data ||= $self->data;
127 $parser ||= $self->parser unless $self->has_parser;
128 if (defined $parser) {
129 $self->_clear_parser;
130 $self->parser($parser);
132 $return = $self->schema;
135 $producer ||= $self->producer unless $self->has_producer;
136 if (defined $producer) {
137 $self->_clear_producer;
138 $self->producer($producer);
139 $return = $self->produce;
145 method parser_type { return $self->parser }
146 method producer_type { return $self->producer }
148 method engine_version(Int|Str|Undef $v, Str $target = 'perl') {
149 return undef unless $v;
154 if ( $v =~ / ^ (\d+) \. (\d{1,3}) (?: \. (\d{1,3}) )? $ /x ) {
155 push @vers, $1, $2, $3;
158 # XYYZZ (mysql) style
159 elsif ( $v =~ / ^ (\d) (\d{2}) (\d{2}) $ /x ) {
160 push @vers, $1, $2, $3;
163 # XX.YYYZZZ (perl) style or simply X
164 elsif ( $v =~ / ^ (\d+) (?: \. (\d{3}) (\d{3}) )? $ /x ) {
165 push @vers, $1, $2, $3;
168 #how do I croak sanely here?
169 die "Unparseable MySQL version '$v'";
172 if ($target eq 'perl') {
173 return sprintf ('%d.%03d%03d', map { $_ || 0 } (@vers) );
175 elsif ($target eq 'mysql') {
176 return sprintf ('%d%02d%02d', map { $_ || 0 } (@vers) );
179 #how do I croak sanely here?
180 die "Unknown version target '$target'";