Spaces:
Runtime error
Runtime error
| # Copyright (C) 2008, 2009 Michael Trier ([email protected]) and contributors | |
| # | |
| # This module is part of GitPython and is released under the | |
| # 3-Clause BSD License: https://opensource.org/license/bsd-3-clause/ | |
| """Utilities to help provide compatibility with Python 3. | |
| This module exists for historical reasons. Code outside GitPython may make use of public | |
| members of this module, but is unlikely to benefit from doing so. GitPython continues to | |
| use some of these utilities, in some cases for compatibility across different platforms. | |
| """ | |
| import locale | |
| import os | |
| import sys | |
| import warnings | |
| from gitdb.utils.encoding import force_bytes, force_text # noqa: F401 | |
| # typing -------------------------------------------------------------------- | |
| from typing import ( | |
| Any, # noqa: F401 | |
| AnyStr, | |
| Dict, # noqa: F401 | |
| IO, # noqa: F401 | |
| List, | |
| Optional, | |
| TYPE_CHECKING, | |
| Tuple, # noqa: F401 | |
| Type, # noqa: F401 | |
| Union, | |
| overload, | |
| ) | |
| # --------------------------------------------------------------------------- | |
| _deprecated_platform_aliases = { | |
| "is_win": os.name == "nt", | |
| "is_posix": os.name == "posix", | |
| "is_darwin": sys.platform == "darwin", | |
| } | |
| def _getattr(name: str) -> Any: | |
| try: | |
| value = _deprecated_platform_aliases[name] | |
| except KeyError: | |
| raise AttributeError(f"module {__name__!r} has no attribute {name!r}") from None | |
| warnings.warn( | |
| f"{__name__}.{name} and other is_<platform> aliases are deprecated. " | |
| "Write the desired os.name or sys.platform check explicitly instead.", | |
| DeprecationWarning, | |
| stacklevel=2, | |
| ) | |
| return value | |
| if not TYPE_CHECKING: # Preserve static checking for undefined/misspelled attributes. | |
| __getattr__ = _getattr | |
| def __dir__() -> List[str]: | |
| return [*globals(), *_deprecated_platform_aliases] | |
| is_win: bool | |
| """Deprecated alias for ``os.name == "nt"`` to check for native Windows. | |
| This is deprecated because it is clearer to write out :attr:`os.name` or | |
| :attr:`sys.platform` checks explicitly, especially in cases where it matters which is | |
| used. | |
| :note: | |
| ``is_win`` is ``False`` on Cygwin, but is often wrongly assumed ``True``. To detect | |
| Cygwin, use ``sys.platform == "cygwin"``. | |
| """ | |
| is_posix: bool | |
| """Deprecated alias for ``os.name == "posix"`` to check for Unix-like ("POSIX") systems. | |
| This is deprecated because it clearer to write out :attr:`os.name` or | |
| :attr:`sys.platform` checks explicitly, especially in cases where it matters which is | |
| used. | |
| :note: | |
| For POSIX systems, more detailed information is available in :attr:`sys.platform`, | |
| while :attr:`os.name` is always ``"posix"`` on such systems, including macOS | |
| (Darwin). | |
| """ | |
| is_darwin: bool | |
| """Deprecated alias for ``sys.platform == "darwin"`` to check for macOS (Darwin). | |
| This is deprecated because it clearer to write out :attr:`os.name` or | |
| :attr:`sys.platform` checks explicitly. | |
| :note: | |
| For macOS (Darwin), ``os.name == "posix"`` as in other Unix-like systems, while | |
| ``sys.platform == "darwin"``. | |
| """ | |
| defenc = sys.getfilesystemencoding() | |
| """The encoding used to convert between Unicode and bytes filenames.""" | |
| def safe_decode(s: None) -> None: ... | |
| def safe_decode(s: AnyStr) -> str: ... | |
| def safe_decode(s: Union[AnyStr, None]) -> Optional[str]: | |
| """Safely decode a binary string to Unicode.""" | |
| if isinstance(s, str): | |
| return s | |
| elif isinstance(s, bytes): | |
| return s.decode(defenc, "surrogateescape") | |
| elif s is None: | |
| return None | |
| else: | |
| raise TypeError("Expected bytes or text, but got %r" % (s,)) | |
| def safe_encode(s: None) -> None: ... | |
| def safe_encode(s: AnyStr) -> bytes: ... | |
| def safe_encode(s: Optional[AnyStr]) -> Optional[bytes]: | |
| """Safely encode a binary string to Unicode.""" | |
| if isinstance(s, str): | |
| return s.encode(defenc) | |
| elif isinstance(s, bytes): | |
| return s | |
| elif s is None: | |
| return None | |
| else: | |
| raise TypeError("Expected bytes or text, but got %r" % (s,)) | |
| def win_encode(s: None) -> None: ... | |
| def win_encode(s: AnyStr) -> bytes: ... | |
| def win_encode(s: Optional[AnyStr]) -> Optional[bytes]: | |
| """Encode Unicode strings for process arguments on Windows.""" | |
| if isinstance(s, str): | |
| return s.encode(locale.getpreferredencoding(False)) | |
| elif isinstance(s, bytes): | |
| return s | |
| elif s is not None: | |
| raise TypeError("Expected bytes or text, but got %r" % (s,)) | |
| return None | |