Skip to main content

Enterprise Server 3.15 está disponível no momento como versão release candidate.

Resolver um conflito de merge no GitHub

Você pode resolver conflitos de merge simples que envolvem alterações concorrentes na linha usando o editor de conflitos.

Você só pode resolver conflitos de merge no GitHub Enterprise Server causados por alterações concorrentes na linha, como quando as pessoas fazem alterações diferentes na mesma linha do mesmo arquivo em diferentes branches no seu repositório Git. Para todos os outros tipos de conflito de merge, você deve resolver o conflito localmente na linha de comando. Para obter mais informações, confira "Resolver um conflito de merge usando a linha de comando".

Se um administrador do site desabilitar o editor de conflitos de mesclagem em solicitações de pull entre repositórios, você não poderá usar o editor de conflitos no GitHub Enterprise Server e precisará resolver os conflitos de mesclagem na linha de comando. Por exemplo, se o editor de conflitos de merge estiver desabilitado, você não poderá usá-lo em uma pull request entre uma bifurcação e um repositório upstream.

Aviso: quando você resolve um conflito de mesclagem no GitHub Enterprise Server, todo o branch base da solicitação de pull é mesclado no branch principal. Verifique se você deseja realmente fazer commit para esse branch. Se o branch do cabeçalho for o branch-padrão do seu repositório, você terá a opção de criar um novo branch para servir como o branch do cabeçalho para o seu pull request. Se o branch head estiver protegido, você não será capaz de mesclar sua resolução de conflitos nele, então você será solicitado a criar um novo branch head. Para obter mais informações, confira "Sobre branches protegidos".

  1. Abaixo do nome do repositório, clique em Solicitações de pull.

    Captura de tela da página principal de um repositório. Na barra de navegação horizontal, uma guia, rotulada como "Solicitações de pull", é destacada em laranja escuro.

  2. Na lista "Pull Requests", clique na pull request que tem um conflito de merge que você deseja resolver.

  3. Na parte inferior da solicitação de pull, clique em Resolver conflitos.

    Captura de tela de um aviso indicando que uma solicitação de pull tem um conflito de mesclagem. O botão "Resolver conflitos de mesclagem" está contornado em laranja escuro.

    Observação: se o botão Resolver conflitos está desativado, o conflito de mesclagem da solicitação de pull é muito complexo de ser resolvido no GitHub Enterprise Server ou o administrador do site desabilitou o editor de conflitos para as solicitações de pull entre repositórios. Você deve resolver o conflito de merge usando um cliente Git alternativo, ou usando o Git na linha de comando. Para obter mais informações, confira "Resolver um conflito de merge usando a linha de comando".

  4. Decida se você deseja manter apenas as alterações do seu branch, manter apenas as alterações do outro branch, ou fazer uma nova alteração, que pode incorporar alterações de ambos os branches. Exclua os marcadores de conflito <<<<<<<, =======, >>>>>>> e faça as alterações desejadas na mesclagem final.

  5. Se houver mais de um conflito de merge no arquivo, role para baixo até o próximo conjunto de marcadores de conflito e repita as etapas quatro e cinco para resolver o conflito de merge.

  6. Depois de resolver todos os conflitos no arquivo, clique em Marcar como resolvido.

    Captura de tela do editor usado para resolver um conflito de mesclagem em uma solicitação de pull. O botão "Marcar como resolvido" está contornado em laranja escuro.

  7. Se você tiver mais de um arquivo com um conflito, selecione o próximo arquivo que deseja editar no lado esquerdo da página abaixo de "conflicting files" (arquivos conflitantes) e repita as etapas de quatro a sete até resolver todos os conflitos de merge da pull request.

  8. Depois de resolver todos os conflitos de mesclagem, clique em Fazer commit da mesclagem. Isso incorpora todo o branch base ao branch head.

    Captura de tela do editor usado para resolver um conflito de mesclagem em uma solicitação de pull. O botão "Fazer commit da mesclagem" está contornado em laranja escuro.

  9. Se solicitado, revise o branch presente no commit.

    Se o branch head for o branch padrão do repositório, você pode escolher atualizar este branch com as mudanças que você fez para resolver o conflito, ou criar um novo branch e usar isso como o branch head da pull request.

    Se você escolher criar um novo branch, digite um nome para o branch.

    Se o branch head de sua pull request estiver protegido, você deve criar um novo branch. Você não terá a opção de atualizar o branch protegido.

    Clique em Criar branch e atualizar minha solicitação de pull ou Entendi. Continuar atualizando o BRANCH. O texto do botão corresponde à ação que você está executando.

  10. Para mesclar sua solicitação de pull, clique em Mesclar solicitação de pull. Para obter mais informações sobre outras opções de mesclagem de solicitação de pull, confira "Mesclar uma solicitação de pull".

Leitura adicional