-
Notifications
You must be signed in to change notification settings - Fork 1
/
BigFloat.pm
162 lines (100 loc) · 3.33 KB
/
BigFloat.pm
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
package PGObject::Type::BigFloat;
use 5.010;
use strict;
use warnings;
use base qw(Math::BigFloat);
use PGObject;
use Carp;
=head1 NAME
PGObject::Type::BigFloat - Math::BigFloat wrappers for PGObject classes
=head1 VERSION
Version 2.001001
=cut
our $VERSION = 2.001001;
our ($accuracy, $precision, $round_mode, $div_scale);
# Globals
$accuracy = $precision = undef;
$round_mode = 'even';
$div_scale = 40;
=head1 SYNOPSIS
use PGObject::Type::BigFloat;
PGObject::Type::BigFloat->register(); # Get all numeric and float types
my $self->{foo} = PGObject::Type::BigFloat->new(0);
$self->call_dbmethod(funcname => 'bar'); # will use this as a numeric
=head1 SUBROUTINES/METHODS
=head2 register(registry => 'default', types => ['float4', 'float8', 'numeric'])
=cut
sub register{
my $self = shift @_;
my %args = @_;
croak "Can't pass reference to register \n".
"Hint: use the class instead of the object" if ref $self;
my $registry = $args{registry};
$registry ||= 'default';
my $types = $args{types};
$types = ['float4', 'float8', 'numeric'] unless defined $types and @$types;
for my $type (@$types){
if ($PGObject::VERSION =~ /^1\./){
my $ret =
PGObject->register_type(registry => $registry, pg_type => $type,
perl_class => $self);
return $ret unless $ret;
} else {
PGObject::Type::Registry->register_type(
registry => $registry, dbtype => $type, apptype => $self
);
}
}
return 1;
}
=head2 to_db
This serializes this into a simple db-friendly form.
=cut
sub to_db {
my $self = shift @_;
return undef if $self->is_undef;
return $self->bstr;
}
=head2 from_db
take simple normalized db floats and turn them into numeric representations.
=cut
sub from_db {
my ($self, $value) = @_;
my $obj = "$self"->new($value);
$obj->is_undef(1) if ! defined $value;
return $obj;
}
=head2 is_undef(optionally $set);
Return undef to the db or user interface. Can be set through apps.
=cut
sub is_undef {
my ($self, $set) = @_;
$self->{_pgobject_undef} = $set if defined $set;
return $self->{_pgobject_undef};
}
=head1 AUTHOR
Chris Travers, C<< <chris.travers at gmail.com> >>
=head1 BUGS
Please report any bugs or feature requests to C<bug-pgobject-type-bigfloat at rt.cpan.org>, or through
the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=PGObject-Type-BigFloat>. I will be notified, and then you'll
automatically be notified of progress on your bug as I make changes.
=head1 SUPPORT
You can find documentation for this module with the perldoc command.
perldoc PGObject::Type::BigFloat
You can also look for information at:
=over 4
=item * RT: CPAN's request tracker (report bugs here)
L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=PGObject-Type-BigFloat>
=item * AnnoCPAN: Annotated CPAN documentation
L<http://annocpan.org/dist/PGObject-Type-BigFloat>
=item * CPAN Ratings
L<http://cpanratings.perl.org/d/PGObject-Type-BigFloat>
=item * Search CPAN
L<http://search.cpan.org/dist/PGObject-Type-BigFloat/>
=back
=head1 ACKNOWLEDGEMENTS
=head1 LICENSE AND COPYRIGHT
Copyright 2013-2014 Chris Travers.
This program is released under the following license: BSD
=cut
1; # End of PGObject::Type::BigFloat