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


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

Index


Code Index:

NAME

Top

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

SYNOPSIS

Top

  =MOD(a, b)

DESCRIPTION

Top

This returns the remainder when a is divided by b

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::MOD;

use strict;
use warnings;

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

sub calculate {
  my ($self, $x, $y) = @_;
  die Spreadsheet::Engine::Error->div0 if $y == 0;
  my $quotient = $x / $y;
  if ($quotient >= 0) {
    $quotient = int($quotient);
  } else {
    $quotient = int($quotient) - 1;
  }
  return $x - ($quotient * $y);
}

1;

__END__