Además de cambiar la URL de inserción a algo no válido (por ejemplo, git remote set-url --push origin DISABLED
), también se puede usar el pre-push
enlace.
Una forma rápida de detenerse git push
es hacer un enlace simbólico /usr/bin/false
para ser el gancho:
$ ln -s /usr/bin/false .git/hooks/pre-push
$ git push
error: failed to push some refs to '...'
El uso de un gancho permite un control más fino de los empujes si es deseable. Vea .git/hooks/pre-push.sample
un ejemplo de cómo evitar empujar los compromisos de trabajo en progreso.
Para evitar empujar a una rama específica o limitar el empuje a una sola rama, esto en un gancho de ejemplo:
$ cat .git/hooks/pre-push
#!/usr/bin/sh
# An example hook script to limit pushing to a single remote.
#
# This hook is called with the following parameters:
#
# $1 -- Name of the remote to which the push is being done
# $2 -- URL to which the push is being done
#
# If this script exits with a non-zero status nothing will be pushed.
remote="$1"
url="$2"
[[ "$remote" == "origin" ]]
Un repositorio de prueba con múltiples controles remotos:
$ git remote -v
origin ../gitorigin (fetch)
origin ../gitorigin (push)
upstream ../gitupstream (fetch)
upstream ../gitupstream (push)
Empujar a origin
está permitido:
$ git push origin
Enumerating objects: 3, done.
Counting objects: 100% (3/3), done.
Writing objects: 100% (3/3), 222 bytes | 222.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To ../gitorigin
* [new branch] master -> master
Empujar a cualquier otro control remoto no está permitido:
$ git push upstream
error: failed to push some refs to '../gitupstream'
Tenga en cuenta que el pre-push
script de enlace puede modificarse para, entre otras cosas, imprimir un mensaje en stderr diciendo que la inserción ha sido desactivada.