Register decimals as numbers.Number

This commit is contained in:
Raymond Hettinger 2009-02-03 03:42:07 +00:00
parent 154ab71e0b
commit 45fd4763ff
3 changed files with 16 additions and 0 deletions

View File

@ -135,6 +135,7 @@ __all__ = [
]
import copy as _copy
import numbers as _numbers
try:
from collections import namedtuple as _namedtuple
@ -3567,6 +3568,12 @@ def _dec_from_triple(sign, coefficient, exponent, special=False):
return self
# Register Decimal as a kind of Number (an abstract base class).
# However, do not register it as Real (because Decimals are not
# interoperable with floats).
_numbers.Number.register(Decimal)
##### Context class #######################################################

View File

@ -30,6 +30,7 @@ import os, sys
import pickle, copy
import unittest
from decimal import *
import numbers
from test.test_support import (TestSkipped, run_unittest, run_doctest,
is_resource_enabled)
import random
@ -1334,6 +1335,12 @@ class DecimalUsabilityTest(unittest.TestCase):
class DecimalPythonAPItests(unittest.TestCase):
def test_abc(self):
self.assert_(issubclass(Decimal, numbers.Number))
self.assert_(not issubclass(Decimal, numbers.Real))
self.assert_(isinstance(Decimal(0), numbers.Number))
self.assert_(not isinstance(Decimal(0), numbers.Real))
def test_pickle(self):
d = Decimal('-3.141590000')
p = pickle.dumps(d)

View File

@ -213,6 +213,8 @@ Library
- Issue #1885: distutils. When running sdist with --formats=tar,gztar
the tar file was overriden by the gztar one.
- Registered Decimal as a numbers.Number.
- Issue #1672332: fix unpickling of subnormal floats, which was
producing a ValueError on some platforms.