В GitFaq я могу прочитать, что
Git устанавливает текущее время как метку времени для каждого изменяемого файла, но только для них.
Однако я попробовал эту последовательность команд ( РЕДАКТИРОВАТЬ: добавлена полная последовательность команд)
$ git init test && cd test
Initialized empty Git repository in d:/test/.git/
$ touch filea fileb
$ git add .
$ git commit -m "first commit"
[master (root-commit) fcaf171] first commit
0 files changed, 0 insertions(+), 0 deletions(-)
create mode 100644 filea
create mode 100644 fileb
$ ls -l > filea
$ touch fileb -t 200912301000
$ ls -l
total 1
-rw-r--r-- 1 exxxxxxx Administ 132 Feb 12 18:36 filea
-rw-r--r-- 1 exxxxxxx Administ 0 Dec 30 10:00 fileb
$ git status -a
warning: LF will be replaced by CRLF in filea
# On branch master
warning: LF will be replaced by CRLF in filea
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: filea
#
$ git checkout .
$ ls -l
total 0
-rw-r--r-- 1 exxxxxxx Administ 0 Feb 12 18:36 filea
-rw-r--r-- 1 exxxxxxx Administ 0 Feb 12 18:36 fileb
Теперь мой вопрос: почему git изменил метку времени файла fileb
? Я ожидаю, что отметка времени не изменится.
Мои команды вызывают проблемы?
Может быть, вместо этого можно сделать что-то вроде git checkout . --modified
Я использую git version 1.6.5.1.1367.gcd48
под Mingw32 / Windows XP.