Skip to content

BUG: Fixes Incompatible return value type in pandas/core/generic.py #52897

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 10 commits into from
May 7, 2023
2 changes: 1 addition & 1 deletion pandas/core/generic.py
Original file line number Diff line number Diff line change
Expand Up @@ -658,7 +658,7 @@ def size(self) -> int:
"""
# error: Incompatible return value type (got "signedinteger[_64Bit]",
# expected "int") [return-value]
return np.prod(self.shape) # type: ignore[return-value]
return int(np.prod(self.shape)) # type: ignore[return-value]

def set_axis(
self,
Expand Down
24 changes: 20 additions & 4 deletions web/pandas_web.py
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,9 @@
import requests
import yaml

from packaging import version
from itertools import groupby

api_token = os.environ.get("GITHUB_TOKEN")
if api_token is not None:
GITHUB_API_HEADERS = {"Authorization": f"Bearer {api_token}"}
Expand Down Expand Up @@ -205,7 +208,6 @@ def maintainers_add_info(context):
@staticmethod
def home_add_releases(context):
context["releases"] = []

github_repo_url = context["main"]["github_repo_url"]
resp = requests.get(
f"https://api.github.com/repos/{github_repo_url}/releases",
Expand All @@ -219,11 +221,26 @@ def home_add_releases(context):
else:
resp.raise_for_status()
releases = resp.json()

with open(pathlib.Path(context["target_path"]) / "releases.json", "w") as f:
json.dump(releases, f, default=datetime.datetime.isoformat)

for release in releases:
# Sort the releases in descending order
sorted_releases = sorted(releases, key=lambda release:version.parse(release["tag_name"]), reverse=True)
sorted_releases = sorted(
releases,
key=lambda release: version.parse(release["tag_name"]),
reverse=True,
)

# Gathers minor versions
latest_releases = []
minor_versions = set()
for release in sorted_releases:
minor_version = ".".join(release["tag_name"].split(".")[:2])
if minor_version not in minor_versions:
latest_releases.append(release)
minor_versions.add(minor_version)
for release in latest_releases:
if release["prerelease"]:
continue
published = datetime.datetime.strptime(
Expand All @@ -241,7 +258,6 @@ def home_add_releases(context):
),
}
)

return context

@staticmethod
Expand Down