]> granicus.if.org Git - python/commitdiff
Patch #1460496: round() now accepts keyword arguments.
authorGeorg Brandl <georg@python.org>
Fri, 31 Mar 2006 18:54:53 +0000 (18:54 +0000)
committerGeorg Brandl <georg@python.org>
Fri, 31 Mar 2006 18:54:53 +0000 (18:54 +0000)
Lib/test/test_builtin.py
Misc/NEWS
Python/bltinmodule.c

index a05babf2888baea77583d549d5980bd22ee63e24..fa36095735bb99b5948475bc395784decf826703 100644 (file)
@@ -1395,6 +1395,9 @@ class BuiltinTest(unittest.TestCase):
 
         self.assertEqual(round(-8.0, -1), -10.0)
 
+        # test new kwargs
+        self.assertEqual(round(number=-8.0, ndigits=-1), -10.0)
+
         self.assertRaises(TypeError, round)
 
     def test_setattr(self):
index 4d0e0bd1a09a84df8508115106e61dd145e26468..ea5095f87bb2626f29ca0d739019555c9e347d70 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -12,6 +12,8 @@ What's New in Python 2.5 alpha 1?
 Core and builtins
 -----------------
 
+- Patch #1460496: round() now accepts keyword arguments.
+
 - Fixed bug #1459029 - unicode reprs were double-escaped.
 
 - Patch #1396919: The system scope threads are reenabled on FreeBSD
index c9da78c6f6f1fe2cfb8f1bef7c31c65391d8eedc..b675c26f2c5906eb50921b97ea89001835250b95 100644 (file)
@@ -1870,32 +1870,34 @@ For most object types, eval(repr(object)) == object.");
 
 
 static PyObject *
-builtin_round(PyObject *self, PyObject *args)
+builtin_round(PyObject *self, PyObject *args, PyObject *kwds)
 {
-       double x;
+       double number;
        double f;
        int ndigits = 0;
        int i;
+       static char *kwlist[] = {"number", "ndigits", 0};
 
-       if (!PyArg_ParseTuple(args, "d|i:round", &x, &ndigits))
-                       return NULL;
+       if (!PyArg_ParseTupleAndKeywords(args, kwds, "d|i:round",
+                kwlist, &number, &ndigits))
+                return NULL;
        f = 1.0;
        i = abs(ndigits);
        while  (--i >= 0)
                f = f*10.0;
        if (ndigits < 0)
-               x /= f;
+               number /= f;
        else
-               x *= f;
-       if (x >= 0.0)
-               x = floor(x + 0.5);
+               number *= f;
+       if (number >= 0.0)
+               number = floor(number + 0.5);
        else
-               x = ceil(x - 0.5);
+               number = ceil(number - 0.5);
        if (ndigits < 0)
-               x *= f;
+               number *= f;
        else
-               x /= f;
-       return PyFloat_FromDouble(x);
+               number /= f;
+       return PyFloat_FromDouble(number);
 }
 
 PyDoc_STRVAR(round_doc,
@@ -2248,7 +2250,7 @@ static PyMethodDef builtin_methods[] = {
        {"reduce",      builtin_reduce,     METH_VARARGS, reduce_doc},
        {"reload",      builtin_reload,     METH_O, reload_doc},
        {"repr",        builtin_repr,       METH_O, repr_doc},
-       {"round",       builtin_round,      METH_VARARGS, round_doc},
+       {"round",       (PyCFunction)builtin_round,      METH_VARARGS | METH_KEYWORDS, round_doc},
        {"setattr",     builtin_setattr,    METH_VARARGS, setattr_doc},
        {"sorted",      (PyCFunction)builtin_sorted,     METH_VARARGS | METH_KEYWORDS, sorted_doc},
        {"sum",         builtin_sum,        METH_VARARGS, sum_doc},