Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 061f4d6d

Von Sven Schöling vor fast 9 Jahren hinzugefügt

  • ID 061f4d6d32ed95055114582ede45e8387b302a53
  • Vorgänger 88dea78e
  • Nachfolger a2bab345

Revert "Form: round_amount precision support"

Originalcommit: 73a78da630ce363f70062447dd82a8a0ece8cd89

Unterschiede anzeigen:

SL/DB/MetaSetup/Default.pm
78 78
  payments_changeable                       => { type => 'integer', default => '0', not_null => 1 },
79 79
  pdonumber                                 => { type => 'text' },
80 80
  ponumber                                  => { type => 'text' },
81
  precision                                 => { type => 'numeric', default => '0.01', not_null => 1, precision => 15, scale => 5 },
82 81
  profit_determination                      => { type => 'text' },
83 82
  project_status_id                         => { type => 'integer' },
84 83
  project_type_id                           => { type => 'integer' },
SL/Form.pm
948 948
}
949 949

  
950 950
sub round_amount {
951
  my ($self, $amount, $places, $adjust) = @_;
951
  my ($self, $amount, $places) = @_;
952 952

  
953 953
  return 0 if !defined $amount;
954 954

  
955 955
  $places //= 0;
956 956

  
957
  if ($adjust) {
958
    my $precision = $::instance_conf->get_precision || 0.01;
959
    return $self->round_amount( $self->round_amount($amount / $precision, 0) * $precision, $places);
960
  }
961

  
962 957
  # We use Perl's knowledge of string representation for
963 958
  # rounding. First, convert the floating point number to a string
964 959
  # with a high number of places. Then split the string on the decimal
sql/Pg-upgrade2/defaults_add_precision.sql
1
-- @tag: defaults_add_precision
2
-- @description: adds new column 'precision' in table defaults, used to round amounts
3
-- @depends: release_3_0_0
4
ALTER TABLE defaults ADD COLUMN precision NUMERIC(15,5) NOT NULL DEFAULT(0.01);
5

  

Auch abrufbar als: Unified diff