Das ist eine alte Version von Git/Starter vom 08.04.2023 08:17 bearbeitet durch WikiAdmin.

Quelltext der Seite Starter

Statt zip-Dateien von WackoWiki herunterzuladen, möchtest du beginnen, daran zu arbeiten, WackoWiki zu deinem Wiki zu machen? Du möchtest leicht jederzeit neueste Änderungen der Entwickler lokal auf Deinem Rechner finden? Du möchtest mit dem auf dieser Seite dargestellen Wissen systematisch selbst an Verbesserungen zur Schaffung deiner eigenen, individuell angepassten WikiSoftware arbeiten? So starte hier:

**Nachfolgend lernst Du:**

{{toc nomark=1}}


=== Git installieren====

Bevor du mit Git loslegen kannst, muss es natürlich zuerst installiert werden. Auch wenn es bereits vorhanden ist, ist es vermutlich eine gute Idee, auf die neueste Version zu aktualisieren.

Installiere Git[[^ Git-Download https://git-scm.com/downloads]], z.B. mit OpenSUSE per Konsole [Strg]+[Alt]+[T] 
%%(cl) sudo zypper install git%%

Prüfe, welche Version von Git installiert wurde
%%(cl) git --version%%

=== Ein Projektverzeichnis anlegen====

Bevor Du ein Git-Repository auf Deinem Rechner erstellst, musst Du einen Ordner anlegen bzw. einen Speicherort dafür festlegen. Ein Ordner mit dem Namen "Projekt" im Homeverzeichnis ##/home/⟨username⟩/Projekt## hat sich als übergeordneter Aufbewahrungsort in der Praxis bewährt.


Erstelle einen Projektordner für verschiedene Git-Repositorys per Konsole in (?deinem (username) anzeigen per Konsole: whoami ?) Homeverzeichnis:

%%(cl) mkdir /home/⟨username⟩/Projekt%%

Eine Möglichkeit vielzählige Git-Repositorys strukturiert lokal zu speichern ist, innerhalb deines Projektordners neue Ordner jeweils für verschiedene, ursprünglich entfernte Speicherorte zu erstellen und jene nach diesen zu benennen. Entfernte Speicherorte der Projektdateien von WackoWiki inkl. derselben Versionsgeschichte sind etwa auf den Webseiten von Sourceforge, BitBucket und Github zu finden. Um darüber hinaus entfernte Git-Repositorys verschiedener Nutzer z.B. von BitBucket auf deinen Rechner zu holen:

Erstelle den Ordner BitBucket in Deinem Projektordner
%%(cl) mkdir /home/⟨username⟩/Projekt/BitBucket%%

Erstelle den Ordner WackoWiki nach der Namenskonvention: //home/⟨username⟩/Projekt/Name_für_entfernte-Git-Hosting-Plattform/Plattform-NutzerName//.

Für eine lokale Kopie des Git-Repositorys des BitBucket-Nutzer WackoWiki nutze:
%%(cl) mkdir /home/⟨username⟩/Projekt/BitBucket/WackoWiki%%


=== Das aktuellste Entwickler Git-Repository in Dein Projektverzeichnis initial holen==

Um nachfolgend eine lokale Kopie aller zum jetzigen Zeitpunkt vorhandenen Projektdateien inkl. der Versionsgeschichte des Nutzers WackoWiki der Git-Hosting Plattform BitBucket strukturiert auf deinem Linux Rechner zu speichern:

Wechsele in dein bereits erstelltes Projektverzeichnis: 
%%(cl) cd /home/⟨username⟩/Projekt/BitBucket/WackoWiki%%

In dem ausgewählten Ordner führe folgende Git-Anweisung aus:
%%(cl) git clone https://bitbucket.org/wackowiki/wackowiki.git%%

Das ausgewählte entfernte Git-Repository des Nutzers WackoWiki auf der Webseite bitbucket.org inkl. der Projektdateien wurde auf deinen Rechner in das Verzeichnis geholt, in dem du dich momentan befindest und dort im - mit git clone erstellten - Ordner /wackowiki gespeichert. Überprüfe das Ergebnis per Konsole mit:
%%(cl) ls -a%%

file:/Git/Starter/git-lokales-repository-angelegt.png

Ohne das .git Verzeichnis fehlen Deinem Arbeitsverzeichnis Git-Repository-Informationen. Du kannst die Repository-Informationen jederzeit löschen und das jeweilige Arbeitsverzeichnis jederzeit wieder in einen Speicherort ohne Git-Funktionalität umwandeln. 

Ein Verzeichnis inkl. Repository-Informationen insgesamt zu löschen ist jedoch für den Start günstiger, da es mit der git clone Anweisung so leicht ist, das jeweils gewünschte entfernte Git-Repository erneut auf Deinen Rechner zu bringen.


=== Jeweils neueste Entwicklungen in dein bestehendes lokales WackoWiki Repository holen==

Nachdem du das WackoWiki Entwicklerrepository in Dein Projektverzeichnis initial mit der Anweisung ##git clone https://bitbucket.org/wackowiki/wackowiki.git## geholt hast, kannst du __in dem jeweiligen Arbeitsverzeichnis__ jederzeit den neuesten Entwicklungsstand wie folgt von der in der .git/config Datei gespeicherten Zugangsadresse im lokalen WackoWiki-Repository aktualisieren:

%%(cl) git fetch origin master%%
%%(cl) git checkout%%

Wenn Du selbst in dem o.g. lokalen WackoWiki-Repository keine Änderungen vorgenommen hast, ist folgende Anweisung problemlos möglich.

%%(cl) git pull origin master%%



=== "git clone" Anweisung für Fortgeschrittene und Schnelllerner==
==== WackoWiki Entwickler Repository auf deinen Rechner bringen==
%%(info type="note" title="tl;dr")
__Einmalig, initial:__
##git clone <git_repo_url> <von_dir_bestimmter_verzeichnisname>##

__Zum Herunterladen der neuesten Änderungen:__
im von Dir bestimmten Verzeichnis: git pull oder
##git -C <von_dir_bestimmter_verzeichnisname> pull##
%%

Damit du WackoWiki von einem entfernten Git-Repository auf Deinen Rechner holen kannst, benötigst du eine Adresse, von welcher du jene Projektdateien inkl. der Versionsgeschichte auf deinem Rechner speicherst. Zudem kannst du mit der Anweisung 
%%(code)git clone <git_repo_url> <von_dir_bestimmter_verzeichnisname>%% den lokalen Speicherort dafür bestimmen.

Folgende Anweisung klont das - ohne Zugangsbeschränkungen verfügbare - WackoWiki Git-Repository der Webseite bitbucket.org %%(code) z.B. https://bitbucket.org/wackowiki/wackowiki.git%% per https, und nicht etwa per ssh, mit den neuesten Änderungen der Entwickler in den noch nicht erstellten bzw. leeren Ordner %%(code) z.B. ~/Projekt/BitBucket/WackoWiki/wackowiki%% im Homeverzeichnis deines Rechners.

%%(cl) git clone https://bitbucket.org/wackowiki/wackowiki.git \
/home/⟨username⟩/Projekt/BitBucket/WackoWiki/wackowiki %%

%%(cl) git -C /home/⟨username⟩/Projekt/BitBucket/WackoWiki/wackowiki  pull%%

%%(info type="default" title="Übung | Training und Reflexion")
Erstelle mit der Konsole in Deinem Projektverzeichnis weitere Ordner für entfernte Git-Repositories und deren Nutzer.
Was bewirkt der Punkt am Ende der Anweisung ##git clone ~https://bitbucket.org/wackowiki/wackowiki.git .##? 
Auf einem Linux System findest Du Hilfe zur Arbeit mit git über den Kommandozeilenbefehl ##git --help## . Detaillierte Informationen zum klonen findest du mit der Anweisung: ##git clone --help## %%

==== Zweigeweise Klonen ==

**ToDo**
  * Nur einen Branch clonen
  git clone --branch <branchname> <remote-repo-url>

  %%(cl) git clone --branch 5.0 https://bitbucket.org/wackowiki/wackowiki.git \
/home/⟨username⟩/Projekt/BitBucket/WackoWiki/5.0%%
  * komprimiertere Information wie z.B. https://www.dokuwiki.org/devel:git