Ответ 1
update: добавлен более безопасный метод
предпочтительный метод:
1) проверьте предыдущее (неизмененное) состояние вашего файла; обратите внимание на двойную тире
git checkout HEAD^ -- /path/to/file
2) зафиксируйте его:
git commit -am "revert changes on this file, not finished with it yet"
3) нажмите, не требуя силы:
git push
4) вернитесь к своей незавершенной работе, снова сделайте (стрелка вверх 3 раза):
git checkout HEAD^ -- /path/to/file
эффективно "неудобный":
Чтобы изменить последнее фиксацию хранилища HEAD, запутывая вашу случайно перенесенную работу, в то же время потенциально столкнувшись с конфликтом с вашим коллегой, который, возможно, уже вытащил его, и кто будет расти седые волосы и терять много времени, пытаясь примирить его головка локального ветки с центральной:
Чтобы удалить файл из последнего фиксации:
1), чтобы вернуть файл в состояние до последнего фиксации, выполните:
git checkout HEAD^ /path/to/file
2), чтобы обновить последнюю фиксацию с возвращенным файлом, выполните:
git commit --amend
3), чтобы нажать обновленную фиксацию на репо, do:
git push -f
Действительно, рассмотрите использование предпочтительного метода, упомянутого ранее.