Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

gh-83714: Fix stat_nanosecond_timestamp() for 32-bit time_t#141069

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 ourterms of service andprivacy statement. We’ll occasionally send you account related emails.

Already on GitHub?Sign in to your account

Merged
vstinner merged 1 commit intopython:mainfromvstinner:statx_sec_to_ns2
Nov 5, 2025

Conversation

@vstinner
Copy link
Member

@vstinnervstinner commentedNov 5, 2025
edited by bedevere-appbot
Loading

@vstinner
Copy link
MemberAuthor

!buildbot x86 Debian

@bedevere-bot
Copy link

🤖 New build scheduled with the buildbot fleet by@vstinner for commit6e56143 🤖

Results will be shown at:

https://buildbot.python.org/all/#/grid?branch=refs%2Fpull%2F141069%2Fmerge

The command will test the builders whose names match following regular expression:x86 Debian

The builders matched are:

  • x86 Debian Installed with X PR
  • x86 Debian Non-Debug with X PR

{
#ifSIZEOF_LONG >=8
#ifSIZEOF_TIME_T==4
returnPyLong_FromLongLong(sec*SEC_TO_NS+nsec);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

What is the type of SEC_TO_NS? Should not it orsec be cast tolong long?

We will get a warning also in the very unlikely case of more than 64-bitlong long. Maybe use conditionSIZEOF_TIME_T + 4 <= SIZEOF_LONG_LONG?

Copy link
MemberAuthor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

What is the type of SEC_TO_NS?

It's a long long: it uses theLL suffix.

Copy link
MemberAuthor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

We will get a warning also in the very unlikely case of more than 64-bit long long.

I don't see which kind of warning would be emitted if long long is larger than 64-bit?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

The same warning. If long long is 128-bit and time_t is 64-bit, then the condition(LLONG_MIN/SEC_TO_NS) <= sec && sec <= (LLONG_MAX/SEC_TO_NS - 1) will be tested, and it will be always true.

I do not know if Python is currently used on any platform with larger than 64-bit long long. This is hypothetical.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

Anyway, this would be just a warning. Not wrong code or missed optimization.

Copy link
MemberAuthor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

If long long is 128-bit and time_t is 64-bit

Oh ok. Well, I expect many warnings if long long is larger than 64-bit, not just on these lines. We can revisit the code once such platform will exist :-)

Copy link
Member

@serhiy-storchakaserhiy-storchaka left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

LGTM. 👍

{
#ifSIZEOF_LONG >=8
#ifSIZEOF_TIME_T==4
returnPyLong_FromLongLong(sec*SEC_TO_NS+nsec);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others.Learn more.

Anyway, this would be just a warning. Not wrong code or missed optimization.

@vstinner
Copy link
MemberAuthor

The warnings are still fixed with this PR on x86 Debian:https://buildbot.python.org/#/builders/1285/builds/531

@vstinnervstinner marked this pull request as ready for reviewNovember 5, 2025 20:16
@vstinnervstinner merged commit986bb0a intopython:mainNov 5, 2025
53 of 54 checks passed
@vstinnervstinner deleted the statx_sec_to_ns2 branchNovember 5, 2025 20:16
StanFromIreland pushed a commit to StanFromIreland/cpython that referenced this pull requestDec 6, 2025
Sign up for freeto join this conversation on GitHub. Already have an account?Sign in to comment

Reviewers

@serhiy-storchakaserhiy-storchakaserhiy-storchaka approved these changes

Assignees

No one assigned

Labels

Projects

None yet

Milestone

No milestone

Development

Successfully merging this pull request may close these issues.

3 participants

@vstinner@bedevere-bot@serhiy-storchaka

[8]ページ先頭

©2009-2025 Movatter.jp