-
-
Notifications
You must be signed in to change notification settings - Fork 248
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
feat(time_display): time should use timezone settings #1327
base: main
Are you sure you want to change the base?
Conversation
6bcd549
to
efe1577
Compare
The pipeline is still not happy. I think another |
Yes, go a bit annoyed because only FreeBSD tests failed (different rustc settings?), and after some to-and-from work, I've forgotten to run |
Yea, I hear ya. I've run into BSD related issues myself. And don't get me started on illumos pipelines. No project should ever use those. Argh! |
But, all tests pass! Yeah! @cafkafk it's ready for review and/or merge. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍 , just left a minor comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice catch! Generally LGTM! Thanks!
The only two things I think could be improved are:
- Most of the commit messages are understandable in the context of this PR but maybe a bit too general for this to be still the case after rebase/merge when this is part of the wider history. So adding scopes and being a little more precise and adding context would help.
- Some of the small fix commits might be better of either squashed together or into the commits that caused them.
I cannot speak for @erwinvaneijk but in my projects I don't care about the commit messages in a PR. What is important is that you don't do a merge commit, but rather a squash commit - and then use a convential commit message. This means that the person who merges the PR can pick whatever commit message they want and there will be only one commit. P.S.: Previously I asked people to rebase, squash, force push in PRs, but I no longer do that. It's easier to follow the development of the PR if this is not done. Especially when there are a lot of comments and change requests. |
Glad you like the PR @gierens, thank you for the review. However, the changes you request to the commit messages cannot be done (or my That goes for me too. The merge to the main should be well-formatted, and it's a choice whether or not to squash or just merge. Trying to create a squash merge in this PR that then can be merged is a pain, IMNSHO. |
@erwinvaneijk I can squash and force-push if the devs insist on it. but I need access/permissions to your repo/branch. @cafkafk can you please have a look? the 2 current reviews didn't make much sense. The first review would have let eza fail silently and as a result shown wrong dates/times without notifying the user. |
I've added you to my repos, thanx for the effort you want to make. |
70f333b
to
27bfb6a
Compare
Done. I've used |
@tessus sorry for the late reply, been a bit busy lately, otherwise I would've helped out with rebasing the commits.
I try to elaborate a bit more, see below.
As the CONTRIBUTING.md states, we like small and conventional commits that make a minimal self-contained change to the code. So for example, when adding a trait in one file and implementing it for some struct in another two commits would be a good choice. There is of course always room for interpretation. But doing a Squash-Merge on a PR that alters several things at once goes directly against that concept. If you do that in your repos that is fine, we do it differently though, which is also why we only have the Rebase option configured on the Merge button. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
By "squashing some of the smaller fix commits" I did not mean squashing everything. What I meant was, there originally were commits that fixed typos in previous commits of this PR, those could've been squashed together. And the commits for removal of unused lifetime names could've been squashed together as they are minor format fixes unrelated to the PR's actual intent.
If you want please rebase it again accordingly, otherwise I can do that tomorrow.
@gierens ah, ok. with Anyway, I now have already squashed all commits into one. I don't have a backup. P.S.: I didn't do a rebase. A rebase is not possible:
|
Sorry for not explaining it very well before.
No problem, I can quickly do that tomorrow but now I have to 😴 |
A rebase is not possible:
|
A rebase would only work, if you have commits in main after now 2025-01-17 23:35:01 +0000 |
Sorry, I didn't mean rebase like that ... I meant picking it apart into multiple commits again, I usually use the term rebase as reference to interactive rebase But don't worry, I can quickly do that tomorrow. |
There's no |
Ok, I used the reflog to do a hard reset and created 2 commits. |
@gierens is it ok now? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for the late reply, was again little overwhelmed by other things.
@gierens is it ok now?
Almost, I split off the addition of dependencies and tests into separate commits. Now it looks clean to me. Thx both of you for your effort and patience :)
LGTM!
To be honest those 2 additional commits make no sense. A code change should not be taken apart, just to create commits. One commit should be about one code change (fix/feat/...). Additionally the code change wouldn't work without adding the crates as dependencies. Tests are usually also put in the same commit. IMO this is not the idea behind conventional commits. Yes, you could have a second commit for the tests, but only if they were not in the first commit, because the author didn't write tests. But creating a separate commit just to use a I've been 30 years in IT and I have never seen a project that has such a weird commit strategy. P.S.: I understand that one wants 2 commits, one for the change and another for the clippy stuff, but I would still merge it, if it were only 1 commit. So 2 commits are perfectlty valid. I would even be ok with 3 commits (tests in a separate commit), even though that's debatable. But these 4 commits are really, really weird. |
Everyone: thank you for the help getting this bug fixed. It doesn’t display the right time (under conditions), which If someone with the appropriate rights can press the merge button, that would be excellent! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The code looks okay, but this seems to give some pretty harsh performance penalties...
hyperfine -w 500 -r 500 '{cmd} -l ../../dbc' --parameter-list cmd ./target/release/eza,eza,./target/release/eza,eza --time-unit microsecond -N
Benchmark 1: ./target/release/eza -l ../../dbc
Time (mean ± σ): 9110.7 µs ± 2264.3 µs [User: 5555.8 µs, System: 14314.8 µs]
Range (min … max): 3641.7 µs … 14175.8 µs 500 runs
Benchmark 2: eza -l ../../dbc
Time (mean ± σ): 6797.0 µs ± 2506.1 µs [User: 3778.8 µs, System: 10336.2 µs]
Range (min … max): 2668.1 µs … 25183.7 µs 500 runs
Benchmark 3: ./target/release/eza -l ../../dbc
Time (mean ± σ): 9824.4 µs ± 1973.4 µs [User: 6026.3 µs, System: 15514.3 µs]
Range (min … max): 3340.9 µs … 16388.8 µs 500 runs
Benchmark 4: eza -l ../../dbc
Time (mean ± σ): 6749.1 µs ± 2599.9 µs [User: 3646.6 µs, System: 10192.5 µs]
Range (min … max): 2584.6 µs … 24336.6 µs 500 runs
Summary
eza -l ../../dbc ran
1.01 ± 0.54 times faster than eza -l ../../dbc
1.35 ± 0.62 times faster than ./target/release/eza -l ../../dbc
1.46 ± 0.63 times faster than ./target/release/eza -l ../../dbc
I wonder if we can somehow mitigate this, it's pretty severe...
src/output/render/times.rs
Outdated
fn render(self, style: Style, time_offset: FixedOffset, time_format: TimeFormat) -> TextCell { | ||
let datestamp = if let Some(time) = self { | ||
fn render(self, style: Style, time_format: TimeFormat) -> TextCell { | ||
let datestamp = if let Ok(timezone_str) = iana_time_zone::get_timezone() { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It may be the case that running iana_time_zone::get_timezone()
for each render all gives us a constant O(n) penalty here that could be a O(1) if we just put the timezone into memory if it will be displayed. Could be e.g. a static oncelock or something else, assuming eza will never run long enough for a timezone change happening while running being fatal (in fact, it may be preferable so that we always assume the tz from when eza was started vs. having two timezones in the very unlikely crossover case).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, that is an issue. I'll see what we can do in this area. The assumption that the TZ will not change within the runtime of eza
is justified.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The code is now checked in, could you repeat the benchmarks?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If we knew something about this dbc
directory, we could run perf tests ourselves. Size, number of files, ....
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm
db4f85e
When a file timestamp is displayed, it should use the timezone info from the time of the timestamp, not from when it is displayed. This occurs when a file timestamp is updated under daylight saving time, and displayed at a time when not under daylight saving time. This bug is quite subtle, as it depends on the time of construction of the timestamp, not on the moment it is read.
- lifetimes that can be elided - not use return as last statement in function
Perform a timezone lookup only once at initialization, assuming that the timezone doesn't change during exection.
db4f85e
to
2e8ebbf
Compare
When a file timestamp is displayed, it should use the timezone info from the time of the timestamp, not from when it is displayed. This occurs when a file timestamp is updated under daylight saving time, and displayed at a time when not under daylight saving time.
The bug is quite subtle, as it depends on the time of construction of the timestamp, not on the moment it is read.
This fixes issue #653 .