require Exporter;
our @ISA = qw(Exporter);
-our @EXPORT = qw(save_form restore_form compare_numbers any cross);
-our @EXPORT_OK = qw(ary_union ary_intersect ary_diff listify ary_to_hash);
+our @EXPORT = qw(save_form restore_form compare_numbers cross);
+our @EXPORT_OK = qw(ary_union ary_intersect ary_diff listify ary_to_hash uri_encode uri_decode);
+use Encode ();
use List::MoreUtils qw(zip);
use YAML;
-use SL::AM;
-
use strict;
sub save_form {
sub compare_numbers {
$main::lxdebug->enter_sub();
- my $a = shift;
- my $a_unit = shift;
- my $b = shift;
- my $b_unit = shift;
-
- $main::all_units ||= AM->retrieve_units(\%main::myconfig, $main::form);
- my $units = $main::all_units;
+ my ($a, $a_unit, $b, $b_unit) = @_;
+ require SL::AM;
+ my $units = AM->retrieve_all_units;
if (!$units->{$a_unit} || !$units->{$b_unit} || ($units->{$a_unit}->{base_unit} ne $units->{$b_unit}->{base_unit})) {
$main::lxdebug->leave_sub();
return $a <=> $b;
}
-sub any (&@) {
- my $f = shift;
- return if ! @_;
- for (@_) {
- return 1 if $f->();
- }
- return 0;
-}
-
sub cross(&\@\@) {
my $op = shift;
use vars qw/@A @B/;
return zip(@indexes, @values);
}
+sub uri_encode {
+ my ($str) = @_;
+
+ $str = Encode::encode('utf-8-strict', $str);
+ $str =~ s/([^a-zA-Z0-9_.:-])/sprintf("%%%02x", ord($1))/ge;
+
+ return $str;
+}
+
+sub uri_decode {
+ my $str = $_[0] // '';
+
+ $str =~ tr/+/ /;
+ $str =~ s/\\$//;
+
+ $str =~ s/%([0-9a-fA-Z]{2})/pack("C",hex($1))/eg;
+ $str = Encode::decode('utf-8-strict', $str);
+
+ return $str;
+}
+
1;
__END__
=head1 DESCRIPTION
-this is a collection of helper functions used in Lx-Office.
+this is a collection of helper functions used in kivitendo.
Most of them are either obvious or too obscure to care about unless you really have to.
The exceptions are documented here.
=over 4
=item save_form
+
=item restore_form
A lot of the old sql-ledger routines are strictly procedural. They search for params in the $form object, do stuff with it, and return a status code.