Spreadsheet::Engine::Function::TRUNC - Spreadsheet funtion TRUNC()


Spreadsheet-Engine documentation Contained in the Spreadsheet-Engine distribution.

Index


Code Index:

NAME

Top

Spreadsheet::Engine::Function::TRUNC - Spreadsheet funtion TRUNC()

SYNOPSIS

Top

  =TRUNC(value, digits)

DESCRIPTION

Top

This truncates the value to the specified number of digits.

HISTORY

Top

This is a Modified Version of code extracted from SocialCalc::Functions in SocialCalc 1.1.0

COPYRIGHT

Top

LICENCE

Top

The contents of this file are subject to the Artistic License 2.0; you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.perlfoundation.org/artistic_license_2_0


Spreadsheet-Engine documentation Contained in the Spreadsheet-Engine distribution.

package Spreadsheet::Engine::Function::TRUNC;

use strict;
use warnings;

use base 'Spreadsheet::Engine::Fn::math2';

sub calculate {
  my ($self, $num, $digits) = @_;
  if ($digits >= 0) {
    my $decimalscale = 10**int $digits;
    my $scaledvalue  = int($num * $decimalscale);
    return $scaledvalue / $decimalscale;
  }

  # $digits < 0
  my $decimalscale = 10**int -$digits;
  my $scaledvalue  = int($num / $decimalscale);
  return $scaledvalue * $decimalscale;
}

1;

__END__