Skip to main content

Esta versión de GitHub Enterprise Server se discontinuó el 2024-09-25. No se realizarán lanzamientos de patch, ni siquiera para problemas de seguridad críticos. Para obtener rendimiento mejorado, seguridad mejorada y nuevas características, actualice a la versión más reciente de GitHub Enterprise Server. Para obtener ayuda con la actualización, póngase en contacto con el soporte técnico de GitHub Enterprise.

Cambiar un mensaje de confirmación

Si un mensaje de confirmación contiene información poco clara, incorrecta o confidencial, puedes modificarlo localmente y subir una nueva confirmación con un nuevo mensaje para GitHub Enterprise Server. También puedes cambiar un mensaje de confirmación para agregar la información faltante.

Volver a escribir el mensaje de confirmación más reciente

Puede cambiar el mensaje de confirmación más reciente mediante el comando git commit --amend.

En Git, el texto del mensaje de confirmación es parte de la confirmación. Cambiar el mensaje de confirmación cambiará el identificador de confirmación; es decir, el checksum de SHA1 que designa la confirmación. Efectivamente, estás creando una nueva confirmación que reemplaza a la anterior.

La confirmación no se ha subido en línea

Si la confirmación solo existe en el repositorio local y no se ha insertado en tu instancia de GitHub Enterprise Server, puedes modificar el mensaje de confirmación con el comando git commit --amend.

  1. En la línea de comando, desplázate hasta el repositorio que contiene la confirmación que deseas modificar.
  2. Escriba git commit --amend y presione Entrar.
  3. En tu editor de texto, edita el mensaje de confirmación y guarda la confirmación.

El nuevo mensaje y la confirmación aparecerán en tu instancia de GitHub Enterprise Server la próxima vez que envíes un cambio.

Puede cambiar el editor de texto predeterminado para Git si modifica el valor core.editor. Para más información, consulta Configuración básica del cliente en el manual de Git.

Medificar mensajes de confirmación antiguos o múltiples

Si ya insertaste la confirmación en tu instancia de GitHub Enterprise Server, tendrás que insertar a la fuerza una confirmación con un mensaje modificado.

Desalentamos enfáticamente que se realicen subidas forzadas, dado que esto cambia el historial de tu repositorio. Si haces subidas forzadas, las personas que ya hayan clonado tu repositorio tendrán que arreglar su historial local manualmente. Para más información, consulta Recuperación de la fusión mediante cambio de base ascendente en el manual de Git.

Cambio del mensaje de la confirmación insertada más recientemente

  1. Siga los pasos anteriores para modificar el mensaje de confirmación.

  2. Use el comando push --force-with-lease para forzar la inserción sobre la confirmación anterior.

    git push --force-with-lease origin EXAMPLE-BRANCH
    

Cambio del mensaje de mensajes anteriores o varios mensajes de confirmación

Si necesitas modificar el mensaje de varias confirmaciones o de una confirmación antigua, puedes utilizar un rebase interactivo y luego hacer una subida forzada para cambiar el historial de la confirmación.

  1. En la línea de comando, desplázate hasta el repositorio que contiene la confirmación que deseas modificar.

  2. Use el comando git rebase -i HEAD~n para mostrar una lista de las últimas confirmaciones n en el editor de texto predeterminado.

    # Displays a list of the last 3 commits on the current branch
    $ git rebase -i HEAD~3
    

    La lista se verá parecida a la siguiente:

    pick e499d89 Delete CNAME
    pick 0c39034 Better README
    pick f7fde4a Change the commit message but push the same commit.
    
    # Rebase 9fdb3bd..f7fde4a onto 9fdb3bd
    #
    # Commands:
    # p, pick = use commit
    # r, reword = use commit, but edit the commit message
    # e, edit = use commit, but stop for amending
    # s, squash = use commit, but meld into previous commit
    # f, fixup = like "squash", but discard this commit's log message
    # x, exec = run command (the rest of the line) using shell
    #
    # These lines can be re-ordered; they are executed from top to bottom.
    #
    # If you remove a line here THAT COMMIT WILL BE LOST.
    #
    # However, if you remove everything, the rebase will be aborted.
    #
    # Note that empty commits are commented out
    
  3. Reemplace pick por reword antes de cada mensaje de confirmación que quiera cambiar.

    pick e499d89 Delete CNAME
    reword 0c39034 Better README
    reword f7fde4a Change the commit message but push the same commit.
    
  4. Guardar y cerrar el archivo con la lista de confirmaciones.

  5. En cada archivo de confirmación resultante, escribe el nuevo mensaje de confirmación, guarda el archivo, y ciérralo.

  6. Cuando estès listo para subir tus cambios a GitHub, utiliza el comando push --force para subir el cambio forzadamente sobre la confirmaciòn antigua.

    git push --force origin EXAMPLE-BRANCH
    

Para más información sobre la fusión mediante cambio de base interactiva, consulta Modo interactivo en el manual de Git.

Como se mencionó anteriormente, el modificar el mensaje de confirmación dará como resultado una confirmación nueva con una ID nueva. Sin embargo, en este caso, cada confirmación que siga a la confirmación modificada también obtendrá un identificador nuevo, ya que cada confirmación contiene también el identificador de su elemento primario.

Si incluiste información sensible en un mensaje de confirmación, el subir dicha confirmación forzadamente con una confirmación modificada no eliminará la confirmación original de GitHub Enterprise Server. La confirmación anterior no será parte del clon siguiente; sin embargo, es posible que siga almacenada en el caché de GitHub Enterprise Server y que se pueda acceder a ella a través de la ID de la confirmación. Debes contactar a el administrador del sitio con la ID de confirmación anterior para que la purguen del repositorio remoto.

Información adicional