diff options
author | Dylan Baker <dylan@pnwbakers.com> | 2021-07-26 15:50:15 -0700 |
---|---|---|
committer | Dylan Baker <dylan@pnwbakers.com> | 2021-08-16 16:21:51 -0700 |
commit | 580f316043ed34ada70af52754dec1340c3125fe (patch) | |
tree | 9df96d1e9c8ccf53fc5132cdb32782631d15e60b /mesonbuild/interpreterbase/baseobjects.py | |
parent | d8d09138c7af71705d8a5ec5b018ef73aa75d82b (diff) | |
download | meson-580f316043ed34ada70af52754dec1340c3125fe.zip meson-580f316043ed34ada70af52754dec1340c3125fe.tar.gz meson-580f316043ed34ada70af52754dec1340c3125fe.tar.bz2 |
interperterbase: help type checkers do better type deduction
This assert causes several type checkers (both mypy and pyright) to
force `obj` to be a base `HoldableObject` instead of the specialized
object. Since the check itself may still be valuable as we don't have
fully type annotation coverage it's simply been removed when type
checking to aid in type specialization.
Diffstat (limited to 'mesonbuild/interpreterbase/baseobjects.py')
-rw-r--r-- | mesonbuild/interpreterbase/baseobjects.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/mesonbuild/interpreterbase/baseobjects.py b/mesonbuild/interpreterbase/baseobjects.py index 8b1293c..ddfd4be 100644 --- a/mesonbuild/interpreterbase/baseobjects.py +++ b/mesonbuild/interpreterbase/baseobjects.py @@ -73,7 +73,11 @@ InterpreterObjectTypeVar = T.TypeVar('InterpreterObjectTypeVar', bound=HoldableO class ObjectHolder(InterpreterObject, T.Generic[InterpreterObjectTypeVar]): def __init__(self, obj: InterpreterObjectTypeVar, interpreter: 'Interpreter') -> None: super().__init__(subproject=interpreter.subproject) - assert isinstance(obj, HoldableObject), f'This is a bug: Trying to hold object of type `{type(obj).__name__}` that is not an `HoldableObject`' + # This causes some type checkers to assume that obj is a base + # HoldableObject, not the specialized type, so only do this assert in + # non-type checking situations + if not T.TYPE_CHECKING: + assert isinstance(obj, HoldableObject), f'This is a bug: Trying to hold object of type `{type(obj).__name__}` that is not an `HoldableObject`' self.held_object = obj self.interpreter = interpreter self.env = self.interpreter.environment |