doc:appunti:prog:git
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revisionLast revisionBoth sides next revision | ||
doc:appunti:prog:git [2022/01/09 16:29] – [Branches] niccolo | doc:appunti:prog:git [2022/01/10 09:57] – [Revert di un singolo file] 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 |
</ | </ | ||
- | ==== Branches | + | Se si desidera rimuovere un tag dal repository remoto: |
+ | |||
+ | < | ||
+ | git push --delete origin print3d-1.0 | ||
+ | </ | ||
+ | |||
+ | ===== Gestionde dei branch ===== | ||
Mostra i rami di sviluppo, locali e remoti: | Mostra i rami di sviluppo, locali e remoti: | ||
Line 151: | Line 168: | ||
'' | '' | ||
+ | |||
+ | ==== Creazione di un nuovo branch ==== | ||
Per creare localmente un nuovo branch di nome **jessie**: | Per creare localmente un nuovo branch di nome **jessie**: | ||
Line 169: | Line 188: | ||
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. | 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**: | Per iniziare a lavorare localmente su un determinato branch si usa il comando **git switch**: | ||
Line 194: | Line 215: | ||
**ATTENZIONE** Prima di Git 2.23 si utilizzava il comando **git checkout** per cambiare branch di lavoro locale. | **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 221: | Line 244: | ||
</ | </ | ||
- | * **[[https:// | + | ==== Clonare uno specifico branch ==== |
- | ==== Locally Committed Differences ==== | + | Quando si clona il repository remoto è possibile indicare subito su quale branch si intende lavorare: |
- | Per vedere le differenze tra il master remoto e quello | + | < |
+ | git clone --branch jessie https:// | ||
+ | </ | ||
+ | |||
+ | Con **git branch** sarà possibile verificare quale è il branch | ||
+ | |||
+ | ===== Misc Commands ===== | ||
+ | |||
+ | ==== Restore o revert di un singolo file ==== | ||
+ | |||
+ | A partire da Git 2.23 esiste il comando | ||
< | < | ||
- | git diff --name-only remotes/origin/master..master | + | git restore path/to/file |
</ | </ | ||
- | L' | + | Con versioni precedenti di Git si può usare: |
- | ==== Mostrare l'URL del repository ==== | + | < |
+ | git checkout -- path/ | ||
+ | </ | ||
+ | |||
+ | Se si desidera tornare ad uno specifico commit, si può visualizzare il log degli stessi e richiederlo esplicitamente: | ||
< | < | ||
- | git remote show origin | + | git log path/ |
+ | git checkout < | ||
</ | </ | ||
- | ===== Creare un 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. | + | ==== Colors ==== |
- | Ad esempio per marcare la versione corrente con il nome **print3d-1.0** si esegue: | + | Disable GUI colors: |
< | < | ||
- | git tag -a print3d-1.0 | + | git config |
</ | </ | ||
- | se invece della versione corrente si vuole etichettare un commit precedente, bisogna individuare l'hash ed eseguire | + | ==== Locally Committed Differences ==== |
+ | |||
+ | Per vedere le differenze tra il master remoto e quello locale | ||
< | < | ||
- | git log --pretty=oneline | + | git diff --name-only remotes/ |
- | ... | + | |
- | d7dd3e5c44023bfefc6a6c649506e3e029929b4c Added a 3D printable OpenSCAD model. | + | |
- | ... | + | |
- | git tag -a print3d-1.0 d7dd3e5 | + | |
</ | </ | ||
- | Infine bisogna salvare sul repository | + | L' |
+ | |||
+ | ==== Mostrare l'URL del repository | ||
< | < | ||
- | git push origin | + | git remote show origin |
</ | </ | ||
doc/appunti/prog/git.txt · Last modified: 2024/02/12 11:07 by niccolo