# -*- mode: perl; -*-
package Math::BigRat::Trace;
use strict;
use warnings;
use Exporter;
use Math::BigRat;
our @ISA = qw(Exporter Math::BigRat);
our $VERSION = '0.65';
use overload; # inherit overload from Math::BigRat
# Globals
our $accuracy = undef;
our $precision = undef;
our $round_mode = 'even';
our $div_scale = 40;
sub new {
my $proto = shift;
my $class = ref($proto) || $proto;
my $value = shift;
my $a = $accuracy;
$a = $_[0] if defined $_[0];
my $p = $precision;
$p = $_[1] if defined $_[1];
my $self = $class -> SUPER::new($value, $a, $p, $round_mode);
printf "Math::BigRat new '%s' => '%s' (%s)\n",
$value, $self, ref($self);
return $self;
}
sub import {
my $class = shift;
printf "%s -> import(%s)\n", $class, join(", ", @_);
# we catch the constants, the rest goes to parent
my $constant = grep { $_ eq ':constant' } @_;
my @a = grep { $_ ne ':constant' } @_;
if ($constant) {
overload::constant
integer => sub {
$class -> new(shift);
},
float => sub {
$class -> new(shift);
},
binary => sub {
# E.g., a literal 0377 shall result in an object whose value
# is decimal 255, but new("0377") returns decimal 377.
return $class -> from_oct($_[0]) if $_[0] =~ /^0_*[0-7]/;
$class -> new(shift);
};
}
$class -> SUPER::import(@a); # need it for subclasses
#$self -> export_to_level(1, $class, @_); # need this ?
}
1;
|