Hej Daniel, $ git clone https://github.com/DanielHabenicht/bug-reproduction.git-repo.git $ cd bug-reproduction.git-repo.git $ git ls-files --eol i/none w/none attr/ .gitattributes i/lf w/lf attr/ README.md i/crlf w/crlf attr/text eol=lf test.cs Your repo needs to be re-normalized: $ git add --renormalize . $ git status On branch main Your branch is up to date with 'origin/main'. Changes to be committed: (use "git restore --staged <file>..." to unstage) modified: test.cs That is all that needs to be done. Users which are confused may put their frustration aside, and read the documentation: https://git-scm.com/docs/gitattributes especially the part about the line endings and normalization, search for "renormalize". I don't know, if there is something we can do that makes live easier, but if yes: suggestions are more than welcome. So yes, thanks for the report. On Thu, Apr 21, 2022 at 01:20:37PM +0000, Daniel Habenicht wrote: > Hi Randall and Brian, > > thanks for the fast response. > @Randall: I also tried it with autocrlf=input and it still reproduces. I included it in the reproduction. I also added more examples for confusing behaviour. > > > Here is the full bug report: > (You can view a Markdown rendered version of this reproduction at: https://github.com/DanielHabenicht/bug-reproduction.git-repo) > > # Description > > When changing the `.gitattributes` file not all changes to the checked in files are apparent. > They only get updated on a new clone or when refreshing the index - that's somehow expected. > But it creates confusion and unexpected behavior if they are not updated together with the `.gitattributes` changes. > It can make easy changes between branches impossible, break the flow of squashing commits or lead to confusing state of everlasting uncommited change. > These edge cases for confusing behaviour I have added below. > > # Reproduction > > 1. Checkout with the following `.gitconfig` settings set: > > ```gitconfig > # .gitconfig > [core] > autocrlf = false > # Or > autocrlf = input > ``` > > 2. Clone the repository > ```bash > git clone https://github.com/DanielHabenicht/bug-reproduction.git-repo.git > ``` > > 3. `test.cs` should be shown as `modified` > > > This is confusing to the user, he just checked the repo out and did not change a thing. At least there should be a warning? > > ``` > git status > On branch main > Your branch is up to date with 'origin/main'. > > Changes not staged for commit: > (use "git add <file>..." to update what will be committed) > (use "git restore <file>..." to discard changes in working directory) > modified: test.cs > > no changes added to commit (use "git add" and/or "git commit -a") > ``` > > 5. Running any git command like the ones below will not remove the changed file: > > ```bash > git rm --cached -r . > git reset --hard > git add --renormalize . > ``` > > > This as well is very confusing and there is no indication on why this is happening and there are still modified files after everything should be reset. > > Keep in mind that this could have happened in error and could be happening to a totally unrelated (to the inital `.gitattributes` change) user. > > 6. Running `git diff` is even more confusing, and doing as the warning suggests (`warning: CRLF will be replaced by LF in test.cs. The file will have its original line endings in your working directory`) and replacing `CRLF` by `LF` does silence the warning but does not change the diff itself: > > ```diff > warning: CRLF will be replaced by LF in test.cs. > The file will have its original line endings in your working directory > diff --git b/test.cs a/test.cs > index 1e230ed..5464a2d 100644 > --- b/test.cs > +++ a/test.cs > @@ -1,11 +1,11 @@ > -using System.Diagnostics.CodeAnalysis; > -using System.Linq; > -using Xunit; > -using Moq; > - > - > - > -namespace Tests > -{ > - > -} > +using System.Diagnostics.CodeAnalysis;^M > +using System.Linq;^M > +using Xunit;^M > +using Moq;^M > +^M > +^M > +^M > +namespace Tests^M > +{^M > +^M > +}^M > ``` > > > This is showing the exact opposite of what git is really doing. Actually it replaces the line encoding of the index (i/crlf) with the right encoding (i/lf) (see **[1]**) > > From the git user perspective everything is in great shape, the file is LF, as it should be, but still git complains about a change that is not visible to the user without background knowledge about gitattributes and the git index. > > 8. Try changing the branch to a modified copy with `git checkout some-changes` is not possible (also with the recommended command). The only solution would be to commit - nothing else helps (but thats not really a solution). : > > ```bash > error: Your local changes to the following files would be overwritten by checkout: > test.cs > Please commit your changes or stash them before you switch branches. > Aborting > ``` > > > This makes changing branches harder, as it can't be force reset and git will always complain about files being overwritten. > > It also break the flow for squashing commits as you would need to manually intervene (and add a commit) if someone forgot to commit all files after a .gitattributes change and only recognized it at a later date. > > > **[1]**: I hope this answer explained it right to me: https://stackoverflow.com/a/71937898/9277073. > But it is rather unintuitive to me, and possibly other users, as there seems to be a hidden middle layer leading to this problem. See the graph at the github repo) > > > > Cheers, > Daniel > > > > > Daniel Habenicht > > > From: rsbecker@xxxxxxxxxxxxx <rsbecker@xxxxxxxxxxxxx> > Sent: Thursday, April 21, 2022 00:34 > To: 'brian m. carlson' <sandals@xxxxxxxxxxxxxxxxxxxx>; 'Daniel Habenicht' <daniel-habenicht@xxxxxxxxxx> > Cc: git@xxxxxxxxxxxxxxx <git@xxxxxxxxxxxxxxx> > Subject: RE: Bug Report > > On April 20, 2022 5:31 PM, brian m. carlson wrote: > >On 2022-04-20 at 19:45:32, Daniel Habenicht wrote: > >> Hi there, > >> > >> I think I found a bug or at least some unexpected behavior. Please > >> have a look at the following reproduction repo: > >> > >> https://nam12.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2FDanielHabenicht%2Fbug-reproduction.git-repo%2Fblob%2Fmain&data=05%7C01%7C%7C145ae6f595d54ac7b5fd08da231de43c%7C84df9e7fe9f640afb435aaaaaaaaaaaa%7C1%7C0%7C637860908535410706%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=HXFm4sBZ5yQGQPkBlkzKhkgDJOXBqSlgETkrhGxgkmI%3D&reserved=0 > >> /README.md > > > >You're more likely to get someone to look at this if you post the actual text to the > >list. While I might be willing to look at it on GitHub, other folks won't, and I > >probably won't get a chance to look at this issue anytime soon. > > The only thing that I can see that is apparently a problem is that autocrlf=false is not documented in the config help, so it is not apparent what the expected result should be relative to the test case. That could be considered confusing. There could also be confusion relative to when the git diff was done relative to what is in the staging area given his test case. I think what Daniel may really want is to use autocrlf=input. > > Daniel, please post your entire report to this list rather than using GitHub, links, or attachments. I happened to be on GitHub at that moment, so looked, but otherwise, I would not have specifically looked. > > --Randall > > -- > Brief whoami: NonStop&UNIX developer since approximately > UNIX(421664400) > NonStop(211288444200000000) > -- In real life, I talk too much.