Mise à jour de Monitor.py et autres scripts
This commit is contained in:
165
myenv/lib/python3.11/site-packages/git/compat.py
Normal file
165
myenv/lib/python3.11/site-packages/git/compat.py
Normal file
@@ -0,0 +1,165 @@
|
||||
# Copyright (C) 2008, 2009 Michael Trier (mtrier@gmail.com) 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."""
|
||||
|
||||
|
||||
@overload
|
||||
def safe_decode(s: None) -> None: ...
|
||||
|
||||
|
||||
@overload
|
||||
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,))
|
||||
|
||||
|
||||
@overload
|
||||
def safe_encode(s: None) -> None: ...
|
||||
|
||||
|
||||
@overload
|
||||
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,))
|
||||
|
||||
|
||||
@overload
|
||||
def win_encode(s: None) -> None: ...
|
||||
|
||||
|
||||
@overload
|
||||
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
|
||||
Reference in New Issue
Block a user