aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/_typing.py
diff options
context:
space:
mode:
authorDylan Baker <dylan@pnwbakers.com>2020-09-24 09:33:21 -0700
committerDylan Baker <dylan@pnwbakers.com>2021-06-02 15:53:17 -0700
commitf8be4f8fc747772d9639fdbb6e84ddbcfb61593a (patch)
tree96838bf032b3eafbb321a0d16757e82dfe36caf0 /mesonbuild/_typing.py
parent023722b2c6f3e3d3ea7ac1593695f8d8d7fb089c (diff)
downloadmeson-f8be4f8fc747772d9639fdbb6e84ddbcfb61593a.zip
meson-f8be4f8fc747772d9639fdbb6e84ddbcfb61593a.tar.gz
meson-f8be4f8fc747772d9639fdbb6e84ddbcfb61593a.tar.bz2
adding a _typing module
this is a place that *must* only be imported inside a if typing.TYPE_CHECKING block. It is a mixture of smoothing over thinigs that moved from typing_extensions to typing in later python versions and useful but typing only code. This makes typing_extensions required for python versions older than 3.8 *when running mypy*. typing_extensions should *only* be imported inside an `if typing.TYPE_CHECKING` block (include the new _typing.py module) to ensure that it doesn't become a runtime dependency
Diffstat (limited to 'mesonbuild/_typing.py')
-rw-r--r--mesonbuild/_typing.py114
1 files changed, 114 insertions, 0 deletions
diff --git a/mesonbuild/_typing.py b/mesonbuild/_typing.py
new file mode 100644
index 0000000..a8faa43
--- /dev/null
+++ b/mesonbuild/_typing.py
@@ -0,0 +1,114 @@
+# SPDX-License-Identifer: Apache-2.0
+# Copyright 2020 The Meson development team
+# Copyright © 2020-2021 Intel Corporation
+
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+
+# http://www.apache.org/licenses/LICENSE-2.0
+
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+"""Meson specific typing helpers.
+
+Holds typing helper classes, such as the ImmutableProtocol classes
+"""
+
+__all__ = [
+ 'Protocol',
+ 'ImmutableListProtocol'
+]
+
+import typing
+
+# We can change this to typing when we require python 3.8
+from typing_extensions import Protocol
+
+
+T = typing.TypeVar('T')
+
+
+class ImmutableListProtocol(Protocol[T]):
+
+ """A protocol used in cases where a list is returned, but should not be
+ mutated.
+
+ This provides all of the methods of a Sequence, as well as copy(). copy()
+ returns a list, which allows mutation as it's a copy and that's (hopefully)
+ safe.
+
+ One particular case this is important is for cached values, since python is
+ a pass-by-reference language.
+ """
+
+ def __iter__(self) -> typing.Iterator[T]: ...
+
+ @typing.overload
+ def __getitem__(self, index: int) -> T:...
+ @typing.overload
+ def __getitem__(self, index: slice) -> typing.List[T]: ...
+
+ def __contains__(self, item: T) -> bool: ...
+
+ def __reversed__(self) -> typing.Iterator[T]: ...
+
+ def __len__(self) -> int: ...
+
+ def __add__(self, other: typing.List[T]) -> typing.List[T]: ...
+
+ def __eq__(self, other: typing.Any) -> bool: ...
+ def __ne__(self, other: typing.Any) -> bool: ...
+ def __le__(self, other: typing.Any) -> bool: ...
+ def __lt__(self, other: typing.Any) -> bool: ...
+ def __gt__(self, other: typing.Any) -> bool: ...
+ def __ge__(self, other: typing.Any) -> bool: ...
+
+ def count(self, item: T) -> int: ...
+
+ def index(self, item: T) -> int: ...
+
+ def copy(self) -> typing.List[T]: ...
+
+
+class ImmutableSetProtocol(Protocol[T]):
+
+ """A protocol for a set that cannot be mutated.
+
+ This provides for cases where mutation of the set is undesired. Although
+ this will be allowed at runtime, mypy (or another type checker), will see
+ any attempt to use mutative methods as an error.
+ """
+
+ def __iter__(self) -> typing.Iterator[T]: ...
+
+ def __contains__(self, item: T) -> bool: ...
+
+ def __len__(self) -> int: ...
+
+ def __add__(self, other: typing.Set[T]) -> typing.Set[T]: ...
+
+ def __eq__(self, other: typing.Any) -> bool: ...
+ def __ne__(self, other: typing.Any) -> bool: ...
+ def __le__(self, other: typing.Any) -> bool: ...
+ def __lt__(self, other: typing.Any) -> bool: ...
+ def __gt__(self, other: typing.Any) -> bool: ...
+ def __ge__(self, other: typing.Any) -> bool: ...
+
+ def copy(self) -> typing.Set[T]: ...
+
+ def difference(self, other: typing.Set[T]) -> typing.Set[T]: ...
+
+ def intersection(self, other: typing.Set[T]) -> typing.Set[T]: ...
+
+ def issubset(self, other: typing.Set[T]) -> bool: ...
+
+ def issuperset(self, other: typing.Set[T]) -> bool: ...
+
+ def symmetric_difference(self, other: typing.Set[T]) -> typing.Set[T]: ...
+
+ def union(self, other: typing.Set[T]) -> typing.Set[T]: ...