Skip to main content

Sobre como comparar branches nas pull requests

As pull requests exibem diffs para comparar as alterações feitas no branch de tópico com o branch base com o qual você deseja fazer merge.

Note

Ao criar sua pull request, você pode alterar o branch base com o qual está comparando as alterações. Para obter mais informações, confira "Como criar uma solicitação de pull".

Você pode ver as alterações propostas em uma solicitação de pull na guia Arquivos alterados. Captura de tela das guias de uma solicitação de pull. A guia "Arquivos alterados" está contornada em laranja escuro.

Em vez de exibir os commits em si, você pode ver as alterações propostas como elas aparecerão nos arquivos assim que a pull request passar pelo merge. Os arquivos são exibidos em ordem alfabética na guia Arquivos alterados. As adições aos arquivos são exibidas em verde e são precedidas por um sinal +, enquanto o conteúdo que foi removido é exibido em vermelho e é precedido por um sinal -.

Opções de exibição de diff

Tip

Se você estiver tendo dificuldades em entender o contexto de uma alteração, clique em View na guia Files alterados para ver todo o arquivo com as alterações propostas.

Há várias opções de exibição de um diff:

  • A exibição unificada mostra conteúdo atualizado e existente juntos em uma exibição linear.
  • A exibição dividida mostra conteúdo antigo em um lado e novo conteúdo do outro lado.
  • A exibição de diff avançado mostra uma visualização da aparência das alterações depois que a pull request passar por merge.
  • A exibição da origem mostra as alterações na origem sem a formatação da exibição de diff avançado.

Também é possível optar por ignorar alterações de espaço em branco para obter uma exibição mais precisa das alterações importantes em uma pull request.

Captura de tela da guia "Arquivos alterados" de uma solicitação de pull. O menu "Exibição de comparação" está contornado em laranja escuro.

Para simplificar a revisão das alterações em um pull request extenso, é possível filtrar o diff para mostrar apenas os tipos de arquivo selecionados, mostrar arquivos dos quais você é CODEOWNER, ocultar arquivos que você já visualizou ou ocultar arquivos excluídos. Para obter mais informações, confira "Filtrar arquivos em uma pull request".

Captura de tela do menu suspenso de filtro de arquivo. O menu está expandido e contornado em laranja escuro.

Motivos pelos quais os diffs não serão exibidos

Comparações de diff do Git de três pontos e dois pontos

Há dois métodos de comparação para o comando git diff; dois pontos (git diff A..B) e três pontos (git diff A...B). As pull requests no GitHub mostram uma comparação de três pontos.

Comparação Git de três pontos

A comparação de três pontos mostra a diferença entre a confirmação comum mais recente de ambos os branchs (base de mesclagem) e a versão mais recente do branch do tópico.

Comparação Git de dois pontos

A comparação de dois pontos mostra a diferença entre o estado mais recente do branch base (por exemplo, main) e a versão mais recente do branch do tópico.

Para ver duas referências de committish em uma comparação de diff de dois pontos no GitHub, você pode editar o URL da página "Comparing changes" (Comparar alterações) do seu repositório. Para obter mais informações, confira "committish" no Glossário do Git do site do livro Pro Git.

Por exemplo, essa URL usa os códigos SHA reduzidos para comparar os commits f75c570 e 3391dcc: https://github.com/github-linguist/linguist/compare/f75c570..3391dcc.

Um diff de dois pontos compara duas referências de committish do Git, como SHAs ou IDs de objeto (OIDs, Object IDs), diretamente entre si. No GitHub, as referências de committish do Git em uma comparação de diff de dois pontos devem ser enviadas por push ao mesmo repositório ou para suas bifurcações.

Se desejar simular um diff de dois pontos em uma pull request e ver uma comparação entre as versões mais recentes de cada branch, você poderá fazer merge do branch base no branch de tópico, o que atualiza o último ancestral comum entre seus branches.

Para obter mais informações sobre os comandos do Git para comparar as alterações, confira "Opções de comparação do Git" no site do livro Pro Git.

Sobre a comparação de três pontos no GitHub

Como a comparação de três pontos se compara com a base de mesclagem, ela se concentra "no que uma pull request introduz".

Quando você usa uma comparação de dois pontos, ela muda quando o branch base é atualizado, mesmo que você não tenha feito nenhuma alteração no branch do tópico. Além disso, uma comparação de dois pontos se concentra no branch base. Isso significa que tudo o que você adicionar é exibido como ausente do branch base, como se fosse uma exclusão e vice-versa. Como resultado, as alterações que o branch de tópico introduz tornam-se ambíguas.

Por outro lado, comparando os branches usando a comparação de três pontos, as alterações no branch de tópico estarão sempre na comparação se o branch base for atualizado, pois ela mostra todas as alterações desde que os branches divergiram.

Mesclar com frequência

Para evitar ficar confuso, mescle o branch base (por exemplo, main) em seu branch de tópico com frequência. Ao mesclar o branch base, as comparações de dois pontos e três pontos mostradas são as mesmas. Recomendamos mesclar uma solicitação de pull o mais rápido possível. Isso incentiva os colaboradores a tornar as solicitações de pull menores, o que é recomendado em geral.

Leitura adicional