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.44.1 → 2.46.0 no changes
- 2.44.0 02/23/24
- 2.43.1 → 2.43.5 no changes
- 2.43.0 11/20/23
RESUMO
git replace [-f] <objeto> <rearranjo> git replace [-f] --edit <objeto> git replace [-f] --graft <commit> [<origem >…] git replace [-f] --convert-graft-file git replace -d <objeto>… git replace [--format=<formato>] [-l [<padrão>]]
DESCRIÇÃO
Adiciona uma referência replace (substituir) no espaço de nomes
refs/replace/
.
O nome da referência replace é o SHA-1 do objeto que é substituído. O conteúdo da referência replace é o SHA-1 do objeto de reposição.
O objeto substituído e o objeto de reposição devem ser do mesmo tipo. Esta
restrição pode ser contornada utilizando a opção -f
.
A menos que -f seja utilizado, a referência replace ainda não deve existir.
Não há outra restrição nos objetos substituídos e os objetos de reposição. Os commits mesclados podem ser substituídos por commits sem mesclagem e vice-versa.
É predefinido que as referências de reposição seja utilizadas por todos os comandos do Git, exceto aqueles que executem o percurso de acessibilidade (remoção "prune", transferência de pacotes "pack transfer" e "fsck").
É possível desativar o uso do rearranjo das referências para qualquer
comando utilizando a opção --no-replace-objects
logo após o git.
Como por exemplo, caso o commit foo foi substituído pelo commit bar:
$ git --no-replace-objects cat-file commit foo
exibe as informações sobre o commit foo, enquanto:
$ git cat-file commit foo
exibe as informações sobre o commit bar.
A variável de ambiente GIT_NO_REPLACE_OBJECTS
pode ser configurada para
obter o mesmo efeito que a opção --no-replace-objects
.
OPÇÕES
- -f
- --force
-
Caso exista uma "ref" de reposição existente para o mesmo objeto, ela será substituída (em vez de falhar).
- -d
- --delete
-
Exclua as refs de reposição existentes para os objetos informados.
- --edit <objeto>
-
Edita o conteúdo de um objeto interativamente. O conteúdo existente para
<objeto>
é impresso em um arquivo temporário, um editor é iniciado no arquivo e o resultado é analisado para criar um novo objeto do mesmo tipo que<objeto>
. Umref
de reposição é criado para substituir<objeto>
com um objeto recém-criado. Para mais detalhes de como o editor será selecionado, consulte git-var[1]. - --raw
-
Ao editar, forneça o conteúdo do objeto bruto, em vez do impresso bonito. Atualmente afeta apenas as árvores que serão exibidas na sua forma binária. É mais difícil trabalhar com isso, porém pode ajudar durante o reparo de uma árvore que está tão corrompida que não pode ser bem impressa. Observe que pode ser necessário configurar o seu editor para ler e gravar os dados binários de forma limpa.
- --graft <commit> [<origem>…]
-
Cria um commit com enxerto. Um novo commit é criado com o mesmo conteúdo de
<commit>
exceto que as suas origens serão [<origem>…] em vez do <commit> das origens. Uma ref de reposição é então criada para substituir o<commit>
pelo commit recém-criado. Utilize--convert-graft-file
para converter um arquivo$GIT_DIR/info/grafts
e utilize as refs de reposição em seu lugar. - --convert-graft-file
-
Cria commits com enxertos para todas as entradas em
$GIT_DIR/info/grafts
e exclui este arquivo quando for bem sucedido. O objetivo é ajudar os usuários a fazer a transição do arquivo de enxerto agora, obsoleto. - -l <padrão>
- --list <padrão>
-
A lista substitui as refs para os objetos que coincidam ao padrão informado (ou todos caso nenhum seja informado). Digitar "git replace" sem argumentos, também lista todos as refs de reposição.
- --format=<formato>
-
Ao listar, utilize o <formato> informado, que pode ser short (curto), medium (médio) e long (longo). Quando omitido, a predefinição retorna para o formato short.
FORMATOS
O seguinte formato está disponível:
-
short: <replaced sha1>
-
medium: <replaced sha1> → <replacement sha1>
-
long: <sha1 substituído> (<tipo substituído>) → <sha1 substituído> (<tipo substituído>)
CRIANDO OBJETOS DE SUBSTITUIÇÃO
O git-hash-object[1], git-rebase[1], e
git-filter-repo, dentre outros
comandos git podem ser utilizados para criar a reposição dos objetos a
partir dos objetos já existentes. A opção --edit
também pode ser usada com
git replace para criar a reposição de um objeto editando um objeto já
existente.
Caso queira substituir várias bolhas, árvores ou commits que fazem parte de uma cadência de commits, você pode apenas criar uma cadência de reposição dos commits e então substituir apenas o commit no topo da cadeia alvo dos commits pelos commits do topo da cadência de substituições dos commits.
BUGS
Comparando as bolhas ou as árvores que foram substituídos por aqueles que os
substituem, não funcionará de forma correta. E utilizar o comando git reset
--hard
para voltar para um commit que foi reposto, moverá o ramo para o
commit que foi substituído em vez do commit que foi resposto.
Pode haver outros problemas durante a utilização do comando git rev-list relacionadas com objetos pendentes.
GIT
Parte do conjunto git[1]