initialize __dict__ if needed
diff --git a/Objects/funcobject.c b/Objects/funcobject.c
index 089356b..6dd91b8 100644
--- a/Objects/funcobject.c
+++ b/Objects/funcobject.c
@@ -832,10 +832,13 @@
}
static PyObject *
-cm_get___dict__(classmethod *cm, void *closure)
+cm_get___dict__(PyObject *cm, void *closure)
{
- Py_INCREF(cm->cm_dict);
- return cm->cm_dict;
+ PyObject **dictptr = _PyObject_GetDictPtr(cm);
+ if (*dictptr == NULL)
+ *dictptr = PyDict_New();
+ Py_XINCREF(*dictptr);
+ return *dictptr;
}
static PyGetSetDef cm_getsetlist[] = {
@@ -1018,10 +1021,13 @@
}
static PyObject *
-sm_get___dict__(staticmethod *sm, void *closure)
+sm_get___dict__(PyObject *sm, void *closure)
{
- Py_INCREF(sm->sm_dict);
- return sm->sm_dict;
+ PyObject **dictptr = _PyObject_GetDictPtr(sm);
+ if (*dictptr == NULL)
+ *dictptr = PyDict_New();
+ Py_XINCREF(*dictptr);
+ return *dictptr;
}
static PyGetSetDef sm_getsetlist[] = {