Resolving metaclass conflicts

后端 未结 6 1262
时光取名叫无心
时光取名叫无心 2020-12-03 09:25

I need to create a class that uses a different base class depending on some condition. With some classes I get the infamous:

TypeError: metaclass conflict: t         


        
6条回答
  •  孤街浪徒
    2020-12-03 09:58

    As far as I understood from the previous answers the only think we usually have to do manually is:

    class M_A(type): pass
    class M_B(type): pass
    class A(metaclass=M_A): pass
    class B(metaclass=M_B): pass
    
    class M_C(M_A, M_B): pass
    class C:(A, B, metaclass=M_C): pass
    

    But we can automate the last two lines now by:

    def metaclass_resolver(*classes):
        metaclass = tuple(set(type(cls) for cls in classes))
        metaclass = metaclass[0] if len(metaclass)==1 \
                    else type("_".join(mcls.__name__ for mcls in metaclass), metaclass, {})   # class M_C
        return metaclass("_".join(cls.__name__ for cls in classes), classes, {})              # class C
    
    class C(metaclass_resolver(A, B)): pass
    

    Since we do not use any version-specific metaclass syntax this metaclass_resolver works with Python 2 as well as Python 3.

提交回复
热议问题