1 package DBIx::Class::DeploymentHandler::DeployMethod::SQL::Translator::Deprecated;
4 # ABSTRACT: (DEPRECATED) Use this if you are stuck in the past
6 use Method::Signatures::Simple;
8 use File::Spec::Functions;
10 extends 'DBIx::Class::DeploymentHandler::DeployMethod::SQL::Translator',
12 method _ddl_schema_consume_filenames($type, $version) {
13 return [$self->_ddl_schema_produce_filename($type, $version)]
16 method _ddl_schema_produce_filename($type, $version) {
17 my $filename = ref $self->schema;
18 $filename =~ s/::/-/g;
21 $self->upgrade_directory, "$filename-$version-$type.sql"
27 method _ddl_schema_up_produce_filename($type, $versions, $dir) {
28 my $filename = ref $self->schema;
29 $filename =~ s/::/-/g;
32 $self->upgrade_directory, "$filename-" . join( q(-), @{$versions} ) . "-$type.sql"
38 method _ddl_schema_up_consume_filenames($type, $versions) {
39 return [$self->_ddl_schema_up_produce_filename($type, $versions)]
42 __PACKAGE__->meta->make_immutable;
46 # vim: ts=2 sw=2 expandtab
52 Yeah, this old Deprecated thing is a drag. It can't do downgrades, it can only
53 use a single .sql file for migrations, it has no .pl support. You should
54 totally switch! Here's how:
56 my $init_part = ref $schema;
57 $init_part =~ s/::/-/g;
58 opendir my $dh, 'sql';
60 if (/\Q$init_part\E-(.*)-(.*)(?:-(.*))?/) {
62 cp $_, $dh->deploy_method->_ddl_schema_up_produce_filename($3, [$1, $2]);
64 cp $_, $dh->deploy_method->_ddl_schema_produce_filename($2, $1);