my ($type, $country) = @_;
- $country ||= $::language;
+ $country ||= $::lx_office_conf{system}->{language};
$country =~ s|.*/||;
$country =~ s|\.||g;
}
}
- my $db_charset = $main::dbcharset || Common::DEFAULT_CHARSET;
- $self->{is_utf8} = (any { lc($::dbcharset || '') eq $_ } qw(utf8 utf-8 unicode)) ? 1 : 0;
+ my $db_charset = $::lx_office_conf{system}->{dbcharset} || Common::DEFAULT_CHARSET;
+ $self->{is_utf8} = (any { lc($::lx_office_conf{system}->{dbcharset} || '') eq $_ } qw(utf8 utf-8 unicode)) ? 1 : 0;
if ($self->{is_utf8}) {
binmode STDOUT, ":utf8";
$self->{iconv_english} = SL::Iconv->new('ASCII', $db_charset);
$self->{iconv_iso8859} = SL::Iconv->new('ISO-8859-15', $db_charset);
$self->{iconv_to_iso8859} = SL::Iconv->new($db_charset, 'ISO-8859-15');
+ $self->{iconv_utf8} = SL::Iconv->new('UTF-8', $db_charset);
$self->_read_special_chars_file($country);
my $self = shift;
my $text = shift;
- if (exists $self->{texts}->{$text}) {
+ if ($self->{texts}->{$text}) {
$text = $self->{iconv}->convert($self->{texts}->{$text});
} else {
$text = $self->{iconv_english}->convert($text);
my ($self, $text) = @_;
my $text_rev = lc $self->{iconv_reverse}->convert($text);
+ $text_rev =~ s/[\s\-]+/_/g;
if (!$self->{texts_reverse}) {
$self->{texts_reverse} = { };
$original =~ s/_+/_/g;
$translation = lc $translation;
+ $translation =~ s/[\s\-]+/_/g;
$self->{texts_reverse}->{$translation} ||= [ ];
push @{ $self->{texts_reverse}->{$translation} }, $original;
}
sub parse_date {
- $main::lxdebug->enter_sub();
+ $main::lxdebug->enter_sub(2);
my ($self, $myconfig, $date, $longformat) = @_;
my ($spc, $yy, $mm, $dd);
unless ($date) {
- $main::lxdebug->leave_sub();
+ $main::lxdebug->leave_sub(2);
return ();
}
$yy = ($yy < 70) ? $yy + 2000 : $yy;
$yy = ($yy >= 70 && $yy <= 99) ? $yy + 1900 : $yy;
- $main::lxdebug->leave_sub();
+ $main::lxdebug->leave_sub(2);
return ($yy, $mm, $dd);
}
}
sub reformat_date {
- $main::lxdebug->enter_sub();
+ $main::lxdebug->enter_sub(2);
my ($self, $myconfig, $date, $output_format, $longformat) = @_;
- $main::lxdebug->leave_sub() and return "" unless ($date);
+ $main::lxdebug->leave_sub(2) and return "" unless ($date);
my ($yy, $mm, $dd) = $self->parse_date($myconfig, $date);
$output_format =~ /y+/;
substr($output_format, $-[0], $+[0] - $-[0]) = $yy;
- $main::lxdebug->leave_sub();
+ $main::lxdebug->leave_sub(2);
return $output_format;
}
my $dd = shift;
my $yy_len = shift || 4;
+ ($yy, $mm, $dd) = ($yy->year, $yy->month, $yy->day) if ref $yy eq 'DateTime';
+
$main::lxdebug->leave_sub() and return "" unless $yy && $mm && $dd;
$yy = $yy % 100 if 2 == $yy_len;
return $self->quote_special_chars($dst_format, $self->quote_special_chars("${src_format}-reverse", shift));
}
+sub raw_io_active {
+ my $self = shift;
+
+ return !!$self->{raw_io_active};
+}
+
sub with_raw_io {
my $self = shift;
my $fh = shift;
my $code = shift;
+ $self->{raw_io_active} = 1;
binmode $fh, ":raw";
$code->();
binmode $fh, ":utf8" if $self->is_utf8;
+ $self->{raw_io_active} = 0;
+}
+
+sub set_numberformat_wo_thousands_separator {
+ my $self = shift;
+ my $myconfig = shift || \%::myconfig;
+
+ $self->{saved_numberformat} = $myconfig->{numberformat};
+ $myconfig->{numberformat} =~ s/^1[,\.]/1/;
+}
+
+sub restore_numberformat {
+ my $self = shift;
+ my $myconfig = shift || \%::myconfig;
+
+ $myconfig->{numberformat} = $self->{saved_numberformat} if $self->{saved_numberformat};
+}
+
+sub get_local_time_zone {
+ my $self = shift;
+ $self->{local_time_zone} ||= DateTime::TimeZone->new(name => 'local');
+ return $self->{local_time_zone};
}
1;