В моих экспериментах я не смог найти никакой функциональной разницы между
git reset --hard
и
git reset --merge
Инструкции по использованию также не дают подсказок
--hard reset HEAD, index and working tree
--merge reset HEAD, index and working tree
Я регулярно использую опцию --hard
, чтобы понять, как это работает. В чем разница между параметрами --merge
и --hard
?
Ура,
Olly
Возможно, здесь поможет пример, давайте используем следующую последовательность:
cd git_repo
touch file_one
git add file_one
git commit -m "commit one" # sha1 of 123abc
echo "one" >> ./file_one
git commit -a -m "commit two" # sha1 of 234bcd
echo "two" >> ./file_one
git add . # populate index with a change
echo "three" >> ./file_one # populate working area with a change
Теперь, если я попытаюсь
git reset --merge 123abc
Я получаю
error: Entry 'file_one' not uptodate. Cannot merge.
fatal: Could not reset index file to revision '123abc'
причина в том, что file_one имеет изменения как в рабочей области, так и в индексе
Чтобы исправить это, я делаю
git add .
git reset --merge 123abc
На этот раз это работает, однако я получаю тот же результат, что и git reset --hard
. Индекс пуст, рабочая область пуста, file_one пуст, как это было после первой фиксации.
Может кто-нибудь придумать шаги, иллюстрирующие разницу?