W Git GUI mogę wybrać części diff i ustawić tylko te linie lub kawałki. Jak mam zrobić coś odwrotnego, jak w przypadku cofnięcia zmienionych linii w pliku. Zwykle są to przypadkowe białe zmiany przestrzeni, które po prostu chcę wycofać, ale nadal etapować/zatwierdzać inne części tego samego pliku.Git Diff - Jak mogę przywrócić wybrane linie lub porcje?
Odpowiedz
Dla Git Gui: Najpierw kliknij Skanuj ponownie, aby wyszukać zmodyfikowany plik. Następnie kliknij ikonę po lewej stronie nazwy pliku, aby wyświetlić wszystkie modyfikacje dotyczące zatwierdzenia. Następnie kliknij prawym przyciskiem myszy na linię debugowania i wybierz Unstage Line From Commit.
Powyższe informacje od: http://nathanj.github.com/gitguide/tour.html
To faktycznie nie przywraca niczego w pliku. –
etapie częściami chcesz z git add -p
, a następnie wyrzucić (git checkout -- filename
) z Unstaged zmian.
Wiem, że pytanie dotyczy Git Gui, ale dziękuję bardzo za udostępnienie alternatyw dla użytkowników linii poleceń. Prosty w użyciu. –
W Git GUI
- Stage cały plik, który zawiera niepożądaną zmianę (-y)
- Unstage Linie/bryły, które mają zostać przywrócone
- Wybierz plik w panelu Unstaged Zmiany i komisje> Przywróć zmiany aby cofnąć wszystkie (Unstaged) zmiany w tym pliku
Źródło: http://git.661346.n2.nabble.com/Revert-hunk-td4991128.html
Rekwizyty odpowiadające na pytanie w tytule i robiące to za pomocą 'git gui'. Bardzo pomocne. – mattgately
Dzięki za to ... to działa. Jednak git gui sprawia, że tęsknię za przedłużeniem git. –
git interaktywny dodaj Wierzę lub http://stackoverflow.com/questions/1085162/how-can-i-commit-only-part-of-a-file-in-git –
Jest odwrotnie. Wprowadza zmiany, ale musisz przywrócić plik. – Kenoyer130
http://stackoverflow.com/questions/1981830/undo-part-of-startstaged-changes-in-git –