Si j'ai n commits, comment puis-je dériver du commit n-3?
Je peux voir le hash de chaque commit.
Vous pouvez créer la branche via un hash:
git branch branchname <sha1-of-commit>
Ou en utilisant une référence symbolique:
git branch branchname HEAD~3
Pour extraire la branche lors de sa création, utilisez
git checkout -b branchname <sha1-of-commit or HEAD~3>
Pour ce faire sur github.com:
La magie peut être faite par réinitialisation de git.
Créez une nouvelle branche et basculez-y (pour que tous vos derniers commits soient stockés ici)
git checkout -b your_new_branch
Revenez à votre branche de travail précédente (supposez que c'est le maître)
git checkout master
Supprimer les derniers commits x, garder le maître propre
git reset --hard HEAD~x # in your case, x = 3
À partir de ce moment, tous les derniers x commits ne sont plus que dans la nouvelle branche, pas dans votre branche précédente (maître).
Si vous ne savez pas quelle validation vous voulez créer à partir de la branche, vous pouvez vérifier les commits et examiner leur code (voir source, compiler, tester) en
git checkout <sha1-of-commit>
une fois que vous avez trouvé le commit que vous souhaitez créer, vous pouvez le faire depuis le commit (c'est-à-dire sans revenir au maître) en créant simplement une branche de la manière habituelle:
git checkout -b <branch_name>
git checkout -b <branch-name> <sha1-of-commit>
Pour ce faire dans Eclipse:
Cela créera une branche locale pour vous. Ensuite, chaque fois que vous transmettez vos modifications, votre branche sera transmise au serveur distant.
Il suffit de lancer:
git checkout -b branch-name <commit>
Par exemple :
git checkout -b import/january-2019 1d0fa4fa9ea961182114b63976482e634a8067b8
La commande checkout
avec le paramètre -b
créera une nouvelle branche ET et vous y basculera
Une bonne question connexe est la suivante: comment voyez-vous cela en utilisant l'option --help
de git? Essayons ça:
git branch --help
Nous voyons cette sortie:
NAME
git-branch - List, create, or delete branches
SYNOPSIS
git branch [--color[=<when>] | --no-color] [-r | -a]
[--list] [-v [--abbrev=<length> | --no-abbrev]]
[--column[=<options>] | --no-column]
[(--merged | --no-merged | --contains) [<commit>]] [--sort=<key>]
[--points-at <object>] [<pattern>...]
git branch [--set-upstream | --track | --no-track] [-l] [-f] <branchname> [<start-point>]
git branch (--set-upstream-to=<upstream> | -u <upstream>) [<branchname>]
git branch --unset-upstream [<branchname>]
git branch (-m | -M) [<oldbranch>] <newbranch>
git branch (-d | -D) [-r] <branchname>...
git branch --edit-description [<branchname>]
Gobbledegook.
Recherchez dans le texte suivant le mot "commit". Nous trouvons ceci:
<start-point>
The new branch head will point to this commit. It may be given as a branch name, a
commit-id, or a tag. If this option is omitted, the current HEAD will be used instead.
Nous allons quelque part!
Maintenant, concentrez-vous sur cette ligne du gobbledegook:
git branch [--set-upstream | --track | --no-track] [-l] [-f] <branchname> [<start-point>]
Condense cela à ceci:
git branch <branchname> [<start-point>]
Et fait.
J'ai pu le faire comme ça:
git branch new_branch_name `git log -n 1 --skip 3 --format=%H`
Où vous devez entrer la valeur de saut. 0 est le dernier, 1 le précédent, 2 le commit avant ça, etc.
Vous pouvez le faire en Stash.
C'est ce que j'ai fait:
C:\Users\[path]\build>git checkout -b responsivenavigation 8a75b001096536b3216022484af3026aa9c7bb5b
Switched to a new branch 'responsivenavigation'
C:\Users\jaimemontoya\Dropbox\CuponClub\androidapp\build>git branch
master
* responsivenavigation
Dans ce cas, 8a75b001096536b3216022484af3026aa9c7bb5b
était et un ancien commit appartenant à la branche master
.
Aller à un commit particulier d'un dépôt git
Parfois, lorsque vous travaillez sur un référentiel git, vous souhaitez revenir à une validation (révision) spécifique pour obtenir un instantané de votre projet à une heure spécifique. Pour ce faire, vous avez besoin du hachage SHA-1 du commit que vous pouvez facilement trouver en consultant le journal avec la commande:
git log --abbrev-commit --pretty=oneline
qui vous donnera une liste compacte de tous les commits et de la version courte du hachage SHA-1.
Maintenant que vous connaissez le hash du commit que vous voulez aller, vous pouvez utiliser l'une des 2 commandes suivantes:
git checkout HASH
ou
git reset --hard HASH
caisse
git checkout <commit> <paths>
Indique à git de remplacer l'état actuel des chemins par leur état dans le commit donné. Les chemins peuvent être des fichiers ou des répertoires.
Si aucune branche n'est donnée, git suppose le commit HEAD.
git checkout <path> // restores path from your last commit. It is a 'filesystem-undo'.
Si aucun chemin n'est donné, git déplace HEAD
vers le commit donné (modifiant ainsi le commit sur lequel vous êtes assis et sur lequel vous travaillez).
git checkout branch //means switching branches.
réinitialiser
git reset <commit> //re-sets the current pointer to the given commit.
Si vous êtes sur une branche (vous devriez normalement l'être), HEAD
et cette branche sont déplacés vers commit.
Si vous êtes dans l'état HEAD
détaché, la réinitialisation de git ne déplace que HEAD
. Pour réinitialiser une branche, commencez par la vérifier.
Si vous voulez en savoir plus sur la différence entre la réinitialisation de git et la caisse de git, je vous recommande de lire le blog officiel de git .
si vous utilisez l’arbre source, c’est assez simple.
Pour faire la réponse acceptée dans Visual Studio 2015 & 2017:
Cliquez sur les modifications (flèche rouge ci-dessus)
Cliquez sur Actions (flèche rouge ci-dessus), puis sur Afficher l'historique dans le menu déroulant.
Et le nouvel onglet s'ouvrira:
Et vous devez cliquer avec le bouton droit sur le commit précédent auquel vous voulez que votre code revienne:
Choisissez de commander une nouvelle branche et voila!
Ci-dessous, bien que ne faisant pas partie de la question OP, mais je fais beaucoup de choses à la fois et celle-ci est une astuce, du moins pour moi: si vous voulez revenir à un commit précédent, sans passer par une nouvelle branche, NE PAS choisir de revenir (! ?); vous devriez choisir redéfinir --mixed ou --hard: