doc:appunti:prog:git
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
doc:appunti:prog:git [2022/01/09 11:55] – [Branches] niccolo | doc:appunti:prog:git [2024/02/12 11:07] (current) – [Chiave SSH per Github.com] niccolo | ||
---|---|---|---|
Line 57: | Line 57: | ||
git remote set-url origin git@github.com: | git remote set-url origin git@github.com: | ||
</ | </ | ||
+ | |||
==== git clone ==== | ==== git clone ==== | ||
Line 122: | Line 123: | ||
Dalla propria home page, cliccare sul fork. Controllare che il titolo della pagina sia **%%< | Dalla propria home page, cliccare sul fork. Controllare che il titolo della pagina sia **%%< | ||
- | ===== Misc Commands ===== | ||
- | ==== Revert di un singolo file ==== | + | ===== Gestione dei tag ===== |
+ | |||
+ | Uno dei motivi più comuni per cui creare un **tag** è dare un nome e un numero di versione di una particolare versione del progetto. Quello che viene maracto con un tag diventa **immutabile** e non potrà essere cambiato in futuro. Per contro i **branch** servono a identificare rami diversi dello sviluppo che subiranno eventuali cambiamenti. | ||
+ | |||
+ | Ad esempio per marcare la versione corrente con il nome **print3d-1.0** si esegue: | ||
< | < | ||
- | git log path/ | + | git tag -a print3d-1.0 |
- | git checkout < | + | |
</ | </ | ||
- | ==== Colors ==== | + | se invece della versione corrente si vuole etichettare un commit precedente, bisogna individuare l'hash ed eseguire il comando (notare che l'hash è indicato in forma abbreviata): |
- | Disable GUI colors: | + | < |
+ | git log --pretty=oneline | ||
+ | ... | ||
+ | d7dd3e5c44023bfefc6a6c649506e3e029929b4c Added a 3D printable OpenSCAD model. | ||
+ | ... | ||
+ | git tag -a print3d-1.0 d7dd3e5 | ||
+ | </ | ||
+ | |||
+ | Infine bisogna salvare sul repository remoto (origin) il nuovo tag: | ||
< | < | ||
- | git config | + | git push origin print3d-1.0 |
+ | </ | ||
+ | |||
+ | Se si desidera rimuovere un tag dal repository remoto: | ||
+ | |||
+ | < | ||
+ | git push --delete origin print3d-1.0 | ||
</ | </ | ||
- | ==== Branches | + | ===== Gestionde dei branch ===== |
Mostra i rami di sviluppo, locali e remoti: | Mostra i rami di sviluppo, locali e remoti: | ||
Line 152: | Line 169: | ||
'' | '' | ||
- | Per creare localmente un nuovo branch | + | ==== Creazione di un nuovo branch ==== |
+ | |||
+ | Per creare localmente un nuovo branch | ||
< | < | ||
git branch jessie | git branch jessie | ||
- | git branch -a | ||
</ | </ | ||
- | questo è l' | + | Si può verificare che sia stato creato: |
< | < | ||
+ | git branch -a | ||
jessie | jessie | ||
* master | * master | ||
Line 167: | Line 186: | ||
remotes/ | remotes/ | ||
</ | </ | ||
+ | |||
+ | Si vede che localmente esistono i due branch **jessie** e **master**; il secondo è marcato con un asterisco ed è quindi quello utilizzato per effettuare i commit locali. Quindi aver creato un branch nuovo non significa automaticamente lavorarci sopra. | ||
+ | |||
+ | ==== Selezionare il branch di lavoro locale ==== | ||
+ | |||
+ | Per iniziare a lavorare localmente su un determinato branch si usa il comando **git switch**: | ||
+ | |||
+ | < | ||
+ | git switch jessie | ||
+ | </ | ||
+ | |||
+ | Si verifica che il branch locale predefinito (marcato con un asterisco) sia effettivamente cambiato: | ||
+ | |||
+ | < | ||
+ | git branch -a | ||
+ | * jessie | ||
+ | master | ||
+ | remotes/ | ||
+ | remotes/ | ||
+ | remotes/ | ||
+ | </ | ||
+ | |||
+ | In ogni momento è possibile cambiare branch di lavoro locale, ad esempio tornando su master: | ||
+ | |||
+ | < | ||
+ | git switch master | ||
+ | </ | ||
+ | |||
+ | **ATTENZIONE** Prima di Git 2.23 si utilizzava il comando **git checkout** per cambiare branch di lavoro locale. | ||
+ | |||
+ | ==== Propagare un branch locale anche in remoto ==== | ||
Per propagare il nuovo branch anche sul repository remoto: | Per propagare il nuovo branch anche sul repository remoto: | ||
Line 174: | Line 224: | ||
</ | </ | ||
- | Con il comando **git branch -a** è possibile verificare che localmente si sta lavorando sul branch **jessie** e che sul repository remoto esistono i branch **master** e **jessie**: | + | È possibile verificare che localmente si sta lavorando |
< | < | ||
+ | git branch -a | ||
jessie | jessie | ||
* master | * master | ||
Line 184: | Line 235: | ||
</ | </ | ||
- | Sul repository remoto | + | Avendo fatto lo switch (o il checkout) ad uno specifico |
- | * **[[https:// | + | < |
+ | git status | ||
+ | On branch jessie | ||
+ | Your branch is ahead of ' | ||
+ | (use "git push" to publish your local commits) | ||
+ | </code> | ||
- | ==== Locally Committed Differences | + | ==== Clonare uno specifico branch |
- | Per vedere le differenze tra il master remoto e quello locale (**ATTENZIONE** questo comando non controlla la versione ultima presente sul repository, lavora sui dati salvati localmente!): | + | Quando si clona il repository |
< | < | ||
- | git diff --name-only remotes/origin/master..master | + | git clone --branch jessie https://github.com/ |
</ | </ | ||
- | L' | + | Con **git branch** sarà possibile verificare quale è il branch locale predefinito, |
- | ==== Mostrare l'URL del repository | + | ===== Misc Commands |
+ | |||
+ | ==== Restore o revert di un singolo file ==== | ||
+ | |||
+ | A partire da Git 2.23 esiste il comando **git restore** che consente di ripristinare un file modificato localmente alla sua versione di checkout: | ||
< | < | ||
- | git remote show origin | + | git restore path/ |
</ | </ | ||
- | ===== Creare un tag ===== | ||
- | Uno dei motivi più comuni per cui creare un **tag** è dare un nome e un numero | + | Con versioni precedenti |
- | Ad esempio per marcare la versione corrente con il nome **print3d-1.0** si esegue: | + | < |
+ | git checkout | ||
+ | </ | ||
+ | |||
+ | Se si desidera tornare ad uno specifico commit, si può visualizzare il log degli stessi e richiederlo esplicitamente: | ||
< | < | ||
- | git tag -a print3d-1.0 | + | git log path/ |
+ | git checkout < | ||
</ | </ | ||
- | se invece della versione corrente si vuole etichettare un commit precedente, bisogna individuare l'hash ed eseguire il comando (notare che l'hash è indicato in forma abbreviata): | + | ==== Colors ==== |
+ | |||
+ | Disable GUI colors: | ||
< | < | ||
- | git log --pretty=oneline | + | git config |
- | ... | + | |
- | d7dd3e5c44023bfefc6a6c649506e3e029929b4c Added a 3D printable OpenSCAD model. | + | |
- | ... | + | |
- | git tag -a print3d-1.0 d7dd3e5 | + | |
</ | </ | ||
- | Infine bisogna salvare sul repository | + | ==== Locally Committed Differences ==== |
+ | |||
+ | Per vedere le differenze tra il master | ||
< | < | ||
- | git push origin | + | git diff --name-only remotes/origin/ |
+ | </ | ||
+ | |||
+ | L' | ||
+ | |||
+ | ==== Mostrare l'URL del repository ==== | ||
+ | |||
+ | < | ||
+ | git remote show origin | ||
</ | </ | ||
Line 289: | Line 361: | ||
ssh -T git@github.com | ssh -T git@github.com | ||
Hi RigacciOrg! You've successfully authenticated, | Hi RigacciOrg! You've successfully authenticated, | ||
- | </code< | + | </code> |
Verifichiamo che un repository locale sia stato clonato tramite protocollo HTTPS: | Verifichiamo che un repository locale sia stato clonato tramite protocollo HTTPS: |
doc/appunti/prog/git.1641725720.txt.gz · Last modified: 2022/01/09 11:55 by niccolo