Configurar git #
Visão geral #
Suas configurações pessoais do git são salvas no .gitconfig
arquivo em seu diretório inicial.
Aqui está um .gitconfig
arquivo de exemplo:
[user]
name = Your Name
email = [email protected]
[alias]
ci = commit -a
co = checkout
st = status
stat = status
br = branch
wdiff = diff --color-words
[core]
editor = vim
[merge]
summary = true
Você pode verificar o que já está em seu arquivo de configuração usando o comando. Você pode editar o arquivo diretamente ou usar o
comando.:git config --list
.gitconfig
git config --global
git config --global user.name "Your Name"
git config --global user.email [email protected]
git config --global alias.ci "commit -a"
git config --global alias.co checkout
git config --global alias.st "status -a"
git config --global alias.stat "status -a"
git config --global alias.br branch
git config --global alias.wdiff "diff --color-words"
git config --global core.editor vim
git config --global merge.summary true
Para configurar em outro computador, você pode copiar seu ~/.gitconfig
arquivo ou executar os comandos acima.
Em detalhe #
user.name e user.email #
É uma boa prática dizer ao git quem você é, para rotular quaisquer alterações feitas no código. A maneira mais simples de fazer isso é na linha de comando:
git config --global user.name "Your Name"
git config --global user.email [email protected]
Isso gravará as configurações em seu arquivo de configuração git, que agora deve conter uma seção de usuário com seu nome e e-mail:
[user]
name = Your Name
email = [email protected]
Você precisará substituir e
pelo seu nome e endereço de e-mail reais.Your Name
you@yourdomain.example.com
Aliases #
Você pode se beneficiar de alguns aliases para comandos comuns.
Por exemplo, você pode querer encurtar
para . Ou você pode querer alias
(que dá uma saída bem formatada do diff) paragit checkout
git co
git diff --color-words
git wdiff
Os seguintes comandos:git config --global
git config --global alias.ci "commit -a"
git config --global alias.co checkout
git config --global alias.st "status -a"
git config --global alias.stat "status -a"
git config --global alias.br branch
git config --global alias.wdiff "diff --color-words"
criará uma alias
seção em seu .gitconfig
arquivo com conteúdo como este:
[alias]
ci = commit -a
co = checkout
st = status -a
stat = status -a
br = branch
wdiff = diff --color-words
Editor #
Você também pode querer certificar-se de que seu editor de escolha é usado
git config --global core.editor vim
Mesclando #
Para impor resumos ao fazer mesclagens ( ~/.gitconfig
arquivar novamente):
[merge]
log = true
Ou na linha de comando:
git config --global merge.log true
Saída de log extravagante #
Este é um alias muito bom para obter uma saída de log sofisticada; deve ir na
alias
seção do seu .gitconfig
arquivo:
lg = log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)[%an]%Creset' --abbrev-commit --date=relative
Você usa o alias com:
git lg
e dá saída de gráfico/texto mais ou menos assim (mas com cor!):
* 6d8e1ee - (HEAD, origin/my-fancy-feature, my-fancy-feature) NF - a fancy file (45 minutes ago) [Matthew Brett]
* d304a73 - (origin/placeholder, placeholder) Merge pull request #48 from hhuuggoo/master (2 weeks ago) [Jonathan Terhorst]
|\
| * 4aff2a8 - fixed bug 35, and added a test in test_bugfixes (2 weeks ago) [Hugo]
|/
* a7ff2e5 - Added notes on discussion/proposal made during Data Array Summit. (2 weeks ago) [Corran Webster]
* 68f6752 - Initial implementation of AxisIndexer - uses 'index_by' which needs to be changed to a call on an Axes object - this is all very sketchy right now. (2 weeks ago) [Corr
* 376adbd - Merge pull request #46 from terhorst/master (2 weeks ago) [Jonathan Terhorst]
|\
| * b605216 - updated joshu example to current api (3 weeks ago) [Jonathan Terhorst]
| * 2e991e8 - add testing for outer ufunc (3 weeks ago) [Jonathan Terhorst]
| * 7beda5a - prevent axis from throwing an exception if testing equality with non-axis object (3 weeks ago) [Jonathan Terhorst]
| * 65af65e - convert unit testing code to assertions (3 weeks ago) [Jonathan Terhorst]
| * 956fbab - Merge remote-tracking branch 'upstream/master' (3 weeks ago) [Jonathan Terhorst]
| |\
| |/
Obrigado a Yury V. Zaytsev por postá-lo.