A rewrite in computer programming is the act or result of re-implementing a large portion of existing functionality without re-use of its source code. When the rewrite is not using existing code at all, it is common to speak of a rewrite from scratch. When instead only parts are re-engineered, which have otherwise become complicated to handle or extend, then it is more precise to speak of code refactoring.
Contents |
[edit] Motivation
- When the source code to be able to extend an existing program is not available.
- When the source code is available under an incompatible license.
- When the code cannot be adapted to a new target platform.
- When the existing code has become too difficult to handle and extend.
- When the task of debugging the existing code seems too complicated.
- When the programmer finds it difficult to understand the source code.
[edit] Controversy
Many prominent software developers warn that this technique rarely leads to the intended success, claiming that rewriting is more fun than debugging, but the rewrite requires more time and will have new bugs.[1][2]
Advocates of this method instead suggest that with every iteration of the rewrite process an even better version is created, provided the same programmers do the job that already wrote the earlier versions.[3][4]
[edit] History
Both Borland's Paradox for Windows and Quattro Pro for Windows started development using beta versions of Windows 3.0, in the spring of 1990. Paradox/Windows ended up delayed about a year beyond its original plan, shipping in early 1993.
The reasons were many, but not entirely surprising for a major rewrite, in an object-oriented programming language with new tools, shifting to a GUI paradigm, on what was essentially a first version operating system. Still it was a big problem for the company and Microsoft managed to ship Access a couple of months ahead of Paradox for Windows, a major marketing win to Microsoft.[citation needed]
It took IBM two years to rewrite OS/2 for PowerPC, and by the time the operating system was ready, the market for OS/2 on PowerPC had evaporated.[citation needed]
Netscape's rewrite of its browser is popularly considered one of the most dramatic strategic mistakes in the history of the Internet.[5][6]
[edit] References
- ^ Ronkes Agerbeek, Joost (April 15, 2005). "Never Rewrite Code From Scratch". Retrieved on 2008-09-11.
- ^ Zawinski, Jamie. "Cascade of Attention-Deficit Teenagers". Retrieved on 2008-09-11.
- ^ Tilly, Ben. "Rewriting, from scratch, a huge code base". Retrieved on 2008-09-11.
- ^ Vorlath (25 September 2007). "Code Rewrite - Yes". Retrieved on 2008-09-11.
- ^ Spolsky, Joel (April 6, 2000). "Things You Should Never Do". Retrieved on 2008-09-11.
- ^ Zawinski, Jamie (March 31, 1999). "resignation and postmortem". Retrieved on 2008-09-11.
[edit] See also
Some projects mentioning major rewrites in their history:
|
|