Em engenharia de software, uma bifurcação ou ramificação (em inglês: fork) acontece quando um desenvolvedor (ou um grupo de desenvolvedores) inicia um projeto independente com base no código de um projeto já existente, ou seja, quando um software é desenvolvido com base em outro, já existente, sem a descontinuidade deste último. O termo é também usado para outras separações de qualquer tipo de trabalho (por exemplo, há várias bifurcações da língua inglesa na Wikipédia).
O termo é particularmente usado no software livre ou de código aberto, quando uma divisão ocorre por causa de diferentes objetivos ou brigas de personalidade. Alguns vêem as bifurcações como uma fraqueza no software livre, mas outros acreditam que eles demonstram a adaptabilidade do modelo. A relação entre os times pode ser cordial ou muito dura (ver xMule e sua bifurcação aMule).
Em uma bifurcação deste tipo, ambos os lados herdam propriedade intelectual idêntica, mas tipicamente apenas o maior grupo, ou aquele que contém o arquiteto original, irá manter o nome original e o seu capital social associado. Então, existe uma penalidade na reputação associada com o bifurcação.
Isto pode acontecer no software de código fechado também, se os direitos ao código comum forem compartilhados; mas este é mais raro, como há, em geral, regras estritas sobre a propriedade do código. É mais comum no software de código fechado um desenvolvedor fazer uma bifurcação do seu próprio projeto, para desenvolver duas versões, como uma versão em janelas e outra em linha de comando.
Outro tipo de bifurcação é uma prática padrão em muitos projetos: fazer uma bifurcação estável ou de produção que será modificada apenas para correções de defeitos, enquanto uma versão de desenvolvimento continua tendo novas características adicionadas. Isto é uma prática comum no núcleo Linux, por exemplo, mas é comumente mal-interpretado na imprensa como o tipo mais problemático de bifurcação. Veja um exemplo aqui
Em alguns casos, um bifurcação pode voltar ao seu projeto original ou substituí-lo. O EGCS (Experimental/Enhanced GNU Compiler System) era um bifurcação do GCC que era mais ativo que o projeto original e foi depois considerado o projeto GCC oficial.
As muitas variações proprietárias do UNIX — todas derivadas do AT&T UNIX e todas chamadas "UNIX", mas cada vez mais mutuamente incompatíveis. Veja guerras do UNIX;
O desenvolvimento do sistema de arquivos NTFS pela Microsoft foi baseado em trabalhos anteriores no HPFS que foi deixado para IBM;
O jogo Nethack tem muitas variantes usando o código original (dizem que o Nethack é uma bifurcação do jogo Rogue, mas seu código foi escrito independentemente);
OpenBSD era originalmente uma bifurcação do NetBSD, nascido de conflitos de personalidade entre os desenvolvedores do NetBSD;
OpenSSH foi uma bifurcação do SSH devido a licença do SSH 2.x era "não-livre" (mesmo estando seu código disponível), então, uma versão antiga do SSH 1.x, a última com licença de software livre, sofreu uma bifurcação e rapidamente quase todas as distribuições do Linux, versões do BSD e alguns Unixes proprietários substituíram o SSH pelo OpenSSH;
O X.OrgX11 foi uma bifurcação do XFree86 por uma razão semelhante a bifurcação SSH/OpenSSH, resultando no desenvolvimento acelerado do X11 e na alta aceitação nas distribuições;
DragonflyBSD é uma bifurcação do FreeBSD, criado para ter uma abordagem técnica diferente da usada no FreeBSD 5;