X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/557beaacf48471b594d47c3d019d1c90a4d66812..f8c8ad09f3ad7be25b7fa5e3b4506785fd0f48f1:/SL/Form.pm diff --git a/SL/Form.pm b/SL/Form.pm index 50c66d4d3..35050a0c7 100644 --- a/SL/Form.pm +++ b/SL/Form.pm @@ -967,7 +967,18 @@ sub parse_amount { } sub round_amount { - my ($self, $amount, $places) = @_; + my ($self, $amount, $places, $adjust) = @_; + + if ($adjust) { + my $precision = 0.01; + # Round amounts to eight places before rounding to the requested + # number of places. This gets rid of errors due to internal floating + # point representation. + $amount = int($amount * 10**8 + .5 * ($amount <=> 0)) / 10**8 if $places < 8; + $amount = int($amount / ($precision = _get_precision()) + ($amount <=> 0) * .5) * $precision; + $amount = int($amount * 10**$places + .5 * ($amount <=> 0)) / 10**$places; + return $amount; + } return 0 if !defined $amount; @@ -3683,6 +3694,20 @@ sub calculate_tax { return ($amount,$tax); }; +sub _get_precision { + my ( $self ) = @_; + my $precision = 0.01; + eval { + my $client = $::auth->{client}; + my $dbconnect = 'dbi:Pg:dbname=' . $client->{dbname} . ';host=' . $client->{dbhost} . ';port=' . $client->{dbport}; + my $dbh = DBI->connect($dbconnect, $client->{dbuser}, $client->{dbpasswd}); + my $query = q{ SELECT precision FROM defaults }; + ($precision) = selectrow_query($::form, $dbh, $query); + $dbh->disconnect; + }; + return $precision; +} + 1; __END__