File: version-control.page

package info (click to toggle)
gnome-devel-docs 40.3-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 79,188 kB
  • sloc: javascript: 2,514; xml: 2,407; ansic: 2,229; python: 1,854; makefile: 805; sh: 499; cpp: 131
file content (118 lines) | stat: -rw-r--r-- 7,333 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<?xml version="1.0" encoding="utf-8"?>
<page xmlns="http://projectmallard.org/1.0/" xmlns:its="http://www.w3.org/2005/11/its" type="topic" id="version-control" xml:lang="de">

  <info>
    <link type="guide" xref="index#general-guidelines"/>

    <credit type="author copyright">
      <name>Philip Withnall</name>
      <email its:translate="no">philip.withnall@collabora.co.uk</email>
      <years>2015</years>
    </credit>

    <include xmlns="http://www.w3.org/2001/XInclude" href="cc-by-sa-3-0.xml"/>

    <desc>Quellcode-Versionsverwaltung mit Git</desc>
  
    <mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
      <mal:name>Mario Blättermann</mal:name>
      <mal:email>mario.blaettermann@gmail.com</mal:email>
      <mal:years>2016, 2018</mal:years>
    </mal:credit>
  
    <mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
      <mal:name>Christian Kirbach</mal:name>
      <mal:email>christian.kirbach@gmail.com</mal:email>
      <mal:years>2016, 2020</mal:years>
    </mal:credit>
  
    <mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
      <mal:name>Stefan Melmuk</mal:name>
      <mal:email>stefan.melmuk@gmail.com</mal:email>
      <mal:years>2018</mal:years>
    </mal:credit>
  
    <mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
      <mal:name>Tim Sabsch</mal:name>
      <mal:email>tim@sabsch.com</mal:email>
      <mal:years>2021</mal:years>
    </mal:credit>
  </info>

  <title>Versionsverwaltung</title>

  <synopsis>
    <title>Zusammenfassung</title>

    <p>Git ist das Versionskontrollsystem aller GNOME-Projekte. Auf dieser Seite nehmen wir an, dass Sie bereits gute praktische Erfahrungen mit git besitzen. Einführungsmaterialien finden Sie <link href="https://www.atlassian.com/git/tutorials/">hier</link>, ein Cheatsheet finden Sie außerdem <link href="https://training.github.com/kit/downloads/github-git-cheat-sheet.pdf">hier</link>.</p>

    <list>
      <item><p>Erstellen Sie atomare, reversible Commits. (<link xref="#guidelines-for-making-commits"/>)</p></item>
      <item><p>Nehmen Sie alle Hintergründe in die Commit-Nachrichten auf, einschließlich Verweise auf Fehlerberichte und Spezifikationen. (<link xref="#guidelines-for-making-commits"/>)</p></item>
      <item><p>Stecken Sie große Änderungen wie Umbenennungen in separate Commits. (<link xref="#guidelines-for-making-commits"/>)</p></item>
      <item><p>Führen Sie Änderungen aus Feature-Branchen durch Rebasen zusammen. (<link xref="#use-of-git"/>)</p></item>
    </list>
  </synopsis>

  <section id="use-of-git">
    <title>Verwendung von Git</title>

    <p>Die meisten GNOME-Repositories folgen diesen Regeln:</p>
    <list>
      <item><p>Keine erzwungenen Pushes. Mit Ausnahme von Branches mit dem <code>wip/</code>-Präfix (»Work in Progress«) darf der Commit-Verlauf nicht geändert werden, da sich Mitwirkende darauf verlassen.</p></item>
      <item><p>Rebasen Sie Commits eher als Mergen, um die History linear zu halten (welcher einfacher zu folgen ist)</p></item>
      <item><p>Arbeiten Sie im GNOME-git mit Feature-Branches (<code>wip/</code>-Präfix), rebasen Sie anschließend auf dem master-Branch und führen Sie die Änderungen mit einem fast-forward-Merge zusammen. Es hat sich ebenfalls bewährt, dass Sie Ihren Nutzernamen in der Form <code>wip/nickname/feature</code> zum Branch hinzufügen.</p></item>
      <item><p>Verstecken Sie Ihre <link href="https://sethrobertson.github.io/GitBestPractices/#sausage">Wurstherstellung</link>, indem Sie Commits vor dem Merge zusammenlegen (»squash«).</p></item>
    </list>
  </section>

  <section id="guidelines-for-making-commits">
    <title>Richtlinien für Commits</title>

    <p>Commits sollten so klein wie möglich sein, aber nicht kleiner. Jeder Commit sollte ein einzelnes Problem adressieren und nur dazu unmittelbar relevante Änderungen enthalten. Die Commit-Nachricht sollte das Problem beschreiben, die Ursache erklären sowie die Lösung aufzeigen, sofern diese nicht offensichtlich ist. Bezieht sich der Commit auf einen Fehlerbericht, sollte in der letzten Zeile der Commit-Nachricht die vollständige URI des Berichts stehen. Ebenso sollte die Commit-Kennung (zu erhalten mittels <cmd>git log --oneline</cmd>) in den Fehlerbericht kopiert werden, sobald der Commit hochgeladen wurde.</p>

    <p>Die Änderungen in jedem Commit sollten einfach zu lesen sein. Zum Beispiel sollten keine unnötigen Änderungen an den Leerzeichen oder Einrückungen enthalten sein. Große, mechanische Änderungen wie das Umbenennen einer Datei oder Funktion sollten in einem eigenen Commit separat von inhaltlichen Änderungen am Code in der Datei oder Funktion stattfinden, damit letztere nicht verloren gehen.</p>

    <p>Die folgenden Prinzipien erklären die soeben aufgezeigten Ratschläge:</p>
    <list>
      <item><p>Jeder Commit überträgt das Repository von einem funktionierenden Zustand in einen anderen. Anderenfalls ist <link href="http://git-scm.com/book/en/v2/Git-Tools-Debugging-with-Git#Binary-Search">Bisection</link> unmöglich.</p></item>
      <item><p>Jeder Commit sollte in sich reversibel sein. Sollte sich später herausstellen, dass der Commit keine gute Idee war, sollte ein <cmd>git revert <var>commit ID</var></cmd> das Repository von einem funktionierenden Zustand in einen anderen übertragen.</p></item>
      <item><p>Die Hintergründe jedes Commits und seine Beziehungen zu externen Ressourcen wie Spezifikationen und Fehlerberichten sollten klar sein. Ein Entwickler sollte noch ein Jahr später in der Lage sein zu verstehen, was ein anderer Entwickler gemacht hat, ohne sich durch alle Änderungen wühlen zu müssen.</p></item>
      <item><p>Jeder Commit sollte einmalig geschrieben und dann vielfach gelesen werden können, von vielen Reviewern und künftigen Entwicklern.</p></item>
    </list>
  </section>

  <section id="merging-procedure">
    <title>Merge-Prozess</title>

    <p>Um einen Feature-Branch namens <code>my-branch</code> in den master-Branch zu mergen, verwenden Sie die folgenden Befehle:</p>
    <code mime="application/x-shellscript">
git checkout master
git pull

git checkout wip/<var>my-branch</var>
git rebase --interactive master
# Ensure the rebase is successful; test the changes

git checkout master
git merge wip/<var>my-branch</var>
git push

# wip/<var>my-branch</var> can now be deleted
git push origin :wip/<var>my-branch</var>
git branch -D wip/<var>my-branch</var></code>
  </section>

  <section id="external-links">
    <title>Externe Links</title>

    <list>
      <item><p><link href="https://sethrobertson.github.io/GitBestPractices/">Git best practices</link></p></item>
      <item><p><link href="https://help.github.com/categories/using-git/">Git FAQ</link></p></item>
      <item><p><link href="https://www.atlassian.com/git/tutorials/">Atlassian git tutorial</link></p></item>
      <item><p><link href="http://git-scm.com/docs/gittutorial">Offizielles Git-Tutorial</link></p></item>
      <item><p><link href="https://try.github.io/">Interaktives Git-Tutorial</link></p></item>
      <item><p><link href="http://www.git-tower.com/learn/">Tutorial zu git-tower</link></p></item>
    </list>
  </section>
</page>