|
Dimensione: 5264
Commento: +revisione; +correzioni; +24.04
|
Dimensione: 8131
Commento:
|
| Le cancellazioni sono segnalate in questo modo. | Le aggiunte sono segnalate in questo modo. |
| Linea 8: | Linea 8: |
| '''Git''' è un sistema di controllo di versione distribuito ('''DVCS''' - '''D'''istributed '''V'''ersion '''C'''ontrol '''S'''ystem). Gli aspetti principali di un sistema di controllo versione riguardano: | '''Git''' è un sistema di controllo di versione distribuito ('''DVCS''' - '''D'''istributed '''V'''ersion '''C'''ontrol '''S'''ystem) utilizzabile da [[AmministrazioneSistema/Terminale|riga di comando]]. Gli aspetti principali di un sistema di controllo versione riguardano: |
| Linea 21: | Linea 21: |
| [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] '''Git''' è necessario: | Sebbene l'uso del [[AmministrazioneSistema/Terminale|terminale]] sia il metodo più diretto e completo |
| Linea 23: | Linea 23: |
| Digitare in un [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{ | [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] '''Git''', digitare in un [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{ |
| Linea 26: | Linea 26: |
== Interfacce grafiche (GUI) == '''Git''' include due strumenti storici basati su Tcl/Tk. Sono essenziali ma molto leggeri e funzionali, per agevolare la visualizzazione dei branch e la gestione dei commit: === Gitk/Git-gui === [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] i pacchetti [[apt://git-gui|git-gui]] e [[apt://gitk|gitk]]. Si avviano dal terminale all'interno della cartella del progetto, digitando nel [[AmministrazioneSistema/Terminale|terminale]] i comandi: * Specializzato nella visualizzazione della cronologia e dei branch:{{{ gitk }}} * Focalizzato sulla creazione dei commit, la gestione dell'area di staging e le operazioni di merge semplici:{{{ git-gui }}} === Gitg (ottimizzato per GNOME) === '''Gitg''': È l'interfaccia grafica predefinita per l'ambiente desktop [[AmbienteGrafico/Gnome|GNOME]]. Offre una visualizzazione moderna e pulita dei commit e permette di gestire le operazioni comuni. [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] il pacchetto [[apt://gitg|gitg]]. === Integrazione in VS Code === Se si utilizza '''[[Ufficio/EditorDiTesto/VisualStudioCode#Git_in_Visual_Studio_Code|Visual Studio Code]]''' per programmare, '''Git''' è integrato nativamente. ##=== GitKraken / SmartGit (Proprietari/Avanzati) === ##Esistono client molto potenti e professionali, spesso usati in ambito aziendale: ## * '''!GitKraken''': Esteticamente molto curato, disponibile come pacchetto .deb o tramite Snap. È gratuito per repository pubblici. ## * '''!SmartGit''': Molto completo, gratuito per uso non commerciale. |
|
| Linea 32: | Linea 65: |
| == Definizione utente == | == Identificazione utente nei progetti == |
| Linea 34: | Linea 67: |
| Impostare il '''nome utente''' e l''''indirizzo e-mail''' da utilizzare per l'identificazione nei progetti:{{{ | Impostare il '''nome utente''' e l''''indirizzo e-mail''' da utilizzare globalmente per l'identificazione nei progetti Git, digitare nel [[AmministrazioneSistema/Terminale|terminale]] questi comandi:{{{ |
| Linea 37: | Linea 70: |
| }}} sostituendo le diciture NOME_UTENTE e INDIRIZZO_E-MAIL con i dati corretti. In questa guida viene preso come esempio l'utente '''Mario Rossi''' con indirizzo email '''`mario.rossi@mail.com`'''; in questo caso i comandi diventano:{{{ | }}}sostituendo le diciture `NOME_UTENTE` e `INDIRIZZO_E-MAIL` con i propri dati. Esempio per l'utente '''Mario Rossi''':{{{ |
| Linea 41: | Linea 74: |
| Linea 42: | Linea 76: |
| È possibile modificare questi dati per un singolo repository omettendo l'opzione '''--global.''' | Le configurazioni globali vengono salvate nel file nascosto `.gitconfig` nella propria directory '''Home'''. Per impostare dati specifici solo per un determinato repository, è sufficiente omettere l'opzione '''--global''' mentre ci si trova all'interno della cartella del progetto. |
| Linea 44: | Linea 78: |
== Impostazione dell'alias lg == Il monitoraggio dell'evoluzione del progetto avviene tramite la consultazione dello storico dei commit. Il comando principale è `git log`, tuttavia, per facilitare la lettura dei rami e delle modifiche, è prassi comune impostare un alias che fornisca una rappresentazione grafica e sintetica. |
|
| Linea 49: | Linea 87: |
| <<Anchor(cronologia)>> = Visualizzazione della cronologia = 0. [[#Configurazione_base|Configurare l'alias]] '''lg'''. 0. Una volta impostato, sarà possibile visualizzare l'andamento del repository digitando:{{{ git lg }}} |
|
| Linea 52: | Linea 98: |
| == Creazione di un nuovo repository == |
|
| Linea 54: | Linea 102: |
| <<Anchor(creare)>> | |
| Linea 64: | Linea 113: |
| }}} Verrà restituito un messaggio simile al seguente:{{{ | }}}Verrà creata la cartella nascosta `.git` contenente l'intera cronologia e i dati di controllo e restituito un messaggio simile al seguente:{{{ |
| Linea 66: | Linea 115: |
| }}} All'interno di `~/gitproject` sarà presente la cartella nascosta `.git` contenente tutte le informazioni del repository. Questa cartella è fondamentale poiché contiene l'intera cronologia e i dati di controllo. | }}} {{{#!wiki note Si ricorda che tutte le operazioni di gestione del repository (commit, visualizzazione cronologia, gestione branch, ecc.) devono essere eseguite posizionandosi all'interno della directory del progetto (ad esempio tramite il comando `cd ~/gitproject`). In questo modo Git può accedere alla sottocartella nascosta `.git` necessaria per il corretto funzionamento dei comandi. }}} |
| Linea 73: | Linea 126: |
Guida verificata con Ubuntu: 22.04 24.04
Problemi in questa pagina? Segnalali in questa discussione
Introduzione
Git è un sistema di controllo di versione distribuito (DVCS - Distributed Version Control System) utilizzabile da riga di comando. Gli aspetti principali di un sistema di controllo versione riguardano:
- tracciare la storia di un progetto e poter lavorare con le versioni precedenti;
- permettere la collaborazione di più persone allo stesso progetto;
- organizzare e semplificare l'andamento del progetto.
A differenza di programmi come CVS o Subversion, e in modo simile a Mercurial o Baazar, Git è caratterizzato da una gestione localizzata, ovvero è utilizzabile con repository locali invece che esclusivamente remoti. Sistemi come Subversion adottano un repository centrale (server o servizio web) in cui risiede il progetto. In tali sistemi, la sincronizzazione del lavoro e il salvataggio delle modifiche (commit) avvengono direttamente sul repository centralizzato.
Git lavora invece in locale. Ogni directory di lavoro è un repository autosufficiente. Operazioni come commit, consultazione dei log e molte altre azioni vengono eseguite localmente, senza necessità di un server esterno. La sincronizzazione con altri repository (server centrale, altri PC in rete, ecc.) avviene solo quando necessario. Ciò garantisce maggiore flessibilità e velocità d'esecuzione.
Installazione
Sebbene l'uso del terminale sia il metodo più diretto e completo
Installare Git, digitare in un terminale il seguente comando:
sudo apt install git
Interfacce grafiche (GUI)
Git include due strumenti storici basati su Tcl/Tk. Sono essenziali ma molto leggeri e funzionali, per agevolare la visualizzazione dei branch e la gestione dei commit:
Gitk/Git-gui
Installare i pacchetti git-gui e gitk.
Si avviano dal terminale all'interno della cartella del progetto, digitando nel terminale i comandi:
Specializzato nella visualizzazione della cronologia e dei branch:
gitk
Focalizzato sulla creazione dei commit, la gestione dell'area di staging e le operazioni di merge semplici:
git-gui
Gitg (ottimizzato per GNOME)
Gitg: È l'interfaccia grafica predefinita per l'ambiente desktop GNOME. Offre una visualizzazione moderna e pulita dei commit e permette di gestire le operazioni comuni.
Installare il pacchetto gitg.
Integrazione in VS Code
Se si utilizza Visual Studio Code per programmare, Git è integrato nativamente.
Configurazione base
Dopo l'installazione è necessario definire l'identità dell'utente per firmare correttamente i commit.
Identificazione utente nei progetti
Impostare il nome utente e l'indirizzo e-mail da utilizzare globalmente per l'identificazione nei progetti Git, digitare nel terminale questi comandi:
git config --global user.name "NOME_UTENTE" git config --global user.email INDIRIZZO_E-MAIL
sostituendo le diciture NOME_UTENTE e INDIRIZZO_E-MAIL con i propri dati. Esempio per l'utente Mario Rossi:
git config --global user.name "Mario Rossi" git config --global user.email mario.rossi@mail.com
Le configurazioni globali vengono salvate nel file nascosto .gitconfig nella propria directory Home. Per impostare dati specifici solo per un determinato repository, è sufficiente omettere l'opzione --global mentre ci si trova all'interno della cartella del progetto.
Impostazione dell'alias lg
Il monitoraggio dell'evoluzione del progetto avviene tramite la consultazione dello storico dei commit. Il comando principale è git log, tuttavia, per facilitare la lettura dei rami e delle modifiche, è prassi comune impostare un alias che fornisca una rappresentazione grafica e sintetica.
È consigliato impostare l'alias lg per una versione personalizzata del comando log, al fine di migliorarne la leggibilità:
git config --global alias.lg "log --pretty=format:'%C(yellow)%h%Cred%d%Creset - %C(cyan)%an %Creset: %s %Cgreen(%cr)' --decorate --graph --all --abbrev-commit"
Visualizzazione della cronologia
Una volta impostato, sarà possibile visualizzare l'andamento del repository digitando:
git lg
Creazione repository
Creazione di un nuovo repository
Per creare un nuovo progetto o per importare (clonare) un progetto esistente, vengono descritte di seguito le procedure.
Creazione nuovo repository
Creare la directory gitproject nella propria cartella Home, digitare nel terminale i seguenti comandi:
mkdir ~/gitproject
Spostarsi all'interno della cartella creata:
cd ~/gitproject
Per inizializzare un repository vuoto, digitare:
git init
Verrà creata la cartella nascosta .git contenente l'intera cronologia e i dati di controllo e restituito un messaggio simile al seguente:
Inizializzato un repository Git in /home/mario/gitproject/.git/
Si ricorda che tutte le operazioni di gestione del repository (commit, visualizzazione cronologia, gestione branch, ecc.) devono essere eseguite posizionandosi all'interno della directory del progetto (ad esempio tramite il comando cd ~/gitproject). In questo modo Git può accedere alla sottocartella nascosta .git necessaria per il corretto funzionamento dei comandi.
Clonazione repository
Per scaricare un progetto già esistente su di un server, il comando da eseguire è:
git clone PERCORSO/PROGETTO
Verrà creata nella propria Home una cartella col nome del progetto in cui saranno copiati i contenuti.
Se invece si preferisce clonare il repository in una cartella specifica, basta aggiungere il percorso al comando:
git clone PERCORSO/PROGETTO PERCORSO/LOCALE
Commit
Attraverso il commit è possibile aggiungere, rimuovere e modificare i file del repository. Consultare la seguente pagina.
Branching
Git permette una gestione avanzata dei branch (rami di sviluppo). Consultare la seguente pagina.
Repository remoti
Tramite gli strumenti fetch, pull e push è possibile sincronizzare il lavoro tra diversi utenti. Consultare la seguente pagina.
