* `git stash --include-untracked` touches .pack files
@ 2025-08-07 2:27 johnkw
2025-08-11 9:10 ` Patrick Steinhardt
0 siblings, 1 reply; 2+ messages in thread
From: johnkw @ 2025-08-07 2:27 UTC (permalink / raw)
To: git
`git stash --include-untracked` causes the timestamp to be touched for
some .pack files. It's not always all .pack files, although I don't see
a pattern regarding how some survive the operation with the timestamp
intact. For a given repo it seems consistent though on the .pack files
impacted by the issue.
This breaks backup systems such as rsync, causing pointless churn.
The issue occurs with or without ".keep" files for the ".pack" files in
question.
`git stash` without `--include-untracked` does not have this issue.
The issue occurs with no untracked files actually even in the repo for
`--include-untracked` to take action on.
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: `git stash --include-untracked` touches .pack files
2025-08-07 2:27 `git stash --include-untracked` touches .pack files johnkw
@ 2025-08-11 9:10 ` Patrick Steinhardt
0 siblings, 0 replies; 2+ messages in thread
From: Patrick Steinhardt @ 2025-08-11 9:10 UTC (permalink / raw)
To: johnkw; +Cc: git
On Wed, Aug 06, 2025 at 09:27:05PM -0500, johnkw wrote:
> `git stash --include-untracked` causes the timestamp to be touched for some
> .pack files. It's not always all .pack files, although I don't see a
> pattern regarding how some survive the operation with the timestamp intact.
> For a given repo it seems consistent though on the .pack files impacted by
> the issue.
>
> This breaks backup systems such as rsync, causing pointless churn.
>
> The issue occurs with or without ".keep" files for the ".pack" files in
> question.
>
> `git stash` without `--include-untracked` does not have this issue.
>
> The issue occurs with no untracked files actually even in the repo for
> `--include-untracked` to take action on.
What you probably see here is Git freshening its objects: when Git is
asked to write objects into the object database that it already knows
about it will freshen the access time of each such object. If the object
is stored in a packfile, then the whole packfile is getting freshened.
This is overall an expected outcome, and Git relies on those freshened
access times to do garbage collection. So this isn't something that we
can change. One _could_ have a look at `save_untracked_files()` and
teach it to skip writing objects in case there is nothing to be done.
But honestly, I doubt that this would really solve the underlying issue
for you, as any other command that writes objects might also cause Git
to freshen the packfile.
Patrick
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-08-11 9:10 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-07 2:27 `git stash --include-untracked` touches .pack files johnkw
2025-08-11 9:10 ` Patrick Steinhardt
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).