diff --git a/pep-0443.txt b/pep-0443.txt index df758321a..d7f69ed9d 100644 --- a/pep-0443.txt +++ b/pep-0443.txt @@ -190,6 +190,19 @@ argument which includes the relevant ABCs. The algorithm is as follows:: mro.insert(index, regcls) return mro +In its most basic form, it returns the MRO for the given type:: + +>>> _compose_mro(dict, []) +[, ] + +When the haystack consists of ABCs that the specified type is a subclass +of, they are inserted in a predictable order:: + +>>> _compose_mro(dict, [Sized, MutableMapping, str, Sequence, Iterable]) +[, , + , , + ] + While this mode of operation is significantly slower, no caching is involved because user code may ``register()`` a new class on an ABC at any time. In such case, it is possible to create a situation with