git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* `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).