{"id":748,"date":"2017-01-30T15:43:20","date_gmt":"2017-01-30T13:43:20","guid":{"rendered":"http:\/\/blog.rollnut.com\/?p=748"},"modified":"2021-04-11T09:35:07","modified_gmt":"2021-04-11T07:35:07","slug":"git-glossar","status":"publish","type":"post","link":"http:\/\/blog.rollnut.com\/git-glossar\/","title":{"rendered":"Git Glossar"},"content":{"rendered":"

Hier findet\u00a0Ihr die wichtigsten Git-Befehle. Selbst wenn Ihr eine grafische Git-Oberfl\u00e4che verwendet ist es gut zu wissen welche Shell-Befehle es gibt und was diese tun.<\/p>\n

<\/p>\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n
Git einrichten<\/strong><\/td>\n<\/tr>\n<\/thead>\n
init<\/td>\nNeues Repository erstellen (aktuelles Verzeichnis).<\/td>\n<\/tr>\n
init --bare<\/td>\nEin zentrales Repository erstellen.
\nAchtung! Der Ordnername sollte mit .git<\/strong> enden (z.B. my-project.git).<\/td>\n<\/tr>\n
clone <repo><\/td>\nKopiert ein Repository welches unter <repo> zu finden ist.<\/td>\n<\/tr>\n
config --global<\/td>\nGlobale Konfiguration von git (z.B. Benutzerinfo angeben).<\/td>\n<\/tr>\n<\/tbody>\n
Mit Git lokal arbeiten<\/strong><\/td>\n<\/tr>\n<\/thead>\n
add <name><\/td>\nDateien und Ordner zur \"Staging Area<\/strong>\" hinzuf\u00fcgen (abh\u00e4ngig von <name>).
\nMit *<\/strong> werden alle \u00c4nderung hinzugef\u00fcgt (.ignore<\/strong>-Regeln werden aber beachtet).<\/td>\n<\/tr>\n
commit<\/td>\n\u00c4nderungen in der \"Staged Area<\/strong>\" werden in das lokale Repository \u00fcbernommen.<\/td>\n<\/tr>\n
stash<\/td>\nSpeichert alle lokalen \u00c4nderungen in ein lokales Stash-Objekt.
\nN\u00fctzlich um\u00a0aktuelle Arbeit ohne Commit zu sichern.<\/td>\n<\/tr>\n
status<\/td>\nZeigt offene\u00a0\u00c4nderungen, welche noch nicht committed wuden.<\/td>\n<\/tr>\n
log<\/td>\nZeigt\u00a0Commits (Ausgabe kann \u00fcber Parameter eingestellt werden, wie z.B. --graph).<\/td>\n<\/tr>\n<\/tbody>\n
Branching<\/strong><\/td>\n<\/tr>\n<\/thead>\n
branch<\/td>\nBranches verwalten (erstellen, l\u00f6schen, umbenennen)<\/td>\n<\/tr>\n
checkout <branch><\/td>\nVon einem Branch in ein anderes wechseln.
\nEs k\u00f6nnen auch einzelne Dateien oder Commits ausgecheckt werden.<\/em><\/td>\n<\/tr>\n
merge\u00a0--no-ff <branch><\/td>\nDas aktuelle\u00a0Branch mit <branch> zusammenf\u00fchren.
\nF\u00fcr Gr\u00f6\u00dfere merges\u00a0empfiehlt es sich immer --no-ff\u00a0zu verwenden (bessere Chronik).
\nNach dem Merge muss normal committed werden.<\/td>\n<\/tr>\n<\/tbody>\n
Git synchronisieren (mit zentralem Repository)<\/strong><\/td>\n<\/tr>\n<\/thead>\n
remote<\/td>\nRemote-Verbindungen verwalten.
\nDieser Befehl erstellt quasi ein Alias f\u00fcr umst\u00e4ndlich lange URL's.<\/td>\n<\/tr>\n
fetch<\/td>\nGit holt sich den aktuellen Stand des zentralen Repositories (ohne merge).
\nDies kann n\u00fctzlich sein um erst ein Review vor dem git merge<\/strong> zu machen.<\/td>\n<\/tr>\n
pull<\/td>\nMacht das selbe wie \"git fetch\"<\/strong> aber zus\u00e4tzlich noch \"git merge\"<\/strong>.<\/td>\n<\/tr>\n
push<\/td>\nLokale Commits zum zentralen Repository schicken.<\/td>\n<\/tr>\n<\/tbody>\n
Fortgeschrittene Funktionen<\/strong><\/td>\n<\/tr>\n<\/thead>\n
checkout<\/td>\nKann \u00e4ltere Commits wiederherstellen (oder zu einem anderen Branch wechseln).<\/td>\n<\/tr>\n
revert<\/td>\nTODO<\/td>\n<\/tr>\n
reset<\/td>\nTODO<\/td>\n<\/tr>\n
clean<\/td>\nTODO<\/td>\n<\/tr>\n
commit --amend<\/td>\n\u00c4nderungen dem letzten Commit hinzuf\u00fcgen (nur erlaubt solange noch kein push erfolgt ist!).<\/td>\n<\/tr>\n
rebase<\/td>\nTODO<\/td>\n<\/tr>\n
reflog<\/td>\nTODO<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n

Tipps & Tricks<\/h1>\n

Lokale \u00c4nderungen verwerfen<\/h2>\n

Folgende Befehle verwerfen alle \u00c4nderungen und stellen quasi den Server-Zustand her:<\/p>\n

git reset --hard\ngit clean -df<\/pre>\n

Squash - (Lokale) Commits zusammenf\u00fchren<\/h2>\n

Manchmal ist es praktisch Zwischenst\u00e4nde in kurzen Abst\u00e4nden zu committen, besonders um etwas auszuprobieren. Bl\u00f6d nur wenn jedes \"Mini\"-Commit zum Server geschickt wird. In so einem Fall w\u00fcnscht man sich eine Merge-Funktion der lokalen Commits um einen gro\u00dfen zu erhalten.<\/p>\n

Achtung:<\/strong> Dieser Befehl\u00a0darf nur f\u00fcr\u00a0lokale Commits angewendet werden welche noch nicht zum Server gepusht wurden!<\/p>\n

Folgt noch...<\/pre>\n","protected":false},"excerpt":{"rendered":"

Hier findet\u00a0Ihr die wichtigsten Git-Befehle. Selbst wenn Ihr eine grafische Git-Oberfl\u00e4che verwendet ist es gut zu wissen welche Shell-Befehle es gibt und was diese tun.<\/p>\n","protected":false},"author":5,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[21,25],"tags":[20],"_links":{"self":[{"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/posts\/748"}],"collection":[{"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/users\/5"}],"replies":[{"embeddable":true,"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/comments?post=748"}],"version-history":[{"count":56,"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/posts\/748\/revisions"}],"predecessor-version":[{"id":925,"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/posts\/748\/revisions\/925"}],"wp:attachment":[{"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/media?parent=748"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/categories?post=748"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/blog.rollnut.com\/wp-json\/wp\/v2\/tags?post=748"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}