use YAML qw(Dump);
-# -------------------------------------------------------------------
sub produce {
my $translator = shift;
my $schema = $translator->schema;
return Dump({
schema => {
- tables => {
+ tables => {
map { ($_->name => view_table($_)) }
$schema->get_tables,
},
- views => {
+ views => {
map { ($_->name => view_view($_)) }
$schema->get_views,
},
- triggers => {
+ triggers => {
map { ($_->name => view_trigger($_)) }
$schema->get_triggers,
},
- procedures => {
- map { ($_->name => view_procedure($_)) }
+ procedures => {
+ map { ($_->name => view_procedure($_)) }
$schema->get_procedures,
},
},
});
}
-# -------------------------------------------------------------------
sub view_table {
my $table = shift;
'indices' => [
map { view_index($_) } $table->get_indices
],
- 'fields' => {
+ 'fields' => {
map { ($_->name => view_field($_)) }
- $table->get_fields
+ $table->get_fields
},
keys %{$table->extra} ? ('extra' => { $table->extra } ) : (),
};
}
-# -------------------------------------------------------------------
sub view_constraint {
my $constraint = shift;
};
}
-# -------------------------------------------------------------------
sub view_field {
my $field = shift;
};
}
-# -------------------------------------------------------------------
sub view_procedure {
my $procedure = shift;
};
}
-# -------------------------------------------------------------------
sub view_trigger {
my $trigger = shift;
};
}
-# -------------------------------------------------------------------
sub view_view {
my $view = shift;
};
}
-# -------------------------------------------------------------------
sub view_index {
my $index = shift;
1;
-# -------------------------------------------------------------------
-
=head1 SEE ALSO
SQL::Translator, YAML, http://www.yaml.org/.