A decorator to automatically detect mismatch when overriding a method.
Project description
A decorator to automatically detect mismatch when overriding a method. See http://stackoverflow.com/questions/1167617/in-python-how-do-i-indicate-im-overriding-a-method
All checks are done when a class or a method is created and not when a method is executed or an instance of a class is created. This means that performance implications are minimal.
Note: Version 2.8.0 is the last one that supports Python 2.7. Versions after that work with Python >= 3.6.
Copyright Disclaimer
Please note, this repository and published pip package is a fork of the original implementation. It’s being distributed separately as it breaks backward compatibility with previous versions.
Why explicit overrides?
Overrides without explicit indicator for them are weak. They leave room for problems that happen during the evolution of a codebase.
(create) Accidental overriding in a subclass when a method to a superclass is added (or vice versa).
(modify) Rename of a superclass method without subclass method rename (or vice versa).
(delete) Deleting of a superclass method without detecting in subclass that the method is not anymore overriding anything (or vice versa).
These might happen for example when overriding a method in a module that does not live in your codebase, or when merging changes done by someone else to the codebase without having access to your subclass.
Installation
$ pip install overrides-extension
Usage
from overrides_extension import override
class SuperClass:
def method(self) -> int:
"""This is the doc for a method and will be shown in subclass method too!"""
return 2
class SubClass(SuperClass):
@override
def method(self) -> int:
return 1
Enforcing usage
from overrides_extension import EnforceOverrides, final, override
class SuperClass(EnforceOverrides):
@final
def method(self) -> int:
"""This is the doc for a method and will be shown in subclass method too!"""
return 2
def method2(self) -> int:
"""This is the doc for a method and will be shown in subclass method too!"""
return 2
@staticmethod
def method3() -> int:
"""This is the doc for a method and will be shown in subclass method too!"""
return 2
# THIS FAILS
class SubClass1(SuperClass):
def method(self) -> int: # <-- overriding a final method
return 1
# THIS FAILS
class SubClass2(SuperClass):
def method2(self) -> int: # <-- @override decorator missing
return 1
# THIS ONE IS OK
class SubClass3(SuperClass):
@override
def method2(self) -> int:
return 1
# ENSURE THAT @classmethod AND @staticmethod ARE PLACED AT THE TOP
class SubClass4(SuperClass):
@staticmethod
@override
def method3() -> int:
return 1
Contributors
This project becomes a reality only through the work of all the people who contribute.
mkorpela, drorasaf, ngoodman90, TylerYep, leeopop, donpatrice, jayvdb, joelgrus, lisyarus, soulmerge, rkr-at-dbx, mozharovsky
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file overrides_extension-3.2.3.tar.gz
.
File metadata
- Download URL: overrides_extension-3.2.3.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.6 CPython/3.9.2 Darwin/20.1.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a8b61a1afdbf26865ae7d8f20c22820eb48844c73d4c99b4590accab36ee59c4 |
|
MD5 | 2cbe73c3dde85e20e30de10d409744e2 |
|
BLAKE2b-256 | b1edd46948ed97c17ecfa9f93aca7a911416d56e7465b6bc7e1a18ecd8ea1b8e |
File details
Details for the file overrides_extension-3.2.3-py3-none-any.whl
.
File metadata
- Download URL: overrides_extension-3.2.3-py3-none-any.whl
- Upload date:
- Size: 20.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.6 CPython/3.9.2 Darwin/20.1.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a94dcee96e3ac5fe6c886e98ae1e53f80c995cf45391db85d6b10dc07767fb04 |
|
MD5 | 3c6e34500f0bb0ccbc274eb2bdc1c4cf |
|
BLAKE2b-256 | 6a5ef1e77506c9ded71524b7a4a6ee5e4ea9c6e43f96e28cc77fc086d7713d82 |