Re: Tracked file cannot be added, mentions to sparse checkout that I don't have.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2024-07-30 at 10:29:26, Nathan Teodosio wrote:
> What did you do before the bug happened? (Steps to reproduce your issue)
> 
> I modified a tracked file.
> 
> What did you expect to happen? (Expected behavior)
> 
> The file is listed as modified in git status and added with git add etc.,
> i.e. the usual commit routine.
> 
> What happened instead? (Actual behavior)
> 
> I cannot add or commit the changes done to that file.
> 
> --->
> % echo 1 >> snapcraft.yaml
> % tail -n1 snapcraft.yaml
> 1
> # I expected snapcraft.yaml to show here:
> % git status -s
> ?? git-bugreport-2024-07-30-1212.txt
> # I expected snapcraft.yaml to be added here:
> % git add snapcraft.yaml
> The following paths and/or pathspecs matched paths that exist
> outside of your sparse-checkout definition, so will not be
> updated in the index:
> snapcraft.yaml
> hint: If you intend to update such entries, try one of the following:
> hint: * Use the --sparse option.
> hint: * Disable or modify the sparsity rules.
> hint: Disable this message with "git config advice.updateSparsePath false"
> <---

Have you perhaps done `git update-index --skip-worktree snapcraft.yaml`?
Here's how you can find out:

  % git ls-files -t | grep snapcraft.yaml
  S snapcraft.yaml

That "S" means it's skip-worktree.  Otherwise, we'd normally expect to
see an "H" or maybe another letter there.

If so, that might be because you've received some information
(unfortunately erroneous) that `git update-index --skip-worktree` or
`git update-index --assume-unchanged` are good ways to ignore changes to
a tracked file.  The Git FAQ[0] is pretty clear that Git doesn't allow
ignoring tracked files and explains why.  The skip-worktree bit is
designed to implement sparse checkout, so that's why you typically get
that message if that bit is set and you try to add the file.

You can unset that bit with `git update-index --no-skip-worktree
snapcraft.yaml`, which should fix the problem.  As for ignoring files,
the Git FAQ outlines an alternative which we recommend instead:

  If your goal is to modify a configuration file, it can often be
  helpful to have a file checked into the repository which is a template
  or set of defaults which can then be copied alongside and modified as
  appropriate. This second, modified file is usually ignored to prevent
  accidentally committing it.

Hopefully that's helpful.  If I'm incorrect and that bit hasn't been set
in the index, please do let us know, because that would be unexpected.

[0] https://git-scm.com/docs/gitfaq#ignore-tracked-files
-- 
brian m. carlson (they/them or he/him)
Toronto, Ontario, CA

Attachment: signature.asc
Description: PGP signature


[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux