Git reset y git reverse

Publicado por Andrea Navarro en

En este artículo se analizan las diferencias entre los comandos de git reset, reverse y sus usos.

Git reset

Git reset se utiliza para mover el proyecto a un commit anterior eliminando todos los posteriores de el historial de commits.

Para hacer reset sobre el último commit:

git reset HEAD~1

O haciendo referencia al ID del commit.

git reset 52gu
Git reset
Git reset

Para hacer reset sobre los últimos dos commits

git reset HEAD~2

O haciendo referencia al ID del commit.

git reset 2yd5
git reset
git reset

Git reset puede utilizarse con tres opciones:

reset –soft

git reset --soft [<commit>]

Genera un reset de HEAD hacia otro commit. No modifica el índice de archivos ni el contenido local. Esto significa que los archivos agregados o eliminados y los cambios producidos durante estos commits reseteados se mantendrán en el contenido local.

reset –mixed

git reset --mixed [<commit>]

Modifca el HEAD y el índice de archivos pero no el contenido local. Cualquier archivo insertado o eliminado dentro de los commits reseteados no se agregará en el índice de commits futuros.

git reset –hard

git reset --hard [<commit>]

Modifca el HEAD, el índice de archivos y el contenido local. El estado del proyecto es el equivalente al que se encontraba en el commit al que fue reseteado.

RESET–soft–mixed–hard
Modifca HEADSISISI
Modifica índice de datosNOSISI
Modifica cambios localesNONOSI

Puede utilizarse reset cuando:

  • Se han hecho commits equivocados no publicados y se desea deshacer los cambios: En el caso de no querer mantener ningunos de los cambios locales realizados puede utilizarse –hard, en caso contrario, si se quieren mantener esos cambios para realizar un commit con ellos más adelante puede utilizarse –soft.
  • Se han publicado commits cuya información se desea eliminar del historial permanentemente..

NO debe utilizarse reset cuando:

  • Se quiere regresar el proyecto al estado de un estado anterior pero se quiere mantener registros de esos cambios. En este caso debe utilizarse reverse.
  • Se está trabajando en proyecto entre más de una persona y no existen un consenso grupal sobre el revertido permanente.

Git reverse

Git reverse revierte el proyecto al estado de un commit generando un nuevo commit que revierte los cambios realizados. De esta manera las modificaciones no son eliminadas del historial y pueden ser accedidas en el futuro. Los cambios locales que no han sido guardados son sobrescritos.

Para hacer reverse sobre el último commit:

git reverse HEAD~1

O haciendo referencia al ID del commit.

git reverse 52gu
git reverse
git reserve

Puede utilizarse reverse cuando:

  • Se ha hecho publicaciones que quieren revertirse pero desean mantenerse en el historial.

NO debe utilizarse reverse cuando:

  • Se han publicado modificaciones que contienen información sensible que no quiere ser registrada en el historial.
  • Se han publicado archivos que quieren eliminarse permanentemente del historial.

Espero que les sea de utilidad. Hasta la próxima!


¿Preguntas? ¿Comentarios?

Si tenés dudas, o querés dejarnos tus comentarios y consultas, sumate al grupo de Telegram de la comunidad JuncoTIC!
¡Te esperamos!

Categorías: ProgramaciónSoftware Libre

Andrea Navarro

- Ingeniera en Informática - Docente universitaria - Investigadora