blob: 58381cc05fa3d33243073273ae06e782a6edee94 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
#!/usr/bin/perl -w
use Test;
use strict;
BEGIN
{
plan tests => 0
+ 6; # our own tests
}
###############################################################################
package Math::BigFloat::Test;
use Math::BigFloat;
require Exporter;
use vars qw/@ISA/;
@ISA = qw/Exporter Math::BigFloat/;
use overload;
sub isa
{
my ($self,$class) = @_;
return if $class =~ /^Math::Big(Int|Float)/; # we aren't one of these
UNIVERSAL::isa($self,$class);
}
sub bmul
{
return __PACKAGE__->new(123);
}
sub badd
{
return __PACKAGE__->new(321);
}
###############################################################################
package main;
# use Math::BigInt upgrade => 'Math::BigFloat';
use Math::BigFloat upgrade => 'Math::BigFloat::Test';
use vars qw ($scale $class $try $x $y $z $f @args $ans $ans1 $ans1_str $setup
$ECL $CL);
$class = "Math::BigFloat";
$CL = "Math::BigInt::Calc";
$ECL = "Math::BigFloat::Test";
ok (Math::BigFloat->upgrade(),$ECL);
ok (Math::BigFloat->downgrade()||'','');
$x = $class->new(123); $y = $ECL->new(123); $z = $x->bmul($y);
ok (ref($z),$ECL); ok ($z,123);
$x = $class->new(123); $y = $ECL->new(123); $z = $x->badd($y);
ok (ref($z),$ECL); ok ($z,321);
# not yet:
# require 'upgrade.inc'; # all tests here for sharing
|