2015-11-12 10 views
9

Mam stare zatwierdzenie md5hash na myfile.extension z SOME CHANGE w treści zatwierdzenia (nie tytuł/metadane zatwierdzenia).Blokowanie kodu Git kodu przeniesionego/usuniętego w pliku

Jak mogę wygenerować listę zatwierdzeń z SOME CHANGE zmodyfikowanych (nie tylko obecnych) w zatwierdzeniach prowadzących do HEAD z md5hash bez konieczności sprawdzania każdej wersji? (z których niestety jest wiele w obecnym przypadku).

Próbowałem git rev-list --all | xargs git grep 'SOME CHANGE', ale wydaje się, że znalazłem wszystkie zatwierdzenia z SOME CHANGE, które znajdują się w pliku.

git blame wydaje się bezużyteczna, ponieważ zmieniły się linie i przeniesiono SOME CHANGE.

Odpowiedz

4

Myślę, że odpowiedź, której szukasz, to git --no-pager log --pretty="%H" -G"SOME CHANGE" -- myfile.extension.

Najpierw pomyślałem o git log -S, ale obejmuje tylko dodawanie/usuwanie. git log -G prawdopodobnie byłby bliski tego, co chcesz. Tutaj możesz zobaczyć różnicę między -S i -G, a także dodałem pełną historię commitów, dzięki czemu możesz zobaczyć, co nie jest objęte. Przeczytaj komunikaty o zatwierdzeniu, aby zobaczyć, co zrobiłem w ciele.

# git --no-pager log --oneline -S"SOME CHANGE" 
12e24ed Remove text 
9427ffc Add the text 
# git --no-pager log --oneline -G"SOME CHANGE" 
12e24ed Remove text 
6a33653 Change other text on same line 
ac09bbb Append other text to same line 
484b447 Move the text two lines down 
9427ffc Add the text 
# git --no-pager log --oneline 
12e24ed Remove text 
9c7f7d5 Change text on adjacent line 
6a33653 Change other text on same line 
ac09bbb Append other text to same line 
484b447 Move the text two lines down 
377936f Add other text on adjacent line 
9427ffc Add the text 
1929648 Initial commit 

Aby dostać tylko z mieszań:

# git --no-pager log --pretty="%H" -G"SOME CHANGE" 
12e24ed749e499bc2d8920c5d8a3ca98a6422e3f 
6a336532210ca85dea86968c34cef516345b8ab4 
ac09bbb5c95bbea65e7c99c730653d27f90397f4 
484b4478e4cb16c839dac558f3e958683b428a64 
9427ffc7dd60a3cfb1d9880083e6262faea0eefb 
0

To wciąż wymaga trochę brodzenie wyników, ale może to Ci bliżej:

git rev-list --all | xargs git show | egrep '(^ ?[+-].*(SOME CHANGE)|^commit)' | egrep -B1 '^ ?[+-]' | uniq 

To pokazuje poprawkę dla każdego popełnienia, pokazuje sha to patrzysz, a następnie wypluwa linię kodu, który pasuje. Odpowiednie sha na mecz jest powyżej meczu.

Możesz dalej budować rurociąg, aby jeszcze bardziej oczyścić wyniki, jeśli jest to wykonalny sposób.

0

myślę szukasz:

git log -S<string> 

Look różnice, które zmieniają liczbę wystąpień określonego ciągu znaków (czyli dodawanie/usuwanie) w pliku. Przeznaczony do użytku skryptera.

Przydaje się, gdy szukasz dokładnego bloku kodu (takiego jak struktura) i chcesz poznać historię tego bloku od jego powstania: użyj funkcji iteracyjnie, aby podać interesujący blok w preimage z powrotem do -S, i kontynuuj, póki nie otrzymasz pierwszej wersji bloku.