Setup and Config
Getting and Creating Projects
Basic Snapshotting
Branching and Merging
Sharing and Updating Projects
Inspection and Comparison
Patching
Debugging
External Systems
Server Admin
Guides
- gitattributes
- Command-line interface conventions
- Everyday Git
- Frequently Asked Questions (FAQ)
- Glossary
- Hooks
- gitignore
- gitmodules
- Revisions
- Submodules
- Tutorial
- Workflows
- All guides...
Administration
Plumbing Commands
- 2.48.1 no changes
- 2.48.0 no changes
- 2.47.1 → 2.47.2 no changes
- 2.47.0 10/06/24
- 2.46.1 → 2.46.3 no changes
- 2.46.0 07/29/24
- 2.45.2 → 2.45.3 no changes
- 2.45.1 04/29/24
- 2.45.0 04/29/24
- 2.44.2 → 2.44.3 no changes
- 2.44.1 04/19/24
- 2.44.0 02/23/24
- 2.43.5 → 2.43.6 no changes
- 2.43.4 04/19/24
- 2.43.2 → 2.43.3 no changes
- 2.43.1 02/09/24
- 2.43.0 11/20/23
- 2.42.3 → 2.42.4 no changes
- 2.42.2 04/19/24
- 2.42.1 11/02/23
- 2.42.0 08/21/23
- 2.41.2 → 2.41.3 no changes
- 2.41.1 04/19/24
- 2.41.0 06/01/23
- 2.40.3 → 2.40.4 no changes
- 2.40.2 04/19/24
- 2.40.1 no changes
- 2.40.0 no changes
- 2.39.5 no changes
- 2.39.4 04/19/24
- 2.39.1 → 2.39.3 no changes
- 2.39.0 12/12/22
- 2.38.3 → 2.38.5 no changes
- 2.38.2 12/11/22
- 2.38.1 no changes
- 2.38.0 10/02/22
- 2.37.3 → 2.37.7 no changes
- 2.37.2 08/11/22
- 2.37.1 no changes
- 2.37.0 06/27/22
- 2.36.1 → 2.36.6 no changes
- 2.36.0 04/18/22
- 2.35.1 → 2.35.8 no changes
- 2.35.0 01/24/22
- 2.34.1 → 2.34.8 no changes
- 2.34.0 11/15/21
- 2.33.3 → 2.33.8 no changes
- 2.33.2 03/23/22
- 2.33.1 10/12/21
- 2.32.1 → 2.33.0 no changes
- 2.32.0 06/06/21
- 2.31.1 → 2.31.8 no changes
- 2.31.0 03/15/21
- 2.30.1 → 2.30.9 no changes
- 2.30.0 12/27/20
- 2.29.1 → 2.29.3 no changes
- 2.29.0 10/19/20
- 2.28.1 no changes
- 2.28.0 07/27/20
- 2.27.1 no changes
- 2.27.0 06/01/20
- 2.26.1 → 2.26.3 no changes
- 2.26.0 03/22/20
- 2.25.2 → 2.25.5 no changes
- 2.25.1 02/17/20
- 2.25.0 01/13/20
- 2.23.1 → 2.24.4 no changes
- 2.23.0 08/16/19
- 2.22.2 → 2.22.5 no changes
- 2.22.1 08/11/19
- 2.22.0 06/07/19
- 2.20.1 → 2.21.4 no changes
- 2.20.0 12/09/18
- 2.19.3 → 2.19.6 no changes
- 2.19.2 11/21/18
- 2.19.1 no changes
- 2.19.0 09/10/18
- 2.18.1 → 2.18.5 no changes
- 2.18.0 06/21/18
- 2.17.1 → 2.17.6 no changes
- 2.17.0 04/02/18
- 2.16.6 12/06/19
- 2.15.4 12/06/19
- 2.14.6 12/06/19
- 2.13.7 no changes
- 2.12.5 09/22/17
- 2.11.4 09/22/17
- 2.10.5 09/22/17
- 2.9.5 07/30/17
- 2.8.6 07/30/17
- 2.7.6 07/30/17
- 2.6.7 05/05/17
- 2.5.6 05/05/17
- 2.4.12 05/05/17
- 2.3.10 09/28/15
- 2.2.3 09/04/15
- 2.1.4 12/17/14
- 2.0.5 12/17/14
RESUMO
git [-v | --version] [-h | --help] [-C <path>] [-c <name>=<value>] [--exec-path[=<path>]] [--html-path] [--man-path] [--info-path] [-p | --paginate | -P | --no-pager] [--no-replace-objects] [--no-lazy-fetch] [--no-optional-locks] [--no-advice] [--bare] [--git-dir=<path>] [--work-tree=<path>] [--namespace=<name>] [--config-env=<name>=<envvar>] <command> [<args>]
DESCRIÇÃO
O Git é um sistema de controle de revisão distribuído, rápido, escalável e com um conjunto de comandos incomumente rico que oferece operações de alto nível e acesso completo aos seus recursos.
Consulte gittutorial[7] para começar e, em seguida, giteveryday[7] para obter um conjunto mínimo útil de comandos. O O manual do usuário do Git tem uma introdução mais aprofundada.
Após dominar os conceitos básicos, você pode voltar a esta página para saber quais comandos o Git oferece. Você pode saber mais sobre comandos individuais do Git com o comando git help. A página do manual gitcli[7] oferece uma visão geral da sintaxe do comando de linha de comando.
Uma cópia formatada e com hiperlink da documentação mais recente do Git pode ser visualizada em https://git.github.io/htmldocs/git.html ou https://git-scm.com/docs.
OPÇÕES
- -v
- --version
-
Imprime a versão do pacote Git exibindo a sua origem.
Esta opção é convertida internamente para
git version ...
e aceita as mesmas opções que o comando git-version[1]. Se a opção--help
também for usada, ela tem precedência sobre a opção--version
. - -h
- --help
-
Imprime a sinopse e uma lista dos comandos mais usados. Caso a opção
--all
ou-a
seja usada, todos os comandos disponíveis serão impressos. Caso um comando Git seja informado, esta opção exibirá a página do manual deste comando.Outras opções estão disponíveis para controlar como a página do manual é exibida. Para mais informações, consulte git-help[1], pois o comando
git --help ...
é convertido internamente emgit help ...
. - -C <caminho>
-
Executar como se o git tivesse sido iniciado em <caminho> em vez de no diretório de trabalho atual. Quando várias opções
-C
são usadas, cada-C <caminho>
não absoluto subsequente é interpretado em relação ao-C <caminho>
anterior. Se o <caminho> estiver presente, mas vazio, por exemplo,-C ""
, o diretório de trabalho atual não será alterado.Esta opção afeta as opções que esperam o nome do caminho, como
--git-dir
e--work-tree
, pois as suas interpretações dos nomes dos caminhos seriam feitas em relação ao diretório de trabalho causado pela opção-C
. Como, por exemplo, as seguintes invocações são equivalentes:git --git-dir=a.git --work-tree=b -C c status git --git-dir=c/a.git --work-tree=c/b status
- -c <nome>=<valor>
-
Repassa um parâmetro de configuração para o comando. O valor fornecido substituirá os valores dos arquivos de configuração. O <nome> é esperado no mesmo formato listado através do comando git config (subchaves separadas por pontos).
Note que ao omitir
=
no comandogit -c foo.bar ...
é permitido e definefoo.bar
com o valor booleano verdadeiro (assim como`[foo]bar` faria em um arquivo de configuração). Incluindo os iguais, porém com um valor vazio (comogit -c foo.bar= ...
) definefoo.bar
para a string vazia quegit config --type=bool
converterá parafalse
. - --config-env=<nome>=<envvar>
-
Assim como
-c <nome>=<valor>
, atribui à variável de configuração <nome> um valor, onde <envvar> é o nome de uma variável de ambiente de onde se obtém o valor. Ao contrário da opção-c
, não há atalho para definir diretamente o valor como uma string vazia; em vez disso, a própria variável de ambiente deve ser definida como uma string vazia. Ocorrerá um erro se a<envvar>
não existir no ambiente. O<envvar>
não pode conter um sinal de igual para evitar ambiguidade com<nome>
que contenha um.Isso é útil para casos onde você deseja passar opções de configuração transitórias para o git, porém está fazendo isso em sistemas operacionais onde outros processos possam ser capazes de ler a sua linha de comando (
/proc/self/cmdline
por exemplo), mas não o seu ambiente (/proc/self/Environment
por exemplo). Este é comportamento normal no Linux, mas pode não estar no seu sistema.Observe que isso pode adicionar segurança para variáveis como
http.extraHeader
onde as informações confidenciais fazem parte do valor, mas nãourl.<base>.insteadOf
por exemplo onde as informações confidenciais podem fazer parte da chave. - --exec-path[=<caminho>]
-
O caminho para o local onde os programas principais do Git estão instalados. Isso também pode ser controlado pela configuração da variável de ambiente
GIT_EXEC_PATH
. Se nenhum caminho for fornecido, o git imprimirá a configuração atual e encerrará. - --html-path
-
Imprima o caminho, sem barra, onde a documentação HTML do Git está instalada e encerre.
- --man-path
-
Imprima o manpath (consulte
man(1)
) para as páginas do manual desta versão do Git e encerre. - --info-path
-
Imprima o caminho onde os arquivos Info que documentam esta versão do Git estão instalados e encerre.
- -p
- --paginate
-
Canalize toda a saída para less (ou, se definido,
$PAGER
) se a saída predefinida for um terminal. Isso substitui as opções de configuraçãopager.<cmd>
(consulte a seção "Mecanismo de configuração" abaixo). - -P
- --no-pager
-
Não canalize a saída do Git para um pager.
- --git-dir=<caminho>
-
Define o caminho para o repositório (o diretório ".git"). Isso também pode ser controlado pela configuração da variável de ambiente
GIT_DIR
. Pode ser um caminho absoluto ou relativo ao diretório de trabalho atual.Especificar o local do diretório .git usando essa opção (ou a variável de ambiente
GIT_DIR
) desativa a descoberta do repositório que tenta encontrar um diretório com o subdiretório .git (que é como o repositório e o nível superior da árvore de trabalho são descobertos) e informa ao Git que você está no nível mais alto da árvore de trabalho. Se você não estiver no diretório do cume da árvore de trabalho, deverá informar ao Git onde está o nível superior da árvore de trabalho, com a opção--work-tree=<caminho>
(ou a variável de ambienteGIT_WORK_TREE
)Caso queira executar o git como se tivesse sido iniciado em
<caminho>
, utilizegit -C <caminho>
. - --work-tree=<caminho>
-
Defina o caminho para a árvore de trabalho. Pode ser um caminho absoluto ou um caminho relativo ao diretório de trabalho atual. Isso também pode ser controlado definindo a variável de ambiente
GIT_WORK_TREE
e a variável de configuraçãocore.worktree
(consultecore.worktree
do comando git-config[1] para obter informações mais detalhadas). - --namespace=<caminho>
-
Define o espaços de nomes do Git. Para mais detalhes consulte gitnamespaces[7]. Equivale a definir a variável de ambiente
GIT_NAMESPACE
. - --bare
-
Trate o repositório como um repositório simples. Se o ambiente
GIT_DIR
não estiver definido, ele será definido como o diretório de trabalho atual. - --no-replace-objects
-
Do not use replacement refs to replace Git objects. This is equivalent to exporting the
GIT_NO_REPLACE_OBJECTS
environment variable with any value. See git-replace[1] for more information. - --no-lazy-fetch
-
Do not fetch missing objects from the promisor remote on demand. Useful together with
git cat-file -e <object>
to see if the object is locally available. This is equivalent to setting theGIT_NO_LAZY_FETCH
environment variable to1
. - --no-optional-locks
-
Não execute operações opcionais que exijam bloqueios. Isso é equivalente que definir o
GIT_OPTIONAL_LOCKS
como0
. - --no-advice
-
Disable all advice hints from being printed.
- --literal-pathspecs
-
Trate os pathpecs literalmente (ou seja, sem globbing, sem truques para o pathpec). Isso é o mesmo que definir a variável de ambiente
GIT_LITERAL_PATHSPECS
como1
. - --glob-pathspecs
-
Adicione a magia glob para todos os pathspec. É como definir a variável de ambiente
GIT_GLOB_PATHSPECS
como1
. A desativação do caractere curinga nos pathspecs individuais podem ser feitos utilizando a mágica do pathspec ": (literal)" - --noglob-pathspecs
-
Adicione a magia literal a todos os "pathspec". É equivalente a definir a variável de ambiente
GIT_NOGLOB_PATHSPECS
para1
. A ativação dos caracteres curinga nos "pathspecs" individuais podem ser feitos utilizando a mágica do pathspec ":(glob)" - --icase-pathspecs
-
Adicione a magia icase em todos os pathspec. É como definir a variável de ambiente
GIT_ICASE_PATHSPECS
como1
. - --list-cmds=<grupo>[,<grupo>…]
-
Liste os comandos por grupo. Essa é uma opção interna/experimental e pode mudar ou ser removido no futuro. Os grupos compatíveis são:
builtins
,parseopt
(comandos internos que utilizam parse-options´),main
(todos os comandos no diretório 'libexec),others
(todos os outros comandos no$PATH
que possuem um prefixo git),list- <categoria>
(consulte as categorias no command-list.txt),nohelpers
(exclua os comandos auxiliares),alias
econfig
(recupera a lista dos comandos da variávelcompletion.commands
) - --attr-source=<tree-ish>
-
Leia o gitattributes do <tree-ish> em vez da árvore de trabalho. Consulte gitattributes[5]. Isso é equivalente a definir a variável de ambiente
GIT_ATTR_SOURCE
.
OS COMANDOS DO GIT
Dividimos o Git em comandos de alto nível ("porcelana") e de baixo nível ("encanamento").
Comandos de alto nível (porcelana)
Separamos os comandos porcelana nos comandos principais e em alguns utilitários auxiliares do usuário.
Os principais comandos porcelana
Warning
|
Missing See original version for this content. |
Comandos Auxiliares
Manipuladores:
Warning
|
Missing See original version for this content. |
Interrogadores:
Warning
|
Missing See original version for this content. |
Interagindo com os outros
Estes comandos são para interagir com um SCM externo e com as outras pessoas através de patch por e-mail.
Warning
|
Missing See original version for this content. |
Redefina, restaure e reverta
Existem três comandos com nomes semelhantes: git reset
, git restore
e o git revert
.
-
git-revert[1] trata de fazer um novo commit que reverte as alterações feitas por outros commit.
-
git-restore[1] trata da restauração dos arquivos na árvore de trabalho do índice ou de outro commit. Este comando não atualiza o seu ramo. O comando também pode ser usado para restaurar os arquivos no índice do outro commit.
-
git-reset[1] trata da atualização do seu ramo, movendo o topo para adicionar ou remover os commits do ramo. Esta operação altera o histórico do commit.
O comando
git reset
também pode ser usado para restaurar o índice, sobrepondo comgit restore
.
Comandos de baixo nível (encanamento plumbing)
Embora o Git inclua a sua própria camada de porcelana, os seus comandos de baixo nível são suficientes para dar suporte ao desenvolvimento de porcelanas alternativas. Os desenvolvedores de tais porcelanas podem começar lendo sobre os comando git-update-index[1] e git-read-tree[1].
A interface (entrada, saída, conjunto de opções e a semântica) desses comandos de baixo nível deve ser muito mais estável do que a dos comandos no nível porcelana, porque estes comandos são destinados principalmente para utilização com scripts. A interface dos comandos porcelana, por outro lado, está sujeita a alterações para melhorar a experiência do usuário final.
A descrição a seguir divide os comandos de baixo nível em comandos que manipulam os objetos (no repositório, índice e árvore de trabalho), comandos que interrogam, comparam objetos, comandos que movem objetos e suas referências entre os repositórios.
Comandos de manipulação
Warning
|
Missing See original version for this content. |
Comandos de interrogação
Warning
|
Missing See original version for this content. |
Em geral, os comandos de interrogação não tocam nos arquivos da árvore de trabalho.
Sincronizando os repositórios
Warning
|
Missing See original version for this content. |
A seguir, são apresentados os comandos auxiliares utilizados acima; os usuários finais normalmente não os utilizam diretamente.
Warning
|
Missing See original version for this content. |
Guias
As páginas da documentação a seguir são os guias sobre os conceitos do Git.
Warning
|
Missing See original version for this content. |
As interfaces do repositório, do comando e do arquivo
Esta documentação discute as interfaces do repositório e os comandos com as quais os usuários devem interagir diretamente. Consulte --user-formats
em git-help[1] para obter mais detalhes sobre os critérios.
Warning
|
Missing See original version for this content. |
Formatos dos arquivos, protocolos e outras interfaces do desenvolvedor
Esta documentação aborda os formatos dos arquivos, uma abordagem geral dos protocolos e das outras interfaces do desenvolvedor git. Consulte --developer-interfaces
em git-help[1].
Warning
|
Missing See original version for this content. |
Mecanismo de Configuração
O Git usa um formato de texto simples para armazenar personalizações que são por repositório e por usuário. Este arquivo de configuração pode ter a seguinte aparência:
# # Os caracteres '#' ou ';' indicam um comentário. # ; variáveis principais [core] ; Não confie nos modos dos arquivos filemode = false ; identidade do usuário [user] name = "Junio C Hamano" email = "gitster@pobox.com"
Vários comandos leem o arquivo de configuração e ajustam a sua operação conforme seja necessário. Consulte o comando git-config[1] para obter uma lista e mais detalhes sobre o mecanismo de configuração.
Terminologia do Identificador
- <objeto>
-
Indica o nome do objeto para qualquer tipo de objeto.
- <blob>
-
Indica um nome de um objeto bolha.
- <árvore>
-
Indica um nome de um objeto árvore.
- <commit>
-
Indica um nome de um objeto commit.
- <tree-ish>
-
Indica um nome do objeto da árvore, commit ou as etiquetas. Um comando que recebe um argumento <tree-ish> deseja operar num objeto
<´árvore>
, mas remove a referência automaticamente nos objetos<commit>
e<etiqueta>
que apontam para uma<árvore>
. - <commit-ish>
-
Indica um nome da etiqueta do objeto ou do commit. Um comando que recebe um argumento
<commit-ish>
deseja operar num objeto<commit>
, mas remove a referência automaticamente nos objetos<etiqueta>
que apontam para um<commit>
. - <tipo>
-
Indica que é necessário um tipo de objeto. Atualmente é um dos seguintes:
blob
,tree
,commit
outag
. - <arquivo>
-
Indica um nome do arquivo - quase sempre em relação à raiz da estrutura da árvore que o
GIT_INDEX_FILE
descreve.
Identificadores Simbólicos
Qualquer comando Git que aceite qualquer <objeto> também pode utilizar a seguinte notação simbólica:
Para obter uma lista mais completa de maneiras de soletrar os nomes dos objetos, consulte a seção "DEFININDO AS REVISÕES" em gitrevisions[7].
A Estrutura dos Arquivos/Diretórios
Favor consultar o documento gitrepository-layout[5].
Para mais detalhes sobre cada gancho, consulte githooks[5].
Os SCMs de alto nível podem fornecer e gerenciar informações adicionais no $GIT_DIR
.
Terminologia
Favor consultar gitglossary[7].
As Variáveis do Ambiente
Vários comandos do Git se atentam às variáveis de ambiente e alteram o seu comportamento. As variáveis de ambiente marcadas como Boolean assumem seus valores da mesma forma que as variáveis de configuração com valor booleano, por exemplo, true, yes, on e números positivos são considerados como yes.
Aqui estão as variáveis:
O Repositório Git
Essas variáveis de ambiente se aplicam a todos os comandos principais do Git. Nb: é importante notar que eles podem ser usados/substituídos pelo SCMS acima do Git, portanto, tenha cuidado caso esteja usando um front-end externo.
-
GIT_INDEX_FILE
-
Essa variável de ambiente determina um arquivo alternativo do índice. Caso não seja definido, é utilizado o padrão
$GIT_DIR/index
. -
GIT_INDEX_VERSION
-
Esta variável de ambiente especifica qual versão do índice é usada ao gravar o arquivo do índice. Isso não afetará os arquivos existentes no índice. É predefinido que seja usada a versão 2 ou 3 do arquivo do índice. Para mais informações consulte git-update-index[1].
-
GIT_OBJECT_DIRECTORY
-
Caso o diretório de armazenamento dos objetos seja informado através desta variável de ambiente, os diretórios sha1 serão criados embaixo - caso contrário, o diretório predefinido
$GIT_DIR/objects
será utilizado. -
GIT_ALTERNATE_OBJECT_DIRECTORIES
-
Devido à natureza imutável dos objetos Git, os objetos antigos podem ser arquivados em diretórios compartilhados com somente leitura apenas. Esta variável especifica uma lista ":" separada (no Windows ";") dos diretórios dos objetos Git que podem ser utilizados para localizar objetos Git. Os novos objetos não serão gravados nestes diretórios.
As entradas que começam com
"
(aspas duplas) serão interpretadas como caminhos entre as aspas no estilo C, removendo as aspas duplas iniciais e finais, respeitando as escapes da barra invertida. Como por exemplo, o valor"path-with-\"-and-:-in-it":vanilla-path
possuí dois caminhos:path-with-"-and-:-in-it
evanilla-path
. -
GIT_DIR
-
Se a variável de ambiente
GIT_DIR
for definida, ela especificará um caminho que será usada para a base do repositório em vez do padrão.git
. A opção de linha de comando--git-dir
também define este valor. -
GIT_WORK_TREE
-
Defina o caminho para a raiz da árvore de trabalho. Isso também pode ser controlado pela opção de linha de comando
--work-tree
e pela variável de configuraçãocore.worktree
. -
GIT_NAMESPACE
-
Defina o espaços de nomes do Git; para mais detalhes consulte gitnamespaces[7]. A opção de linha de comando
--namespace
também define este valor. -
GIT_CEILING_DIRECTORIES
-
Essa deve ser uma lista de caminhos absolutos separados por dois-pontos. Se definido, é uma lista de diretórios para os quais o Git não deve fazer um chdir ao procurar pelo diretório do repositório (útil para excluir diretórios de rede com carregamento lento). Ele não excluirá o diretório de trabalho atual ou um
GIT_DIR
definido na linha de comando ou no ambiente. Normalmente, o Git precisa ler os itens dessa lista e resolver qualquer link simbólico que possa estar presente para compará-los com o diretório atual. No entanto, se mesmo esse acesso for lento, você pode adicionar uma entrada vazia à lista para informar ao Git que as entradas subsequentes não são links simbólicos e não precisam ser resolvidas; por exemplo,GIT_CEILING_DIRECTORIES=/maybe/symlink::/very/slow/non/symlink
. -
GIT_DISCOVERY_ACROSS_FILESYSTEM
-
Quando executado num diretório que não tenha um diretório de repositório .git, o Git tenta encontrar esse diretório nos diretórios pai para encontrar o cume da árvore de trabalho, mas, por padrão, ele não cruza os limites do sistema de arquivos. Essa variável de ambiente booleana pode ser definida como true para dizer ao Git para não parar nos limites do sistema de arquivos. Assim como o
GIT_CEILING_DIRECTORIES
, isso não afetará um diretório de repositório explícito definido viaGIT_DIR
ou na linha de comando. -
GIT_COMMON_DIR
-
Se essa variável estiver definida para um caminho, os arquivos que não são da árvore de trabalho, estão normalmente estão em $GIT_DIR e serão obtidos desse caminho. Os arquivos específicos da árvore de trabalho, como
HEAD
ou índice serão obtidos de $GIT_DIR. Para mais detalhes consulte gitrepository-layout[5] e git-worktree[1]. Essa variável tem precedência mais baixa do que outras variáveis de caminho comoGIT_INDEX_FILE
,GIT_OBJECT_DIRECTORY
… -
GIT_DEFAULT_HASH
-
Se essa variável for definida, o algoritmo de hash predefinido para os novos repositórios será definido com este valor. Esse valor é ignorado durante a clonagem e a configuração do repositório remoto é sempre usada. A predefinição é sha1. Consulte a opção
--object-format
do comando git-init[1]. -
GIT_DEFAULT_REF_FORMAT
-
Se esta variável for definida, o formato padrão do "backend" de referência para os novos repositórios será definido com esse valor. A predefinição é files. Consulte a opção
--ref-format
do comando git-init[1].
Os Commits do Git
-
GIT_AUTHOR_NAME
-
O endereço legível do endereço de e-mail utilizado na identidade do autor ao criar os commits, na tag dos objetos ou ao gravar os reflogs. Substitui as definições de configuração
user.name
eauthor.name
. -
GIT_AUTHOR_EMAIL
-
O endereço de email utilizado na identidade do autor ao criar os commits, na marcação dos objetos ou ao gravar os reflogs. Substitui as definições da configuração
user.email
eauthor.email
. -
GIT_AUTHOR_DATE
-
A data utilizada para a identidade do autor ao criar objetos commit ou tags ou quando escrever "reflogs". Para conhecer os formatos válidos, consulte git-commit[1].
-
GIT_COMMITTER_NAME
-
O endereço legível do nome utilizado na identidade do autor do commit ao criar os commits, na tag dos objetos ou ao gravar os reflogs. Substitui as definições de configuração
user.name
ecommitter.name
. -
GIT_COMMITTER_EMAIL
-
O endereço de email utilizado na identidade do autor ao criar os commits, na marcação dos objetos ou ao gravar os reflogs. Overrides the
user.email
andcommitter.email
configuration settings. -
GIT_COMMITTER_DATE
-
A data utilizada para a identidade de quem fez o commit durante a criação dos objetos as tags do commit ou ao gravar os reflogs. Para mais formatos válidos, consulte git-commit[1].
-
EMAIL
-
O endereço de e-mail usado nas identidades do autor e do commit, caso nenhuma outra variável de ambiente ou da configuração relevante tiver sido definida.
Os Diffs do Git
-
GIT_DIFF_OPTS
-
A única configuração válida é
--unified=??
ou-u??
para definir a quantidade de linhas de contexto exibidas quando um diff unificado for criado. Isso tem precedência sobre qualquer valor da opção-U
ou--unified
usado na linha de comando do Git diff. -
GIT_EXTERNAL_DIFF
-
Quando a variável de ambiente
GIT_EXTERNAL_DIFF
é definida, o programa nomeado por ela é invocado para gerar diferenças, e o Git não usa seu mecanismo de diferenças embutido. Para um caminho que for adicionado, removido ou modificado, oGIT_EXTERNAL_DIFF
é invocado com 7 parâmetros:path old-file old-hex old-mode new-file new-hex new-mode
onde:
- <old|new>-file
-
são os arquivos que
GIT_EXTERNAL_DIFF
pode utilizar para ler o conteúdo do <antigo|novo>, - <old|new>-hex
-
são os hashes SHA-1 com 40 hexadecimais,
- <old|new>-mode
-
são a representação octais dos modos dos arquivos.
Os parâmetros do arquivo podem apontar para o arquivo de trabalho do usuário (
new-file
em git-diff-files por exemplo),/dev/null
(old-file
quando um novo arquivo é adicionado por exemplo) ou um arquivo temporário (old-file
no índice por exemplo). OGIT_EXTERNAL_DIFF
não deve se preocupar em desvincular o arquivo temporário - ele é removido quando oGIT_EXTERNAL_DIFF
for encerrado.Para um caminho que não foi mesclado,
GIT_EXTERNAL_DIFF
é chamado com 1 parâmetro, <caminho>.Para cada caminho
GIT_EXTERNAL_DIFF
que é chamado, duas variáveis de ambiente,GIT_DIFF_PATH_COUNTER
eGIT_DIFF_PATH_TOTAL
são definidas. -
GIT_EXTERNAL_DIFF_TRUST_EXIT_CODE
-
If this Boolean environment variable is set to true then the
GIT_EXTERNAL_DIFF
command is expected to return exit code 0 if it considers the input files to be equal or 1 if it considers them to be different, likediff(1)
. If it is set to false, which is the default, then the command is expected to return exit code 0 regardless of equality. Any other exit code causes Git to report a fatal error. -
GIT_DIFF_PATH_COUNTER
-
Um contador com base 1 incrementado por um em cada caminho.
-
GIT_DIFF_PATH_TOTAL
-
A quantidade total dos caminhos.
Outros
-
GIT_MERGE_VERBOSITY
-
Um número que controla a quantidade de saída exibida pela estratégia de mesclagem recursiva. Substitui o
merge.verbosity
. Consulte o comando git-merge[1] -
GIT_PAGER
-
Esta variável de ambiente substitui a variável
$PAGER
. Se for definido como uma string vazia ou com o valor cat, o Git não iniciará um gerenciador. Consulte também a opçãocore.pager
do comando git-config[1]. -
GIT_PROGRESS_DELAY
-
Um número que controla quantos segundos atrasar antes de mostrar os indicadores opcionais do progresso. A predefinição retorna para
2
. -
GIT_EDITOR
-
Essa variável de ambiente substitui
$EDITOR
e$VISUAL
. Ele é usado por vários comandos do Git quando, no modo interativo, um editor tiver que ser iniciado. Consulte também git-var[1] e a opçãocore.editor
do comando git-config[1]. -
GIT_SEQUENCE_EDITOR
-
Esta variável de ambiente substitui a configuração do editor do Git ao editar a lista de tarefas de um rebase interativo. Consulte também o comando git-rebase[1] e a opção
sequence.editor
em git-config[1]. -
GIT_SSH
-
GIT_SSH_COMMAND
-
Se uma dessas variáveis de ambiente estiver definida, o git fetch e o git push usarão o comando especificado em vez do ssh quando precisarem se conectar a um sistema remoto. Os parâmetros da linha de comando passados para o comando configurado são determinados pela variante ssh. Para mais detalhes consulte a opção
ssh.variant
do comando git-config[1].O
$GIT_SSH_COMMAND
tem precedência sobre o$GIT_SSH
e é interpretado pelo shell, o que permite a inclusão de argumentos adicionais. O$GIT_SSH
, por outro lado, deve ser apenas o caminho para um programa (que pode ser um script de shell de proteção, caso argumentos adicionais sejam necessários).Normalmente, é mais fácil configurar as opções desejadas através do seu arquivo pessoal
.ssh/config
. Consulte a documentação do ssh para obter mais informações. -
GIT_SSH_VARIANT
-
Se esta variável de ambiente estiver configurada, ela substitui a detecção automática do Git, caso
GIT_SSH
/GIT_SSH_COMMAND
/core.sshCommand
se refere ao OpenSSH, plink ou tortoiseplink. Esta variável substitui a configuraçãossh.variant
que serve ao mesmo propósito. -
GIT_SSL_NO_VERIFY
-
Ao definir e exportar essa variável de ambiente para qualquer valor, informa ao Git para não verificar o certificado SSL ao buscar ou enviar via HTTPS.
-
GIT_ATTR_SOURCE
-
Define a árvore da qual os gitattributes serão lidos.
-
GIT_ASKPASS
-
Se essa variável de ambiente for definida, os comandos do Git que precisarem obter senhas ou frases-senha (por exemplo, para autenticação HTTP ou IMAP) invocarão este programa com um prompt adequado como argumento de linha de comando e lerão a senha de seu STDOUT. Consulte também a opção
core.askPass
do comando git-config[1]. -
GIT_TERMINAL_PROMPT
-
Caso esta variável de ambiente boleana esteja definida como
false
, o git não será solicitado no terminal (ao solicitar uma autenticação HTTP por exemplo). -
GIT_CONFIG_GLOBAL
-
GIT_CONFIG_SYSTEM
-
Obtenha a configuração dos arquivos fornecidos em vez dos arquivos de configuração globais ou em nível de sistema. Se o
GIT_CONFIG_SYSTEM
for definido, o arquivo de configuração do sistema definido no momento da compilação (geralmente/etc/gitconfig
) não será lido. Da mesma maneira, se oGIT_CONFIG_GLOBAL
for definido, nem$HOME/.gitconfig
nem$XDG_CONFIG_HOME/git/config
serão lidos. Pode ser definido como/dev/null
para ignorar a leitura de arquivos de configuração do respectivo nível. -
GIT_CONFIG_NOSYSTEM
-
Se deve ignorar a leitura das configurações do arquivo
$(prefix)/etc/gitconfig
de todo o sistema. Esta variável de ambiente booleana pode ser usada junto com$HOME
e$XDG_CONFIG_HOME
para criar um ambiente previsível para um script mais exigente, ou você pode defini-la como verdadeira para evitar temporariamente o uso de um arquivo/etc/gitconfig
com erros enquanto espera que alguém com permissões suficientes o conserte. -
GIT_FLUSH
-
Se essa variável de ambiente booleana for definida como true, comandos como git blame (no modo incremental), git rev-list, git log, git check-attr e git check-ignore irão impor uma descarga do fluxo de saída após cada registro ter sido descarregado. Se essa variável for definida como false, a saída desses comandos será feita usando a E/S que estiver armazenada no buffer. Se esta variável de ambiente não for definida, o Git escolherá a descarga com o buffer ou orientada a registros com base no fato do stdout parecer estar sendo redirecionado para um arquivo ou não.
-
GIT_TRACE
-
Ativa o rastreio geral das mensagens, por exemplo expansão do pseudônimo, execução interna dos comandos e a execução externa dos comandos.
Caso esta variável esteja definida como
1
,2
outrue
(a comparação não diferencia as maiúsculas das minúsculas), as mensagens de rastreio serão impressas no stderr.Caso a variável seja configurada com um valor inteiro maior que 2 e menor que 10 (estritamente), o Git interpretará este valor como um descritor de arquivo aberto e tentará gravar as mensagens de monitoramento neste descritor do arquivo.
Como alternativa, caso a variável estiver definida como um caminho absoluto (começando com um caractere /), o Git interpretará isso como um caminho do arquivo e tentará anexar as mensagens de rastreio nelas.
Desativar a variável ou defini-la como vazia 0 ou false (não faz distinção entre maiúsculas e minúsculas) desativa as mensagens de monitoramento.
-
GIT_TRACE_FSMONITOR
-
Ativa as mensagens de rastreamento para a extensão do monitor de arquivos do sistema. Consulte o
GIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_PACK_ACCESS
-
Ativa as mensagens de rastreamento para todos os acessos a qualquer pacote. Para cada acesso, são registrados o nome do arquivo do pacote e o offset. Isso pode ser útil para solucionar alguns problemas de desempenho relacionados ao pacote. Consulte o
GIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_PACKET
-
Ativa as mensagens de rastreamento para todos os pacotes que entram ou saem de um determinado programa. Isso pode ajudar a depurar a negociação de objetos ou de outros problemas de protocolo. O rastreamento é desativado num pacote que começa com "PACK" (consulte o
GIT_TRACE_PACKFILE
abaixo). Consulte oGIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_PACKFILE
-
Permite o monitoramento dos arquivos dos pacotes enviados ou recebidos através de um determinado programa. Diferente de outras saídas monitoradas, esse monitoramento é literalmente: sem cabeçalhos e sem a citação dos dados binários. Você quase que certamente vai querer direcionar para um arquivo (
GIT_TRACE_PACKFILE=/tmp/my.pack
por exemplo) em vez de exibi-lo no terminal ou misturá-lo com uma outra saída monitorada.Observe que atualmente isso é implementado apenas para o lado do cliente dos clones e das buscas.
-
GIT_TRACE_PERFORMANCE
-
Ativa as mensagens de rastreamento relacionadas ao desempenho, como o tempo total de execução de cada comando do Git por exemplo. Consulte o
GIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_REFS
-
Ativa as mensagens de rastreamento para as operações no banco de dados de referência. Consulte o
GIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_SETUP
-
Permite que as mensagens de rastreamento imprimam o .git, a árvore de trabalho e o diretório de trabalho atual depois que o Git tiver concluído a sua fase de configuração. Consulte o
GIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_SHALLOW
-
Ativa asmensagens de rastreamento que possam ajudar a depurar a busca/clonagem dos repositórios rasos. Consulte o
GIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_CURL
-
Ativa um curl que faz um dump de rastreamento completo de todos os dados da entrada e da saída, incluindo informações descritivas, do protocolo de transporte git. Isso é semelhante a fazer curl
--trace-ascii
na linha de comando. Consulte oGIT_TRACE
para consultar as opções de rastreamento disponíveis. -
GIT_TRACE_CURL_NO_DATA
-
Quando um rastreamento curl está ativado (consulte
GIT_TRACE_CURL
acima), não despeje os dados (ou seja, apenas despeje as linhas de informações e os cabeçalhos). -
GIT_TRACE2
-
Ativa as mensagens de rastreamento mais detalhadas da biblioteca "trace2". A saída do
GIT_TRACE2
é um formato simples com base em texto para facilitar a leitura humana.Caso esta variável esteja definida como
1
,2
outrue
(a comparação não diferencia as maiúsculas das minúsculas), as mensagens de rastreio serão impressas no stderr.Caso a variável seja configurada com um valor inteiro maior que 2 e menor que 10 (estritamente), o Git interpretará este valor como um descritor de arquivo aberto e tentará gravar as mensagens de monitoramento neste descritor do arquivo.
Como alternativa, se a variável for definida como um caminho absoluto (começando com um caractere /), o Git interpretará isso como um caminho de arquivo e tentará anexar as mensagens de rastreamento a ele. Se o caminho já existir e for um diretório, as mensagens de rastreamento serão gravadas em arquivos (um por processo) neste diretório, nomeados de acordo com o último componente do SID e um contador opcional (para evitar colisões de nomes de arquivos).
Além disso, se a variável for definida como
af_unix:[<tipo-do-soquete>:]<nome-do-caminho-completo>
, o Git tentará abrir o caminho como um Unix Domain Socket. O tipo de soquete pode serstream
oudgram
.Desativar a variável ou defini-la como vazia 0 ou false (não faz distinção entre maiúsculas e minúsculas) desativa as mensagens de monitoramento.
Para mais detalhes, consulte Trace2 documentation.
-
GIT_TRACE2_EVENT
-
Esta configuração grava um formato baseado em JSON que é adequado para interpretação por máquina. Consulte
GIT_TRACE2
para obter as opções disponíveis de saída do rastreamento e Documentação do Trace2 para consultar todos os detalhes. -
GIT_TRACE2_PERF
-
Além das mensagens com base em texto disponíveis no
GIT_TRACE2
, esta configuração grava um formato baseado em colunas para entender as regiões de aninhamento. ConsulteGIT_TRACE2
para obter as opções disponíveis de saída do rastreamento e Documentação do Trace2 para consultar todos os detalhes. -
GIT_TRACE_REDACT
-
É predefinido que quando o monitoramento seja ativado, o Git redita os valores dos cookies, o cabeçalho "Autorização:" o cabeçalho e o URI do arquivo do pacote "Autorização do proxy:". Defina esta variável de ambiente boleana como
false
para evitar esta redação. -
GIT_NO_REPLACE_OBJECTS
-
Setting and exporting this environment variable tells Git to ignore replacement refs and do not replace Git objects.
-
GIT_LITERAL_PATHSPECS
-
Ao definir essa variável de ambiente boleana como
true
fará com que o Git trate todos os pathspecs de forma literal, e não como padrões glob. Como, por exemplo, a execução doGIT_LITERAL_PATHSPECS=1 git log -- '*.c'
procurará pelos commits que tocam no caminho*.c
e não nos caminhos que coincidem com o agrupamento*.c
. Você pode querer isso caso esteja alimentando caminhos literais para o Git (por exemplo, os caminhos informados anteriormente a você pelogit ls-tree
,--raw
, saída do diff, etc). -
GIT_GLOB_PATHSPECS
-
Ao definir essa variável de ambiente boleana como
true
fará com que o Git trate todos os pathspecs como padrões "glob" (também informados como "glob" mágico). -
GIT_NOGLOB_PATHSPECS
-
Ao definir essa variável de ambiente boleana como
true
fará com que o Git trate todos os pathspecs como literal (também informados como mágica "literal"). -
GIT_ICASE_PATHSPECS
-
Ao definir essa variável de ambiente boleana como
true
fará com que o Git trate todos os pathspecs como indiferente para maiúsculas e minúsculas. -
GIT_NO_LAZY_FETCH
-
Setting this Boolean environment variable to true tells Git not to lazily fetch missing objects from the promisor remote on demand.
-
GIT_REFLOG_ACTION
-
Quando uma ref é atualizada, são criadas entradas de reflog para manter o controle do motivo pelo qual a ref foi atualizada (que normalmente é o nome do comando de alto nível que atualizou a ref), além dos valores antigos e novos da ref. Um comando porcelana com script pode usar a função auxiliar set_reflog_action no
git-sh-setup
para definir seu nome para essa variável quando for invocado como o comando de nível superior pelo usuário final, a ser registrado no corpo do reflog. -
GIT_REF_PARANOIA
-
Caso essa variável de ambiente boleana seja definida como
false
, ignore os refs quebrados ou mal nomeados ao iterar sobre as listas dos refs. Normalmente o Git tentará incluir qualquer um desses refs, o que pode causar a falha de algumas operações. Isto normalmente é preferível, já que as operações potencialmente destrutivas (como git-prune[1]) são melhores abortando em vez de ignorar os refs quebrados (e assim considerando o histórico que eles apontam como não valendo a pena salvar). O valor predefinido étrue
(ou seja, ser paranoico ao detectar e abortar todas as operações). Normalmente não é preciso definir isso comofalse
, mas pode ser útil ao tentar salvar os dados de um repositório corrompido. -
GIT_COMMIT_GRAPH_PARANOIA
-
Ao carregar um objeto commit do gráfico do commit-graph, o Git executa uma verificação de existência do objeto no banco de dados. Isso é feito para evitar problemas com commit-graphs obsoletos que contêm referências a commits que já foram excluídos, ao custo de uma penalidade no desempenho.
A predefinição é false, que desativa o comportamento mencionado acima. Ativa a verificação de existência para que os commits que estejam desatualizados nunca sejam retornados do commit-graph, ao custo de uma penalidade no desempenho.
-
GIT_ALLOW_PROTOCOL
-
Caso seja definido como uma lista de protocolos separados por dois pontos, comporte-se como se a opção de configuração
protocol.allow
esteja definida comonever
, e cada um dos protocolos listados possuaprotocol.<nome>.allow
definido comoalways
(substituindo qualquer configuração já existente). Consulte a descrição doprotocol.allow
no git-config[1] para obter mais detalhes. -
GIT_PROTOCOL_FROM_USER
-
Defina esta variável booleana de ambiente como false para evitar que os protocolos usados por
fetch/push/clone
sejam configurados para o estadouser
. Isso é útil para restringir a inicialização recursiva de submódulos a partir de um repositório não confiável ou para programas que alimentam URLS potencialmente não confiáveis para os comandos do git. Para mais detalhes consulte git-config[1]. -
GIT_PROTOCOL
-
For internal use only. Used in handshaking the wire protocol. Contains a colon : separated list of keys with optional values <key>[=<value>]. Presence of unknown keys and values must be ignored.
Observe que os servidores podem precisar ser configurados para permitir que esta variável passe por alguns transportes. Ele será propagado automaticamente ao acessar os repositórios locais (ou seja,
file://
ou um caminho do sistema de arquivos), bem como sobre o protocologit://
. Para git-over-http, ele deve funcionar automaticamente na maioria das configurações, porém consulte git-http-backend[1]. Para git-over-ssh, o servidor ssh pode precisar ser configurado para permitir que os clientes passem esta variável (por exemplo, usandoAcceptEnv GIT_PROTOCOL
com o OpenSSH).Esta configuração é opcional. Caso a variável não seja propagada, os clientes voltarão ao protocolo "v0" original (mas podem perder algumas melhorias de desempenho ou de recursos). Atualmente esta variável afeta apenas os clones e as buscas (fetch); ainda não é usado para envios "push" (mas pode ser no futuro).
-
GIT_OPTIONAL_LOCKS
-
Se essa variável de ambiente booleana for definida como false, o Git concluirá qualquer operação solicitada sem executar nenhuma suboperação opcional que exija um bloqueio. Por exemplo, como um efeito colateral, isso impedirá que o
git status
atualize o índice. Isso é útil para processos executados em segundo plano que não queiram causar contenção de bloqueio com outras operações no repositório. A predefinição é1
. -
GIT_REDIRECT_STDIN
-
GIT_REDIRECT_STDOUT
-
GIT_REDIRECT_STDERR
-
Apenas no Windows: permite redirecionar os identificadores predefinidos de input/output/error para os caminhos definidos através das variáveis do ambiente. Em particular isso é útil nos aplicativos "multi-threaded" onde a maneira canônica de encaminhar os identificadores predefinidos através do
CreateProcess()
não seja uma opção pois exigiria que os identificadores fossem marcados como herdáveis (e consequentemente todo processo gerado os herdaria, possivelmente fazendo o bloqueio das operações do Git). A intenção primária de utilização é utilizar os pipes informados para comunicação (\\.\pipe\my-git-stdin-123
por exemplo).Dois valores especiais são compatíveis:
off
simplesmente fechará o identificador predefinido correspondente e casoGIT_REDIRECT_STDERR
seja2> & 1
, a predefinição do erro será redirecionado para o mesmo identificador na saída padrão. -
GIT_PRINT_SHA1_ELLIPSIS
(descontinuado) -
Se definido como
yes
, imprime uma elipse após um valor SHA-1 (abreviado). Isso afeta as indicações de `HEAD`s desanexados (git-checkout[1]) e a criação de um diff puro (git-diff[1]). A impressão de reticências nos casos mencionados não é mais considerada adequada e o suporte para isso provavelmente será removido num futuro próximo (junto com a variável). -
GIT_ADVICE
-
If set to
0
, then disable all advice messages. These messages are intended to provide hints to human users that may help them get out of problematic situations or take advantage of new features. Users can disable individual messages using theadvice.*
config keys. These messages may be disruptive to tools that execute Git processes, so this variable is available to disable the messages. (The--no-advice
global option is also available, but old Git versions may fail when this option is not understood. The environment variable will be ignored by Git versions that do not understand it.)
Discussão
Mais detalhes estão disponíveis no capítulo dos conceitos do Git no manual do usuário e gitcore-tutorial[7].
Um projeto Git normalmente consiste num diretório de trabalho com um subdiretório .git no nível mais alto. O diretório .git contém, entre outras coisas, um banco de dados dos objetos compactado que representa o histórico completo do projeto, um arquivo index (índice) que vincula este histórico ao conteúdo atual da árvore de trabalho e os ponteiros nomeados neste histórico, como as etiquetas (tags) e os cabeçalhos da ramificação.
O banco de dados do objeto contém os objetos dos tipos da árvore principal: bolhas, que contêm os dados do arquivo; árvores, que apontam para as bolhas e as outras árvores para criar as hierarquias do diretório; e os commits, cada qual faz referência a uma única árvore e algum número do commit do pai.
O commit, equivalente ao que outros sistemas chamam de conjunto de alterações ou versão, representa uma etapa no histórico do projeto, e cada ramo principal (parent) representa uma etapa imediatamente anterior. Os commits com mais de um ramo principal representam as mesclagens das linhas independentes do desenvolvimento.
Todos os objetos são nomeados pelo hash SHA-1 de seu conteúdo, normalmente escrito como uma cadeia de 40 dígitos hexadecimais. Estes nomes são únicos globalmente. Todo o histórico que leva a um commit pode ser comprovado assinando apenas este commit. Um quarto tipo de objeto, a etiqueta (tag), é fornecida para esta finalidade.
Quando criados pela primeira vez, os objetos são armazenados em arquivos individuais, porém, visando uma maior eficiência, podem ser compactados posteriormente em "pacotes de arquivos".
Os ponteiros mencionados chamados de refs marcam pontos interessantes na história. Uma ref pode conter o nome do SHA-1 de um objeto ou o nome de outra ref (esta última é chamada de "ref simbólica" (symbolic ref)). As refs com nomes que começam com refs/head/
contêm o nome SHA-1 do commit mais recente (ou cabeçalho HEAD) de uma ramificação em desenvolvimento. Os nomes SHA-1 das etiquetas de interesse são armazenados em refs/tags/
. Uma ref simbólica denominada HEAD
contém o nome do ramo atualmente submetido ao check-out.
O arquivo do índice é inicializado com uma lista de todos os caminhos e, para cada caminho, um objeto bolha (blob) e um conjunto de atributos. O objeto bolha (blob) representa o conteúdo do arquivo a partir do cabeçalho da ramificação atual. Os atributos (hora da última alteração, tamanho, etc.) são obtidos do arquivo correspondente na árvore de trabalho. As alterações subsequentes na árvore de trabalho podem ser encontradas através da comparação destes atributos. O índice pode ser atualizado com um novo conteúdo, e novos commits podem ser criados a partir do conteúdo armazenado no índice.
O índice também é capaz de armazenar várias entradas (chamadas de "stages" ou "estágios") para um determinado nome do caminho. Estes estágios são usados para manter as várias versões não mescladas de um arquivo quando uma mesclagem já estiver em andamento.
SEGURANÇA
Some configuration options and hook files may cause Git to run arbitrary shell commands. Because configuration and hooks are not copied using git clone
, it is generally safe to clone remote repositories with untrusted content, inspect them with git log
, and so on.
However, it is not safe to run Git commands in a .git
directory (or the working tree that surrounds it) when that .git
directory itself comes from an untrusted source. The commands in its config and hooks are executed in the usual way.
By default, Git will refuse to run when the repository is owned by someone other than the user running the command. See the entry for safe.directory
in git-config[1]. While this can help protect you in a multi-user environment, note that you can also acquire untrusted repositories that are owned by you (for example, if you extract a zip file or tarball from an untrusted source). In such cases, you’d need to "sanitize" the untrusted repository first.
If you have an untrusted .git
directory, you should first clone it with git clone --no-local
to obtain a clean copy. Git does restrict the set of options and hooks that will be run by upload-pack
, which handles the server side of a clone or fetch, but beware that the surface area for attack against upload-pack
is large, so this does carry some risk. The safest thing is to serve the repository as an unprivileged user (either via git-daemon[1], ssh, or using other tools to change user ids). See the discussion in the SECURITY
section of git-upload-pack[1].
DOCUMENTAÇÃO ADICIONAL
Consulte as referências na seção "descrição" para começar a usar o Git. Os detalhes a seguir provavelmente são maiores do que o necessário para um usuário iniciante.
O capítulo de conceitos do Git do manual do usuário e o gitcore-tutorial[7] fornecem introduções à arquitetura subjacente do Git.
Para obter uma visão geral das recomendações do fluxo de trabalho, consulte gitworkflows[7].
Para mais alguns exemplos úteis, consulte também o documento howto.
As entranhas estão documentadas no Documentação da API do Git.
Os usuários que estiverem migrando do CVS também podem querer ler gitcvs-migration[7].
Autores
O Git foi criado por Linus Torvalds e atualmente é mantido por Junio C Hamano. Várias contribuições vieram da lista de discussão do Git <git@vger.kernel.org>. O site https://openhub.net/p/git/contributors/summary fornece uma lista mais completa dos colaboradores.
Caso tenha um clone do git.git, a saída do git-shortlog[1] e do git-blame[1] pode exibir os autores para as partes específicas do projeto.
Reportando um Erro
Relate os erros na lista de discussão do Git <git@vger.kernel.org>, onde o desenvolvimento principal e a manutenção são feitas. Não é necessário estar inscrito na lista para enviar uma mensagem para lá. Consulte o arquivo da lista em https://lore.kernel.org/git para ver relatórios de erros anteriores além de outras discussões.
Os problemas relevantes para a segurança devem ser divulgadas em particular na mailing list do Git Security <git-security@googlegroups.com>.
GIT
Parte do conjunto git[1]