diff options
author | Raymond Hettinger <python@rcn.com> | 2008-01-24 19:05:29 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2008-01-24 19:05:29 (GMT) |
commit | 5a05364049a7b0c3eeee94fb7b77e6b41036b3ae (patch) | |
tree | 81c455f0e6117e62fdaa6df0da46aece07267095 | |
parent | 71dba4ccee4d90c7dfb970ab77fcba113c9aec5c (diff) | |
download | cpython-5a05364049a7b0c3eeee94fb7b77e6b41036b3ae.zip cpython-5a05364049a7b0c3eeee94fb7b77e6b41036b3ae.tar.gz cpython-5a05364049a7b0c3eeee94fb7b77e6b41036b3ae.tar.bz2 |
Add support for trunc().
-rw-r--r-- | Lib/decimal.py | 2 | ||||
-rw-r--r-- | Lib/test/test_decimal.py | 11 |
2 files changed, 13 insertions, 0 deletions
diff --git a/Lib/decimal.py b/Lib/decimal.py index e624a6d..eea9448 100644 --- a/Lib/decimal.py +++ b/Lib/decimal.py @@ -1433,6 +1433,8 @@ class Decimal(object): else: return s*int(self._int[:self._exp] or '0') + __trunc__ = __int__ + def __long__(self): """Converts to a long. diff --git a/Lib/test/test_decimal.py b/Lib/test/test_decimal.py index 2135637..0ea4a36 100644 --- a/Lib/test/test_decimal.py +++ b/Lib/test/test_decimal.py @@ -1151,6 +1151,7 @@ class DecimalUsabilityTest(unittest.TestCase): checkSameDec("__floordiv__", True) checkSameDec("__hash__") checkSameDec("__int__") + checkSameDec("__trunc__") checkSameDec("__long__") checkSameDec("__mod__", True) checkSameDec("__mul__", True) @@ -1216,6 +1217,16 @@ class DecimalPythonAPItests(unittest.TestCase): r = d.to_integral(ROUND_DOWN) self.assertEqual(Decimal(int(d)), r) + def test_trunc(self): + for x in range(-250, 250): + s = '%0.2f' % (x / 100.0) + # should work the same as for floats + self.assertEqual(int(Decimal(s)), int(float(s))) + # should work the same as to_integral in the ROUND_DOWN mode + d = Decimal(s) + r = d.to_integral(ROUND_DOWN) + self.assertEqual(Decimal(trunc(d)), r) + class ContextAPItests(unittest.TestCase): def test_pickle(self): |