Главная | Все статьи | Код

Ой, блин, гит!

Время чтения статьи ~1 минута
Ой, блин, гит! главное изображение

Это перевод заметки "Oh shit, git!" от Katie Sylor-Miller.

Git — сложная штука. Испортить все очень легко, а исправить проблему иногда чертовски сложно. В официальной документации прослеживается проблема курицы и яйца: сложно понять как выйти из сложной ситуации если не знаешь название штуки, которая тебе требуется чтобы исправить проблему.

Вот список плохих ситуаций, в которые я попадала, и как я в итоге смогла выбраться. На простом языке!

Ой, блин, я сделал что-то не то. Тут же есть машина времени, правда?..

git reflog
# ты увидишь список всех действий во всех ветках
# у каждой есть индекс HEAD@{index}
# найди тот, после которого ты все поломал
git reset HEAD@{index}
# волшебная машина времени

Блин! Сделал коммит, но понял, что забыл одну мелочь

# сделай что хотел
git add . # или добавляй файлы по одному
git commit --amend
# теперь измени или оставь старое сообщение коммита
# теперь твой последний коммит включает то новое изменение!

Ой, блин, нужно изменить сообщение в последнем коммите

git commit --amend
# тут можно изменить сообщение

Бли-и-ин! Коммитнул в мастер, а надо было в новую ветку!

# создай новую ветку на основе мастера
git branch some-new-branch-name
# удали последний коммит из мастера
git reset HEAD~ --hard
git checkout some-new-branch-name
# теперь тот коммит в новой ветке! :)

Естественно, это не сработает если ты уже сделал пуш в origin. Ну, и если коммитов больше, чем один, то надо git reset HEAD@{число}.

Блин! Коммитнул не в ту ветку.

# отмени последний коммит, но оставь изменения
git reset HEAD~ --soft
git stash
# перейди в нужную ветку
git checkout name-of-the-correct-branch
git stash pop
git add . # или добавь файлы по одному
git commit -m "your message here"
# теперь изменения в нужной ветке

Другой вариант — использовать cherry-pick:

git checkout name-of-the-correct-branch
# возьми последний коммит мастера
git cherry-pick master
# удали его из мастера
git checkout master
git reset HEAD~ --hard

Блин, сделал diff, но ничего не происходит!

git diff --staged

Git показывает изменения в diff только для тех файлов, которые еще не добавлены в staging area (еще не сделан git add). С флагом --staged будет показывать diff для добавленных файлов.

Нахрен всё, я сдаюсь

cd ..
sudo rm -r fucking-git-repo-dir
git clone https://some.github.url/fucking-git-repo-dir.git
cd fucking-git-repo-dir
Аватар пользователя R. D.
R. D. 19 декабря 2017
7
Рекомендуемые программы
профессия
от 6 300 ₽ в месяц
Разработка фронтенд-компонентов для веб-приложений
10 месяцев
с нуля
Старт 25 апреля
профессия
от 6 300 ₽ в месяц
Разработка веб-приложений на Django
10 месяцев
с нуля
Старт 25 апреля
профессия
от 6 183 ₽ в месяц
Ручное тестирование веб-приложений
4 месяца
с нуля
Старт 25 апреля
профессия
от 6 300 ₽ в месяц
Разработка приложений на языке Java
10 месяцев
с нуля
Старт 25 апреля
профессия
от 5 025 ₽ в месяц
новый
Сбор, анализ и интерпретация данных
9 месяцев
с нуля
Старт 25 апреля
профессия
от 6 300 ₽ в месяц
Разработка веб-приложений на Laravel
10 месяцев
с нуля
Старт 25 апреля
профессия
от 5 840 ₽ в месяц
Создание веб-приложений со скоростью света
5 месяцев
c опытом
Старт 25 апреля
профессия
от 9 900 ₽ в месяц
Разработка фронтенд- и бэкенд-компонентов для веб-приложений
16 месяцев
с нуля
Старт 25 апреля
профессия
от 6 300 ₽ в месяц
Разработка бэкенд-компонентов для веб-приложений
10 месяцев
с нуля
Старт 25 апреля
профессия
новый
Автоматизированное тестирование веб-приложений на JavaScript
8 месяцев
c опытом
в разработке
Старт 25 апреля
профессия
Верстка с использованием последних стандартов CSS
5 месяцев
с нуля
Старт в любое время