<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Jhon Esteban Herrera</title>
    <description>The latest articles on DEV Community by Jhon Esteban Herrera (@jhonesteban).</description>
    <link>https://dev.to/jhonesteban</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F744393%2Ff87136f0-e4af-44ba-8097-5aedf08dfdfb.jpeg</url>
      <title>DEV Community: Jhon Esteban Herrera</title>
      <link>https://dev.to/jhonesteban</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/jhonesteban"/>
    <language>en</language>
    <item>
      <title>Como eliminar commits con git reset</title>
      <dc:creator>Jhon Esteban Herrera</dc:creator>
      <pubDate>Mon, 24 Jan 2022 17:45:52 +0000</pubDate>
      <link>https://dev.to/jhonesteban/como-eliminar-commits-con-git-reset-l7d</link>
      <guid>https://dev.to/jhonesteban/como-eliminar-commits-con-git-reset-l7d</guid>
      <description>&lt;p&gt;Para nadie es un secreto que el dominio del &lt;strong&gt;control de versiones&lt;/strong&gt; es fundamental para ser un buen desarrollador, aquí es donde entra &lt;strong&gt;Git&lt;/strong&gt; con sus innumerables comandos. En esta ocasión te mostraré como puedes eliminar commits a través del comando &lt;strong&gt;git reset&lt;/strong&gt; y sus diferentes variantes.&lt;br&gt;&lt;br&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Para usar &lt;code&gt;git reset&lt;/code&gt; es fundamental tener en cuenta lo siguiente:
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Debemos haber inicializado previamente nuestro proyecto con el comando &lt;code&gt;git init&lt;/code&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Debemos obtener la referencia del commit previo al que queremos eliminar.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Si queremos eliminar varios commits, debemos obtener la referencia del commit en el cual queremos posicionarnos y los posteriores a este serán los afectados.&lt;br&gt;&lt;br&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  ¿Cómo obtengo la referencia de un commit?
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Para buscar la referencia del commit debemos ir a la &lt;strong&gt;lista de commits&lt;/strong&gt; con el comando &lt;code&gt;git log&lt;/code&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Una vez usado este comando, se te mostrará una lista con los commits que has hecho, un mensaje que describe a cada uno y su respectivo identificador único, referencia de commit o también llamado hash.&lt;br&gt;&lt;br&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Ejemplo
&lt;/h3&gt;

&lt;p&gt;Previamente, cree una carpeta llamada &lt;strong&gt;ejemplo-git&lt;/strong&gt; donde inicialice &lt;strong&gt;Git&lt;/strong&gt; con el comando &lt;code&gt;git init&lt;/code&gt;, realice cuatro commits y utilice el comando &lt;code&gt;git log&lt;/code&gt; para ver la lista completa de commits.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fkgui24iba29tofl49ll1.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fkgui24iba29tofl49ll1.jpg" alt="Lista de commits" width="629" height="482"&gt;&lt;/a&gt;&lt;br&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Uso de &lt;code&gt;git reset&lt;/code&gt; y sus variantes
&lt;/h2&gt;

&lt;h3&gt;
  
  
  - &lt;code&gt;git reset --mixed hash_del_commit&lt;/code&gt;
&lt;/h3&gt;

&lt;p&gt;Esta variante nos permite eliminar commits y enviar sus cambios a la zona de trabajo o en inglés llamado &lt;strong&gt;working directory&lt;/strong&gt;, este es su comportamiento por defecto así que no es necesario emplear la bandera &lt;code&gt;--mixed&lt;/code&gt;, pero es importante saberlo.&lt;/p&gt;

&lt;p&gt;Cabe resaltar que si algún archivo que generaste en el commit que acabaste de eliminar no tenía cambios previos en otros commits, este dejara de tener seguimiento por &lt;strong&gt;Git&lt;/strong&gt;, para restaurarlo solo debes enviarlo a la zona de preparación o en inglés llamado &lt;strong&gt;staging area&lt;/strong&gt;.&lt;br&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Ejemplo
&lt;/h3&gt;

&lt;p&gt;Continuaremos con el proyecto &lt;strong&gt;ejemplo-git&lt;/strong&gt; donde ya había generado cuatro commits, en este caso procederé a eliminar el último commit donde había agregado un archivo README.md.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Visualizamos la lista de commits con el comando &lt;code&gt;git log&lt;/code&gt; y obtenemos el hash del commit previo al último, ya que ahí es donde queremos posicionar el proyecto, que elimine el commit posterior a este y lleve los cambios a la zona de trabajo.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fgh3asa0dmlnarp5wx8yc.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fgh3asa0dmlnarp5wx8yc.jpg" alt="Lista de commits" width="629" height="482"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Ejecutamos el comando &lt;code&gt;git reset --mixed&lt;/code&gt; junto con el hash del
commit para completar la eliminación, verificamos que el archivo esté en la zona de trabajo con el comando &lt;code&gt;git status&lt;/code&gt; y que ya no exista el commit en la lista con el comando &lt;code&gt;git log&lt;/code&gt;.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fm7l8wxnp1xetslnzta4c.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fm7l8wxnp1xetslnzta4c.jpg" alt="Comando git reset variante mixed" width="775" height="577"&gt;&lt;/a&gt;&lt;br&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  - &lt;code&gt;git reset --soft hash_del_commit&lt;/code&gt;
&lt;/h3&gt;

&lt;p&gt;Esta variante nos permite eliminar commits y enviar sus cambios a la zona de preparación o en inglés llamado &lt;strong&gt;staging area&lt;/strong&gt;. Normalmente, este comando lo podemos usar cuando nos faltó algún cambio que agregar en el último commit.&lt;br&gt;&lt;br&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Ejemplo
&lt;/h3&gt;

&lt;p&gt;Continuamos en el proyecto &lt;strong&gt;ejemplo-git&lt;/strong&gt; y lo que haremos será eliminar de nuevo el último commit, que en este caso es el commit donde agregue un archivo index.js.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Visualizamos de nuevo la lista de commits con el comando &lt;code&gt;git log&lt;/code&gt; y obtenemos el hash del commit previo.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftfwlbtrwacw16pgjzf6w.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftfwlbtrwacw16pgjzf6w.jpg" alt="Lista de commits" width="634" height="355"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Ejecutamos el comando &lt;code&gt;git reset --soft&lt;/code&gt; junto con el hash del
commit para completar la eliminación, comprobamos que el archivo esté en la zona de preparación con el comando &lt;code&gt;git status&lt;/code&gt; y que ya no exista el commit en la lista con el comando &lt;code&gt;git log&lt;/code&gt;.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F2k1xslvookflzogjbgif.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F2k1xslvookflzogjbgif.jpg" width="649" height="527"&gt;&lt;/a&gt;&lt;br&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  - &lt;code&gt;git reset --hard hash_del_commit&lt;/code&gt;
&lt;/h3&gt;

&lt;p&gt;Esta variante nos permite eliminar commits y sus cambios totalmente sin dejar rastro alguno.&lt;/p&gt;

&lt;p&gt;Al emplear esta variante es fundamental verificar que no hayas hecho cambios en ningún otro archivo, ya que estos cambios también serian borrados, no importa si están en la zona de trabajo o de preparación, si ya tienen un seguimiento por &lt;strong&gt;Git&lt;/strong&gt; serán afectados.&lt;/p&gt;

&lt;p&gt;Para saber que archivos no tienen seguimiento por &lt;strong&gt;Git&lt;/strong&gt;, podemos  utilizar el comando &lt;code&gt;git status&lt;/code&gt; y estos aparecerán en el apartado de &lt;strong&gt;untracked files&lt;/strong&gt;, este es el estado de todos los archivos que creamos y nunca han estado en la zona de preparación o que en algún momento los bajamos de allí.&lt;br&gt;&lt;br&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Ejemplo
&lt;/h3&gt;

&lt;p&gt;Siguiendo con el proyecto &lt;strong&gt;ejemplo-git&lt;/strong&gt;, ahora solo nos quedan dos commits y vamos a eliminar el último, que en este caso sería el commit donde agregue el archivo styles.css.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Visualizamos de nuevo la lista de commits con el comando &lt;code&gt;git log&lt;/code&gt; y obtenemos el hash del commit previo.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fqm1oqgfg326o4tyr6fhe.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fqm1oqgfg326o4tyr6fhe.jpg" width="644" height="244"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Ejecutamos el comando &lt;code&gt;git reset --hard&lt;/code&gt; junto con el hash del
commit para completar la eliminación, usamos el comando &lt;code&gt;git status&lt;/code&gt; para verificar que no esté el archivo styles.css, también podremos ver que el index.js fue borrado y que el archivo README.md permaneció intacto por las razones anteriormente mencionadas. Para finalizar revisamos que ya no exista el commit en la lista con el comando &lt;code&gt;git log&lt;/code&gt;.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fv593fg27axg1amd0mtdb.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fv593fg27axg1amd0mtdb.jpg" width="781" height="370"&gt;&lt;/a&gt;&lt;br&gt;&lt;/p&gt;

&lt;h4&gt;
  
  
  IMPORTANTE
&lt;/h4&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Recuerden que pueden eliminar más de un commit y decidir que hacer con los cambios de esos commits, a través de las variantes mostradas que te ofrece &lt;code&gt;git reset&lt;/code&gt;, en este caso siempre elimine el último para llevar un orden y que se entendiera.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Si solo has creado un commit en tu proyecto &lt;code&gt;git reset&lt;/code&gt; no funcionara como esperas, ya que este se basa en tener por lo menos dos commits. De tal modo que se necesita una referencia a un commit previo para poder devolver el proyecto a un estado anterior.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;git reset&lt;/strong&gt; es considerado por algunos como una mala práctica, así que utilízalo cuando sea realmente necesario, es muy probable que lo necesites para salir de algún apuro.&lt;br&gt;&lt;br&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Si te gusto puedes compartirlo, además te invito a conectar conmigo en mi LinkedIn, seguiré generando este tipo de artículos sobre desarrollo frontend.&lt;/p&gt;

&lt;h2&gt;
  
  
  👇👇
&lt;/h2&gt;

&lt;h2&gt;
  
  
  &lt;a href="https://www.linkedin.com/in/jhon-esteban-herrera" rel="noopener noreferrer"&gt;LinkedIn&lt;/a&gt;&lt;br&gt;&lt;br&gt;
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fhfb1a4p8rk7h6ueo4761.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fhfb1a4p8rk7h6ueo4761.gif" width="500" height="281"&gt;&lt;/a&gt;&lt;/p&gt;

</description>
      <category>git</category>
      <category>programming</category>
      <category>tutorial</category>
    </item>
  </channel>
</rss>
