X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/kivitendo-erp.git/blobdiff_plain/50b62dbb07efa821b05e9b6368c574ec76df2bb9..35cf7c7029b4aa69eb9d02c7533d1a15aafb118b:/SL/DBUpgrade2.pm diff --git a/SL/DBUpgrade2.pm b/SL/DBUpgrade2.pm index 650258378..6d0b207a7 100644 --- a/SL/DBUpgrade2.pm +++ b/SL/DBUpgrade2.pm @@ -7,7 +7,6 @@ use List::MoreUtils qw(any); use SL::Common; use SL::DBUpgrade2::Base; use SL::DBUtils; -use SL::Iconv; use strict; @@ -52,7 +51,7 @@ sub parse_dbupdate_controls { my $path = $self->path; foreach my $file_name (<$path/*.sql>, <$path/*.pl>) { - next unless (open(IN, $file_name)); + next unless (open(IN, "<:encoding(UTF-8)", $file_name)); my $file = $file_name; $file =~ s|.*/||; @@ -133,7 +132,7 @@ sub process_query { my ($self, $dbh, $filename, $version_or_control) = @_; my $form = $self->{form}; - my $fh = IO::File->new($filename, "r"); + my $fh = IO::File->new($filename, "<:encoding(UTF-8)"); my $query = ""; my $sth; my @quote_chars; @@ -146,8 +145,6 @@ sub process_query { $dbh->begin_work(); while (<$fh>) { - $_ = SL::Iconv::convert('UTF-8', 'UTF-8', $_); - # Remove DOS and Unix style line endings. chomp; @@ -297,28 +294,6 @@ sub process_file { : $self->process_perl_script($dbh, $filename, $version_or_control); } -sub update2_available { - $::lxdebug->enter_sub(); - - my ($self, $dbh) = @_; - - map { $_->{applied} = 0; } values %{ $self->{all_controls} }; - - my $sth = $dbh->prepare(qq|SELECT tag FROM | . $self->{schema} . qq|schema_info|); - if ($sth->execute) { - while (my ($tag) = $sth->fetchrow_array) { - $self->{all_controls}->{$tag}->{applied} = 1 if defined $self->{all_controls}->{$tag}; - } - } - $sth->finish(); - - my $needs_update = any { !$_->{applied} } values %{ $self->{all_controls} }; - - $::lxdebug->leave_sub(); - - return $needs_update; -} - sub unapplied_upgrade_scripts { my ($self, $dbh) = @_; @@ -335,6 +310,14 @@ sub unapplied_upgrade_scripts { return grep { !$_->{applied} } @all_scripts; } +sub update2_available { + my ($self, $dbh) = @_; + + my @unapplied_scripts = $self->unapplied_upgrade_scripts($dbh); + + return !!@unapplied_scripts; +} + sub apply_admin_dbupgrade_scripts { my ($self, $called_from_admin) = @_; @@ -347,8 +330,6 @@ sub apply_admin_dbupgrade_scripts { $self->{form}->{login} ||= 'admin'; - map { $_->{description} = SL::Iconv::convert('UTF-8', 'UTF-8', $_->{description}) } values %{ $self->{all_controls} }; - if ($called_from_admin) { $self->{form}->{title} = $::locale->text('Dataset upgrade'); $self->{form}->header;