X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/a97d97a009197f5b5b72897e0b09fb5889e2eb90..7e0ad798bc842b710a27b0e1a7a720b117b2566a:/SL/DBUpgrade2.pm diff --git a/SL/DBUpgrade2.pm b/SL/DBUpgrade2.pm index ae07d1c08..1a0b0433b 100644 --- a/SL/DBUpgrade2.pm +++ b/SL/DBUpgrade2.pm @@ -2,24 +2,26 @@ package SL::DBUpgrade2; use SL::Common; -require Exporter; -our @ISA = qw(Exporter); - -our @EXPORT = qw(parse_dbupdate_controls sort_dbupdate_controls); - use strict; +sub new { + my ($package, $form, $dbdriver) = @_; + my $self = { form => $form, dbdriver => $dbdriver }; + return bless($self, $package); +} + sub parse_dbupdate_controls { $main::lxdebug->enter_sub(); - my ($form, $dbdriver) = @_; + my ($self) = @_; + my $form = $self->{form}; my $locale = $main::locale; local *IN; my %all_controls; - my $path = "sql/${dbdriver}-upgrade2"; + my $path = "sql/" . $self->{dbdriver} . "-upgrade2"; foreach my $file_name (<$path/*.sql>, <$path/*.pl>) { next unless (open(IN, $file_name)); @@ -92,6 +94,8 @@ sub parse_dbupdate_controls { map({ _dbupdate2_calculate_depth(\%all_controls, $_->{"tag"}) } values(%all_controls)); + $self->{all_controls} = \%all_controls; + $main::lxdebug->leave_sub(); return \%all_controls; @@ -148,9 +152,11 @@ sub _dbupdate2_calculate_depth { } sub sort_dbupdate_controls { + my $self = shift; + return sort({ $a->{"depth"} != $b->{"depth"} ? $a->{"depth"} <=> $b->{"depth"} : $a->{"priority"} != $b->{"priority"} ? $a->{"priority"} <=> $b->{"priority"} - : $a->{"tag"} cmp $b->{"tag"} } values(%{$_[0]})); + : $a->{"tag"} cmp $b->{"tag"} } values(%{ $self->{all_controls} })); } 1;