Antes de responder, agreguemos algunos antecedentes, explicando de qué se HEAD
trata.
First of all what is HEAD?
HEAD
es simplemente una referencia a la confirmación actual (más reciente) en la rama actual.
Solo puede haber una sola HEAD
en un momento dado (excluyendo git worktree
).
El contenido de HEAD
se almacena dentro .git/HEAD
y contiene los 40 bytes SHA-1 de la confirmación actual.
detached HEAD
Si no está en la última confirmación, lo que significa que HEAD
apunta a una confirmación previa en el historial se llama detached HEAD
.
En la línea de comando, se verá así: SHA-1 en lugar del nombre de la rama ya HEAD
que no apunta a la punta de la rama actual:
Algunas opciones sobre cómo recuperarse de un HEAD separado:
git checkout <commit_id>
git checkout -b <new branch> <commit_id>
git checkout HEAD~X // x is the number of commits t go back
Esto verificará la nueva rama que apunta a la confirmación deseada.
Este comando pagará a un commit dado.
En este punto, puede crear una rama y comenzar a trabajar a partir de este punto.
# Checkout a given commit.
# Doing so will result in a `detached HEAD` which mean that the `HEAD`
# is not pointing to the latest so you will need to checkout branch
# in order to be able to update the code.
git checkout <commit-id>
# Create a new branch forked to the given commit
git checkout -b <branch name>
Siempre puedes usar el reflog
también.
git reflog
mostrará cualquier cambio que haya actualizado HEAD
y revisando la entrada de reflog deseada establecerá el HEAD
respaldo de este commit.
Cada vez que se modifique el HEAD habrá una nueva entrada en el reflog
git reflog
git checkout HEAD@{...}
Esto lo llevará de regreso a su compromiso deseado
"Mueva" su CABEZA de nuevo a la confirmación deseada.
# This will destroy any local modifications.
# Don't do it if you have uncommitted work you want to keep.
git reset --hard 0d1d7fc32
# Alternatively, if there's work to keep:
git stash
git reset --hard 0d1d7fc32
git stash pop
# This saves the modifications, then reapplies that patch after resetting.
# You could get merge conflicts if you've modified things which were
# changed since the commit you reset to.
- Nota: ( desde Git 2.7 ) también puedes usar el
git rebase --no-autostash
.
"Deshacer" el compromiso o rango de compromiso dado.
El comando reset "deshacerá" cualquier cambio realizado en el commit dado.
Se confirmará una nueva confirmación con el parche de deshacer, mientras que la confirmación original también permanecerá en el historial.
# Add a new commit with the undo of the original one.
# The <sha-1> can be any commit(s) or commit range
git revert <sha-1>
Este esquema ilustra qué comando hace qué.
Como puede ver allí, reset && checkout
modifique el HEAD
.
git checkout 23b6772
debería hacer.