Além de alterar o URL de envio para algo inválido (por exemplo, git remote set-url --push origin DISABLED
), também é possível usar o pre-push
gancho.
Uma maneira rápida de parar git push
é fazer o link simbólico /usr/bin/false
para ser o gancho:
$ ln -s /usr/bin/false .git/hooks/pre-push
$ git push
error: failed to push some refs to '...'
O uso de um gancho permite um controle mais refinado dos impulsos, se desejado. Veja .git/hooks/pre-push.sample
um exemplo de como evitar o envio de confirmações de trabalho em andamento.
Para impedir o envio para um ramo específico ou limitar o envio para um único ramo, isso é um exemplo de gancho:
$ 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" ]]
Um repositório de teste com vários controles remotos:
$ git remote -v
origin ../gitorigin (fetch)
origin ../gitorigin (push)
upstream ../gitupstream (fetch)
upstream ../gitupstream (push)
Pressionar para origin
é 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
Empurrar para qualquer outro controle remoto não é permitido:
$ git push upstream
error: failed to push some refs to '../gitupstream'
Observe que o pre-push
script do gancho pode ser modificado para, entre outras coisas, imprimir uma mensagem para o stderr dizendo que o envio foi desativado.