Cruft is jargon for anything that is left over, redundant and getting in the way. It is used particularly for superseded and unemployed technical and electronic hardware and useless, superfluous or dysfunctional elements in computer software.
Around 1958, the term was used in the sense of "garbage" by students frequenting the MIT Tech Model Railroad Club (TMRC). In the 1959 edition of the club's dictionary, it was defined as "that which magically amounds in the Clubroom just before you walk in to clean up. In other words, rubbage". Its author Peter Samson later explained that this was meant in the sense of "detritus, that which needs to be swept up and thrown out. The dictionary has no definition for 'crufty,' a word I didn't hear until some years later."
The origin of the term is uncertain, but it may be derived[original research?] from Harvard University's Cruft Laboratory (built in 1915 as a gift from a donor named Harriet Otis Cruft), which was the Harvard Physics Department's radar lab during World War II. As late as the early 1990s, unused technical equipment could be seen stacked in front of Cruft Hall's windows. According to students, if a place filled with useless machinery is called Cruft Hall, the machinery itself must be cruft. This image of "discarded technical clutter" quickly migrated from hardware to software. Cruft may also be a play on the archaic medial "s", rendering "crust" as "cruſt". In the TMRC dictionary, the relation to the term "crud" (dirt, crap) is pointed out by humorously defining the better known word (crud) by the more obscure one (cruft).
The FreeBSD handbook uses the term to refer to leftover or superseded object code that accumulates in a folder or directory when software is recompiled and new executables and data files produced Such cruft, if required for the new executables to work properly, can cause the BSD equivalent of Dependency hell. The word is also used to describe instances of unnecessary, leftover or just poorly written source code in a computer program that is then uselessly, or even harmfully, compiled into object code.
Cruft accumulation may result in technical debt, which can subsequently make adding new features or modifying existing features—even to improve performance—more difficult and time consuming.
In the context of Internet or Web addresses (Uniform Resource Locators or "URLs"), cruft refers to the characters which are relevant or meaningful only to the people who created the site, such as implementation details of the computer system which serves the page. Examples of URL cruft include filename extensions such as .php or .html, and internal organizational details such as /public/ or /Users/john/work/drafts/.
Cruft may also refer to unused and out-of-date computer paraphernalia, collected through upgrading, inheritance, or simple acquisition, both deliberate and through circumstance. This accumulated hardware, however, often has benefit when IT systems administrators, technicians, and the like have need for critical replacement parts. An unused machine or component similar to a production unit could allow near-immediate restoration of the failed unit, as opposed to waiting for a shipped replacement.
- Dead code removal, the automatic removal of unnecessary code by compilers
- Duplicate code
- Muda (Japanese term)
- Spaghetti code
- Junk DNA
- Steven Levy: "Hackers: Heroes of the Computer Revolution - 25th Anniversary Edition." O'Reilly Media, 2010, ISBN 9781449393748, p.8
- Peter Samson: AN ABRIDGED DICTIONARYof the TMRC LANGUAGE June 1959 (with 2005 commentary)
- "crufty". The Jargon File, version 4.4.7.
- "18.104.22.168. What do I do if something goes wrong?". FreeBSD Handbook, Third Edition. Retrieved 2007-08-18.
- Developer blog comment: http://disfunksioneel.blogspot.co.uk/2011/04/linux-software-dependencies.html
- TechTarget SearchSoftwareQuality definition http://searchsoftwarequality.techtarget.com/definition/cruft
- "Hypertext Style: Cool URIs don't change". Retrieved 2007-08-18. "Cool URIs don't change."
|Look up cruft in Wiktionary, the free dictionary.|