git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
From: "Torsten Bögershausen" <tboegi@web.de>
To: "Mirochnik, Oleg V" <oleg.v.mirochnik@intel.com>
Cc: "git@vger.kernel.org" <git@vger.kernel.org>
Subject: Re: git reset --hard can leave modified files
Date: Mon, 2 May 2022 21:26:34 +0200	[thread overview]
Message-ID: <20220502192634.bzjfvoda2wjjxs3i@tb-raspi4> (raw)
In-Reply-To: <CY5PR11MB608914F7E815A8EF95441BB1C6C19@CY5PR11MB6089.namprd11.prod.outlook.com>

On Mon, May 02, 2022 at 06:37:26PM +0000, Mirochnik, Oleg V wrote:
> > -----Original Message-----
> > From: Torsten Bögershausen <tboegi@web.de>
> > Sent: Friday, April 29, 2022 9:50 PM
> > To: Mirochnik, Oleg V <oleg.v.mirochnik@intel.com>
> > Cc: git@vger.kernel.org
> > Subject: Re: git reset --hard can leave modified files
> >
> > On Fri, Apr 29, 2022 at 03:50:59PM +0000, Mirochnik, Oleg V wrote:
> > > Thank you for filling out a Git bug report!
> > > Please answer the following questions to help us understand your issue.
> > >
> > > What did you do before the bug happened? (Steps to reproduce your
> > > issue) git clone https://github.com/intel/llvm cd llvm git checkout
> > > git-bug-reproducer git merge 38df0bd4fccd1067f3abe078d42e94c740748628
> > > -m Merge1 --no-ff git merge b6b8d34554a4d85ec064463b54a27e073c42beeb
> > > -m Merge2 --no-ff git reset --hard HEAD~ git status --porcelain
> > >
> > > What did you expect to happen? (Expected behavior) An empty output
> > > from the last command
> > >
> > > What happened instead? (Actual behavior)  M
> > > clang-tools-extra/test/clang-apply-replacements/Inputs/crlf/crlf.cpp
> > >  M
> > > clang-tools-extra/test/clang-apply-replacements/Inputs/crlf/crlf.cpp.e
> > > xpected
> > >
> > > What's different between what you expected and what actually happened?
> > > Obvious
> > >
> > > Anything else you want to add:
> > > The issue is flaky. First found for v2.29.2 Multiple executions of the
> > > "git reset --hard HEAD" can help.
> > > I ran a simple script to get some numbers: 100 attempts to get and fix the issue
> > with up to 100 runs of the "git reset --hard HEAD"
> > > Got max number of runs - 45. Most of the cases (63) required 5 runs. 5 cases
> > did not get the issue at all.
> > > V2.36.0 built from sources got similar results:
> > >
> > > The script:
> > > (set -e; for a in {0..99}; do echo ++++++++++++++++ a=$a; git reset
> > > --hard origin/git-bug-reproducer; git merge
> > > b2d4d67d5e34c345cb6a3cf725b2e26a15a9dfe5 -m Merge1 --no-ff; git merge
> > > b6b8d34554a4d85ec064463b54a27e073c42beeb -m Merge2 --no-ff; git reset
> > > --hard HEAD~; for b in {1..99}; do git status --porcelain | grep . ||
> > > break; git reset --hard HEAD; done; echo ++++++++ b=$b; git status
> > > --porcelain | grep . || continue; echo FAILED $a; break; done) >
> > > ../logg 2>&1
> > >
> > > Please review the rest of the bug report below.
> > > You can delete any lines you don't wish to share.
> > >
> > >
> > > [System Info]
> > > git version:
> > > git version 2.36.0
> > > cpu: x86_64
> > > no commit associated with this build
> > > sizeof-long: 8
> > > sizeof-size_t: 8
> > > shell-path: /bin/sh
> > > uname: Linux 4.18.0-193.el8.x86_64 #1 SMP Fri Mar 27 14:35:58 UTC 2020
> > > x86_64 compiler info: gnuc: 4.4 libc info: glibc: 2.28 $SHELL
> > > (typically, interactive shell): /bin/bash
> > >
> > >
> > > [Enabled Hooks]
> > > not run from a git repository - no hooks to show
> >
> > One quesion, out of interest:
> > do you have core.autocrlf=true ?
>
> Nope.
>
> > What does
> > git config core.autocrlf
> > give you ?
>
> Nothing:
> $ git config core.autocrlf
> $
>
> > The llvm repo itself has a lot of files commited with CRLF in the repo.
> >
> > You can see this by running
> > git ls-files --eol | grep "^i/crlf"
> >
> > So my recommendation would be to set up a proper .gitatributes file in the root
> > of the repo, run
> >
> > git add --renormalize .
> > git add .gitattributes
> > git commit -m "Normalize the line endings"
>
> AFAIK all of them CRLF files are intentional.
> LLVM community decides on the stuff, we have to follow the decisions.
>

I somewhat suspect seriously that the problem is related to this thread:
https://reviews.llvm.org/D124563

I didn't dig into all the details (yet).

===================================
 git show c9a16e8c3d99173c7525e576d78eed571
Drop '* text=auto' from .gitattributes and normalize

 Git wants to check in 'text' files with LF endings, so this changes them
     in the repository but not in the checkout, where they keep CRLF endings.

    Differential Revision: https://reviews.llvm.org/D124563
--------------------
I don't know, if this was a good change or not.
If folks wants CRLF in their working tree, there are 3 ways to do so:
- Set core.autoclrf to true
- Set core.eol to CRLF
(This works on Windows and Unix)

Or, if everybody should have CRLF in the working tree,
we could (and should) still have LF in the repo.

Just set

*myfiles.cpp text=auto eol=crlf

In other words
(I may be wrong due a lack of time to dig deeper into the llvm repo)
the problem seems to come from upstream.

And we could find out, what upstream really wants and needs,
and may be able to help here.

Is this maybe something you can do, contact upstream ?


  reply	other threads:[~2022-05-02 19:27 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-04-29 15:50 git reset --hard can leave modified files Mirochnik, Oleg V
2022-04-30  4:49 ` Torsten Bögershausen
2022-05-02 18:37   ` Mirochnik, Oleg V
2022-05-02 19:26     ` Torsten Bögershausen [this message]
2022-05-02 22:07       ` Mirochnik, Oleg V
2022-05-04 15:42         ` Torsten Bögershausen

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: http://vger.kernel.org/majordomo-info.html

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220502192634.bzjfvoda2wjjxs3i@tb-raspi4 \
    --to=tboegi@web.de \
    --cc=git@vger.kernel.org \
    --cc=oleg.v.mirochnik@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

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 read-only IMAP folder(s) and NNTP newsgroup(s).