| Fork (software Development) |
Article Index for Fork |
Website Links For Fork |
Information AboutFork (software Development) |
|
In Software Engineering , a project fork or '''branch''' happens when a developer (or a group of them) takes a copy of Source Code from one Software Package and starts to independently develop a new package. The term is also used more loosely to represent a similar branching of any work (for example, there are several forks of the English-language Wikipedia ), particularly with Free or Open Source software. Forks with free software result from a Schism over different goals or personality clashes. In a fork, both parties assume closely identical Copyright s but typically only the larger group, or that containing the original Architect , will retain the full original name and its associated user community. Thus there is a reputation penalty associated with forking. In Proprietary Software , the rights to the common code are shared; but this is rarer, as usually there are strict copyright terms associated with the source code, and usually these rights and interests are held by the employing entity, not the individual software developers. More commonly, a developer internally forks the code to develop two or more versions, such as a Windowed version and a Command Line version, or across newer or common and widespread operating systems, such as a Wordprocessor or other such Software Application for IBM PC compatible machines and one for Macintosh or Unix based computers. Generally, such internal forks will concentrate on having the same look, feel, and operation (behavior) between platforms so that a user familar with one can also be productive or share documents generated on the other. This is almost always an economic decision to generate a greater Market Share and thus pay back the associated extra development costs created by the fork. A fork that is standard practice in many projects are ''stable'' or ''release'' versions which are modified only for bug fixes, while a ''development'' tree develops new features. This is common practice in the Linux Kernel , for instance, but has been misrepresented occasionally in the trade press as the more problematic sort of fork described above. {Link without Title} In some cases, a fork can merge back into the original project or replace it. EGCS (Experimental/Enhanced GNU Compiler System) was a fork from GCC which proved more vital than the original project and was eventually "blessed" as the official GCC project. Forks are considered an expression of the freedom made available by free software and a weakness since they duplicate development efforts or can confuse users over which forked package to use. Developers have the option to collaborate and pool resources with free software but it is not ensured by Free Software Licenses but only by a commitment to cooperation. The relationship between the different teams can be cordial or very bitter. For instance, the author of the LMule file-sharing program for Linux was uninterested in porting it to other systems, the XMule team started a fork to do so. Disagreements among the developers led to xMule itself being forked into AMule , and the tension between the developers persisted. On the matter of forking, the Jargon File says: :"Forking is considered a Bad Thing — not merely because it implies a lot of wasted effort in the future, but because forks tend to be accompanied by a great deal of strife and acrimony between the successor groups over issues of legitimacy, succession, and design direction. There is serious social pressure against forking. As a result, major forks (such as the Gnu-Emacs / XEmacs split, the fissionings of the 386BSD group into three daughter projects, and the short-lived GCC/EGCS split) are rare enough that they are remembered individually in hacker folklore." Because of the ease of forking a project but the challenge of continuing to develop and support it, it's common for forks without extensive resources to become inactive — for instance, see GoneME , a fork of GNOME by a former developer, which was shortly discontinued despite attracting some publicity. Some well-known forks have enjoyed great success, however, such as the X.Org X11 server, a fork from XFree86 . Most distributions have switched to X.Org, and overall X11 development has sped up as well. OTHER EXAMPLES
REFERENCES
|