O que é o git cherry pick?

O git cherry pick é um comando do Git que permite copiar um único commit de uma branch para outra. Isso significa que você pode escolher commits específicos de uma branch e aplicá-los em outra, sem precisar fazer um merge completo. Essa funcionalidade é extremamente útil quando você precisa trazer alterações específicas de uma branch para outra, sem trazer todo o histórico de commits.

Quando usar o git cherry pick?

O git cherry pick é uma ferramenta poderosa que pode ser utilizada em diversas situações. Aqui estão alguns cenários em que o git cherry pick pode ser útil:

1. Corrigir um bug em uma branch de produção

Imagine que você tenha uma branch de produção que está em produção e um bug crítico foi descoberto. Você já corrigiu o bug em uma branch de desenvolvimento, mas precisa trazer essa correção para a branch de produção sem trazer todas as outras alterações que foram feitas na branch de desenvolvimento. Nesse caso, você pode utilizar o git cherry pick para copiar o commit da correção e aplicá-lo na branch de produção.

2. Adicionar uma funcionalidade específica em uma branch de release

Suponha que você esteja trabalhando em uma nova funcionalidade que será lançada em uma próxima versão do seu software. Você já implementou essa funcionalidade em uma branch de desenvolvimento, mas precisa trazê-la para uma branch de release específica, sem trazer todas as outras alterações que foram feitas na branch de desenvolvimento. Nesse caso, o git cherry pick pode ser utilizado para copiar o commit da funcionalidade e aplicá-lo na branch de release.

3. Reverter um commit específico

Às vezes, você pode cometer um erro e desejar desfazer um commit específico. Em vez de reverter todos os commits feitos após o commit indesejado, você pode usar o git cherry pick para copiar o commit anterior ao commit indesejado e aplicá-lo na branch atual. Isso desfaz apenas o commit indesejado, mantendo todos os outros commits intactos.

4. Aplicar alterações de uma branch para outra

Se você estiver trabalhando em uma branch e quiser trazer algumas alterações específicas de outra branch, o git cherry pick pode ser uma ótima opção. Você pode escolher os commits que deseja trazer e aplicá-los na branch atual, sem precisar fazer um merge completo.

Como usar o git cherry pick?

Agora que você entendeu o que é o git cherry pick e quando usá-lo, vamos ver como utilizá-lo na prática. O comando git cherry pick é bastante simples e possui a seguinte sintaxe:

git cherry-pick

Onde é o hash do commit que você deseja copiar. Você pode encontrar o hash do commit utilizando o comando git log.

Após identificar o hash do commit que deseja copiar, você pode executar o comando git cherry pick seguido do hash do commit. O Git irá aplicar o commit na branch atual e criar um novo commit com as alterações do commit copiado.

É importante ressaltar que o git cherry pick pode gerar conflitos de merge, especialmente se as alterações feitas no commit copiado entrarem em conflito com as alterações existentes na branch atual. Nesse caso, você precisará resolver os conflitos manualmente antes de finalizar o git cherry pick.

Conclusão

O git cherry pick é uma ferramenta poderosa que permite copiar commits específicos de uma branch para outra. Ele pode ser utilizado em diversas situações, como corrigir bugs em branches de produção, adicionar funcionalidades em branches de release, reverter commits indesejados e aplicar alterações de uma branch para outra. O comando git cherry pick é simples de usar, mas é importante estar atento aos possíveis conflitos de merge que podem surgir. Com o git cherry pick, você tem mais controle sobre quais alterações deseja trazer para uma determinada branch, sem precisar trazer todo o histórico de commits.