Skip to content

Commit

Permalink
Merge pull request #1585 from google/google_sync
Browse files Browse the repository at this point in the history
Google sync
  • Loading branch information
rchen152 authored Feb 13, 2024
2 parents f9c7c6c + ff392ba commit 8af6303
Show file tree
Hide file tree
Showing 5 changed files with 32 additions and 3 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
Version 2024.02.13:

Bug fixes:
* Fix: pytype.single -> pytype.main.
* Catch UnicodeDecodeError when attempting to read excluded files.
* Add protocol overload to definition of builtins.divmod.

Version 2024.02.09:

Updates:
Expand Down
2 changes: 1 addition & 1 deletion pytype/__version__.py
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
# pylint: skip-file
__version__ = '2024.02.09'
__version__ = '2024.02.13'
7 changes: 5 additions & 2 deletions pytype/file_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,9 @@ def is_file_script(filename, directory=None):
# of course we assume that they start with a shebang
file_path = expand_path(filename, directory)
if path_utils.isfile(file_path):
with open(file_path, "r") as file:
line = file.readline().rstrip().lower()
with open(file_path, "r") as fi:
try:
line = fi.readline().rstrip().lower()
except UnicodeDecodeError:
return False
return re.fullmatch(r"#!.+python3?", line) is not None
10 changes: 10 additions & 0 deletions pytype/stubs/builtins/builtins.pytd
Original file line number Diff line number Diff line change
Expand Up @@ -65,9 +65,19 @@ def coerce(x: _T, y: _T) -> tuple[_T, _T]: ... # E.g. coerce([], [1]) -> ([], [
def compile(source, filename: str, mode: str, flags: int = ..., dont_inherit: int = ..., optimize: int = ...) -> code: ...
def delattr(object, name: Union[str, bytes, bytearray]) -> None: ...
def dir(*args, **kwargs) -> list[str]: ...

class _SupportsDivMod(Protocol[_T, _T2, _T3]):
def __divmod__(self, other: _T) -> tuple[_T2, _T3]: ...

@overload
def divmod(x: int, y: int) -> tuple[int, int]: ...
@overload
def divmod(x: Union[int, float], y: Union[int, float]) -> tuple[float, float]: ...
@overload
def divmod(x: Union[int, float, complex], y: Union[int, float, complex]) -> tuple[complex, complex]: ...
@overload
def divmod(x: _SupportsDivMod[_T, _T2, _T3], y: _T) -> tuple[_T2, _T3]: ...

def eval(src, *args, **kwargs) -> Any: ... # Can't say *anything* about the result -- different from "-> object"
def exec(src, *args, **kwargs) -> NoneType: ...
def execfile(filename: str, *args, **kwargs) -> NoneType: ...
Expand Down
9 changes: 9 additions & 0 deletions pytype/tests/test_builtins4.py
Original file line number Diff line number Diff line change
Expand Up @@ -768,6 +768,15 @@ def __index__(self) -> int:
print(x[C()])
""")

def test_divmod(self):
self.Check("""
import datetime
from typing import Tuple
assert_type(divmod(1, 2), Tuple[int, int])
assert_type(divmod(datetime.timedelta(1), datetime.timedelta(2)),
Tuple[int, datetime.timedelta])
""")


class SetMethodsTest(test_base.BaseTest):
"""Tests for methods of the `set` class."""
Expand Down

0 comments on commit 8af6303

Please sign in to comment.