summaryrefslogtreecommitdiffstats
path: root/Python/bltinmodule.c
diff options
context:
space:
mode:
Diffstat (limited to 'Python/bltinmodule.c')
-rw-r--r--Python/bltinmodule.c18
1 files changed, 13 insertions, 5 deletions
diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c
index 85d8b37..727f8d1 100644
--- a/Python/bltinmodule.c
+++ b/Python/bltinmodule.c
@@ -669,18 +669,26 @@ builtin_getattr(self, args)
PyObject *self;
PyObject *args;
{
- PyObject *v;
+ PyObject *v, *result, *dflt = NULL;
PyObject *name;
- if (!PyArg_ParseTuple(args, "OS:getattr", &v, &name))
+ if (!PyArg_ParseTuple(args, "OS|O:getattr", &v, &name, &dflt))
return NULL;
- return PyObject_GetAttr(v, name);
+ result = PyObject_GetAttr(v, name);
+ if (result == NULL && dflt != NULL) {
+ PyErr_Clear();
+ Py_INCREF(dflt);
+ result = dflt;
+ }
+ return result;
}
static char getattr_doc[] =
-"getattr(object, name) -> value\n\
+"getattr(object, name[, default]) -> value\n\
\n\
-Get a named attribute from an object; getattr(x, 'y') is equivalent to x.y.";
+Get a named attribute from an object; getattr(x, 'y') is equivalent to x.y.\n\
+When a default argument is given, it is returned when the attribute doesn't\n\
+exist; without it, an exception is raised in that case.";
static PyObject *