summaryrefslogtreecommitdiff
path: root/Modules/_abc.c
diff options
context:
space:
mode:
authorINADA Naoki <methane@users.noreply.github.com>2018-03-22 21:52:42 +0900
committerGitHub <noreply@github.com>2018-03-22 21:52:42 +0900
commitf757b72b2524ce3451d2269f0b8a9f0593a7b27f (patch)
treed4a97b175fb960870cee461019551e76d6d45480 /Modules/_abc.c
parent40472dd42de4f7265d456458cd13ad6894d736db (diff)
downloadcpython-git-f757b72b2524ce3451d2269f0b8a9f0593a7b27f.tar.gz
bpo-32999: Revert GH-6002 (fc7df0e6) (GH-6189)
bpo-33018 (GH-5944) fixed bpo-32999 too. So fc7df0e6 is not required anymore. Revert it except test case.
Diffstat (limited to 'Modules/_abc.c')
-rw-r--r--Modules/_abc.c35
1 files changed, 11 insertions, 24 deletions
diff --git a/Modules/_abc.c b/Modules/_abc.c
index 7daa18e37e..aa091c717d 100644
--- a/Modules/_abc.c
+++ b/Modules/_abc.c
@@ -16,7 +16,6 @@ _Py_IDENTIFIER(__abstractmethods__);
_Py_IDENTIFIER(__class__);
_Py_IDENTIFIER(__dict__);
_Py_IDENTIFIER(__bases__);
-_Py_IDENTIFIER(__mro__);
_Py_IDENTIFIER(_abc_impl);
_Py_IDENTIFIER(__subclasscheck__);
_Py_IDENTIFIER(__subclasshook__);
@@ -574,7 +573,7 @@ _abc__abc_subclasscheck_impl(PyObject *module, PyObject *self,
return NULL;
}
- PyObject *ok, *mro = NULL, *subclasses = NULL, *result = NULL;
+ PyObject *ok, *subclasses = NULL, *result = NULL;
Py_ssize_t pos;
int incache;
_abc_data *impl = _get_impl(self);
@@ -643,31 +642,20 @@ _abc__abc_subclasscheck_impl(PyObject *module, PyObject *self,
}
Py_DECREF(ok);
- /* 4. Check if it's a direct subclass.
- *
- * if cls in getattr(subclass, '__mro__', ()):
- * cls._abc_cache.add(subclass)
- * return True
- */
- if (_PyObject_LookupAttrId(subclass, &PyId___mro__, &mro) < 0) {
- goto end;
- }
- if (mro != NULL) {
- if (!PyTuple_Check(mro)) {
- // Python version supports non-tuple iterable. Keep it as
- // implementation detail.
- PyErr_SetString(PyExc_TypeError, "__mro__ is not a tuple");
+ /* 4. Check if it's a direct subclass. */
+ PyObject *mro = ((PyTypeObject *)subclass)->tp_mro;
+ assert(PyTuple_Check(mro));
+ for (pos = 0; pos < PyTuple_GET_SIZE(mro); pos++) {
+ PyObject *mro_item = PyTuple_GET_ITEM(mro, pos);
+ if (mro_item == NULL) {
goto end;
}
- for (pos = 0; pos < PyTuple_GET_SIZE(mro); pos++) {
- PyObject *mro_item = PyTuple_GET_ITEM(mro, pos);
- if ((PyObject *)self == mro_item) {
- if (_add_to_weak_set(&impl->_abc_cache, subclass) < 0) {
- goto end;
- }
- result = Py_True;
+ if ((PyObject *)self == mro_item) {
+ if (_add_to_weak_set(&impl->_abc_cache, subclass) < 0) {
goto end;
}
+ result = Py_True;
+ goto end;
}
}
@@ -708,7 +696,6 @@ _abc__abc_subclasscheck_impl(PyObject *module, PyObject *self,
end:
Py_DECREF(impl);
- Py_XDECREF(mro);
Py_XDECREF(subclasses);
Py_XINCREF(result);
return result;