|
Dimensione: 4985
Commento:
|
Dimensione: 8778
Commento: +correzioni
|
| Le cancellazioni sono segnalate in questo modo. | Le aggiunte sono segnalate in questo modo. |
| Linea 4: | Linea 4: |
| <<Informazioni(forum="http://forum.ubuntu-it.org/viewtopic.php?f=46&t=590616"; rilasci="14.04")>> | <<Informazioni(forum="http://forum.ubuntu-it.org/viewtopic.php?f=46&t=590616"; rilasci="24.04 22.04")>> |
| Linea 8: | Linea 8: |
| '''Git''' è un [[http://it.wikipedia.org/wiki/Controllo_versione|CVS]] ('''C'''ontrol '''V'''ersion '''S'''ystem). Gli aspetti importanti di un CSV si possono riassumere nel: | '''Git''' è un sistema di controllo di versione distribuito ('''[[https://it.wikipedia.org/wiki/Controllo_versione_distribuito|DVCS]]''' - '''D'''istributed '''V'''ersion '''C'''ontrol '''S'''ystem) utilizzabile da [[AmministrazioneSistema/Terminale|riga di comando]]. Gli aspetti principali riguardano: |
| Linea 14: | Linea 14: |
| Rispetto a programmi come [[Programmazione/Cvs|CVS]], [[Programmazione/Subversion|Subversion]] ma più similmente a [[http://mercurial.selenic.com|Mercurial]], [[Programmazione/Bazaar|Baazar]], '''Git''' è caratterizzato da un sistema di controllo di versione localizzato, cioè utilizzabile con repository locali invece che remoti. Programmi come '''Subversion''' adottano un repository centrale, che materialmente è il posto (server, servizio web) in cui risiede il progetto. Gli utenti sincronizzano il lavoro con questo repository e quando devono salvare delle modifiche al progetto (''commit''), le salvano direttamente sul repository centralizzato. | A differenza di programmi come [[Programmazione/Cvs|CVS]] o [[Programmazione/Subversion|Subversion]], e in modo simile a [[http://mercurial.selenic.com|Mercurial]] o [[Programmazione/Bazaar|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. |
| Linea 16: | Linea 16: |
| '''Git''' invece lavora in locale. Non esiste un repository centralizzato nel modo che si intende in '''Subversion''' et similia. Ogni cartella di lavoro è un repository autosufficiente. Commit, ricerca log e molte altre azioni vengono eseguite in locale, senza l'appoggio di un server esterno. Quando si rende necessario è possibile sincronizzarsi con altri repository (server centrale, pc in rete, ecc..). Questo comporta ovvi vantaggi in termini di flessibilità. | 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. {{{#!wiki note Se si utilizza '''[[Ufficio/EditorDiTesto/VisualStudioCode#Git_in_Visual_Studio_Code|Visual Studio Code]]''' per programmare, '''Git''' è integrato nativamente. }}} |
| Linea 19: | Linea 23: |
| = Installazione/Configurazione base = | = Installazione = |
| Linea 21: | Linea 25: |
| 0. Per installare '''Git''' digitare in un [[AmministrazioneSistema/RigaDiComando|terminale]]:{{{ sudo apt-get install git |
Sebbene l'uso del [[AmministrazioneSistema/Terminale|terminale]] sia il metodo più diretto e completo [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] '''Git''', digitare in un [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{ sudo apt install git |
| Linea 24: | Linea 30: |
| 0. Impostare '''nome utente''' e '''indirizzo e-mail''' che si vogliono utilizzare per identificarsi nei progetti:{{{ | == Interfaccia grafica == '''Git''' include due strumenti storici ad interfaccia grafica basati su Tcl/Tk. Sono essenziali ma molto leggeri e funzionali, per agevolare la visualizzazione dei branch e la gestione dei commit: [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] i pacchetti: * '''[[apt://gitk|gitk]]''': Specializzato nella visualizzazione della cronologia e dei branch. * '''[[apt://git-gui|git-gui]]''': Focalizzato sulla creazione dei commit, la gestione dell'area di staging e le operazioni di merge semplici. Essendo leggeri e funzionali '''gitk''' e '''git-gui''' richiedono l'avvio dal [[AmministrazioneSistema/Terminale|terminale]] all'interno della cartella del progetto, digitando i comandi:{{{ gitk }}} o {{{ git-gui }}} === Ottimizzazione in GNOME === Per l'ambiente desktop [[AmbienteGrafico/Gnome|GNOME]] '''Gitg''' offre una visualizzazione moderna e pulita dei [[Programmazione/Git/Commit|commit]] e permette di gestire le operazioni comuni. [[AmministrazioneSistema/InstallareProgrammi/Apt|Installare]] il pacchetto [[apt://gitg|gitg]]. ##=== 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. <<Anchor(configurazione)>> = 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 [[AmministrazioneSistema/Terminale|terminale]] questi comandi:{{{ |
| Linea 27: | Linea 69: |
| }}}avendo cura di soistituire le diciture NOME_UTENTE e INDIRIZZO_E-MAIL col proprio nome utente e indirizzo e-mail. ||<tablestyle="text-align: justify; width:100%;" style="border:none;" 5%><<Immagine(Icone/Piccole/note.png,,center)>> ||<style="padding:0.5em; border:none;">''È possibile modificare questi dati per un singolo repository omettendo il flag '''--global.''''' || 0. Consigliato ma non obbligatorio, impostare l'alias '''lg''' per una versione personalizzata del comando '''log''' al fine di migliorarne la leggibilità:{{{ |
}}}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 }}} {{{#!wiki note 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 alias lg == Il monitoraggio dell'evoluzione del progetto avviene tramite la consultazione dello storico dei [[Programmazione/Git/Commit|commit]]. '''Git''' fornisce il comando nativo `git log`, tuttavia, per facilitare la lettura dei rami e delle modifiche, è prassi comune impostare un alias '''lg''' che fornisca una rappresentazione grafica, colorata e sintetica, al fine di migliorarne la leggibilità dei rami. {{{#!wiki important Operazione da eseguire una sola volta. }}} Digitare nel [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{ |
| Linea 33: | Linea 90: |
| <<Anchor(cronologia)>> == Visualizzazione della cronologia == Per visualizzare la cronologia, l'andamento dei rami in qualsiasi repository del sistema una sola volta [[#Impostazione_alias_lg|configurato l'alias]] '''lg''', digitare nel [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{ git lg }}} Altrimenti per visualizzare la cronologia testuale semplice, digitare nel [[AmministrazioneSistema/Terminale|terminale]] il comando:{{{ git log }}} <<Anchor(creare)>> |
|
| Linea 35: | Linea 104: |
| Viene qui mostrato come creare un '''nuovo progetto''' o come importare (clonare) un '''progetto esistente'''. | Per creare un '''nuovo progetto''' o per importare (clonare) un '''progetto esistente''', vengono descritte di seguito le procedure. |
| Linea 37: | Linea 106: |
| == Creazione nuovo repository == | 0. [[AmministrazioneSistema/ComandiBase#mkdir|Creare]] la directory `gitproject` nella propria cartella '''Home''', digitare nel [[AmministrazioneSistema/Terminale|terminale]] i seguenti comandi:{{{ mkdir ~/gitproject }}} 0. [[AmministrazioneSistema/ComandiBase#cd|Spostarsi]] all'interno della cartella creata:{{{ cd ~/gitproject }}} 0. 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/ }}} |
| Linea 39: | Linea 118: |
| <<Anchor(creare)>> 0. Creare la cartella `gitproject` nella propria '''Home''' che conterrà il progetto e spostarsi al suo interno:{{{ mkdir ~/gitproject cd ~/gitproject |
{{{#!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 44: | Linea 121: |
| 0. Per inizializzare un repository vuoto su cui poter incominciare a lavorare, digitare:{{{ git init }}}verrà restituito un messaggio del tipo{{{ Inizializzato un repository Git in /home/USER_NAME/gitproject/.git/ }}}All'interno di `~/gitproject` sarà ora presente la cartella `.git` che contiene le informazioni del repository. Questa cartella è molto importante perché è l'unica che contiene tutti i dati necessari. (In '''Subversion''' ad es. viene creata una cartella .svn in ogni sottocartella del progetto). |
|
| Linea 50: | Linea 122: |
| == Clonazione repository == | <<Anchor(clonare)>> = Clonazione repository = |
| Linea 53: | Linea 126: |
| git clone PERCORSO/PROGETTO }}}Verrà creata nella propria '''Home''' una cartella col nome del progetto in cui saranno copiati i contenuti. |
git clone PERCORSO/PROGETTO }}}Verrà creata nella propria '''Home''' una cartella col nome del progetto in cui saranno copiati i contenuti. |
| Linea 57: | Linea 129: |
| git clone PERCORSO/PROGETTO PERCORSO/LOCALE }}} |
git clone PERCORSO/PROGETTO PERCORSO/LOCALE }}} |
| Linea 66: | Linea 138: |
| '''Git''' prevede una gestione molto efficace dei '''branch''' (rami di sviluppo). Consultare la [[Programmazione/Git/Branch|seguente pagina]]. | '''Git''' permette una gestione avanzata dei '''branch''' (rami di sviluppo). Consultare la [[Programmazione/Git/Branch|seguente pagina]]. |
| Linea 70: | Linea 142: |
| Attraverso gli strumenti '''fetch''', '''merge''', '''pull''', '''push''' è possibile sincronizzare il lavoro svolto da utenti diversi utenti. Consultare la [[Programmazione/Git/RepositoryRemoti|seguente pagina]]. | Tramite gli strumenti '''fetch''', '''pull''' e '''push''' è possibile sincronizzare il lavoro tra diversi utenti. Consultare la [[Programmazione/Git/RepositoryRemoti|seguente pagina]]. = Risoluzioni problemi = == 'lg' is not a git command == Se si prova a digitare `git lg`, '''Git''' restituisce il seguente errore:{{{ git: 'lg' is not a git command. See 'git --help' }}} Il comando `git lg` non esiste nativamente in '''Git''' funziona solo se è stato creato l'[[#Impostazione_alias_lg|alias corrispondente]]. |
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 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.
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.
Se si utilizza Visual Studio Code per programmare, Git è integrato nativamente.
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
Interfaccia grafica
Git include due strumenti storici ad interfaccia grafica basati su Tcl/Tk. Sono essenziali ma molto leggeri e funzionali, per agevolare la visualizzazione dei branch e la gestione dei commit:
Installare i pacchetti:
gitk: Specializzato nella visualizzazione della cronologia e dei branch.
git-gui: Focalizzato sulla creazione dei commit, la gestione dell'area di staging e le operazioni di merge semplici.
Essendo leggeri e funzionali gitk e git-gui richiedono l'avvio dal terminale all'interno della cartella del progetto, digitando i comandi:
gitk
o
git-gui
Ottimizzazione in GNOME
Per l'ambiente desktop GNOME Gitg offre una visualizzazione moderna e pulita dei commit e permette di gestire le operazioni comuni.
Installare il pacchetto gitg.
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 alias lg
Il monitoraggio dell'evoluzione del progetto avviene tramite la consultazione dello storico dei commit. Git fornisce il comando nativo git log, tuttavia, per facilitare la lettura dei rami e delle modifiche, è prassi comune impostare un alias lg che fornisca una rappresentazione grafica, colorata e sintetica, al fine di migliorarne la leggibilità dei rami.
Operazione da eseguire una sola volta.
Digitare nel terminale il seguente comando:
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
Per visualizzare la cronologia, l'andamento dei rami in qualsiasi repository del sistema una sola volta configurato l'alias lg, digitare nel terminale il seguente comando:
git lg
Altrimenti per visualizzare la cronologia testuale semplice, digitare nel terminale il comando:
git log
Creazione repository
Per creare un nuovo progetto o per importare (clonare) un progetto esistente, vengono descritte di seguito le procedure.
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.
Risoluzioni problemi
'lg' is not a git command
Se si prova a digitare git lg, Git restituisce il seguente errore:
git: 'lg' is not a git command. See 'git --help'
Il comando git lg non esiste nativamente in Git funziona solo se è stato creato l'alias corrispondente.
