The Community for Technology Leaders
2012 35th Annual IEEE Software Engineering Workshop (2006)
Columbia, Maryland
Apr. 24, 2006 to Apr. 28, 2006
ISSN: 1550-6215
ISBN: 0-7695-2624-1
pp: 47-58
Phillip A. Laplante , Penn State University, USA
Pam Vercellone-Smith , Penn State University, USA
Melissa M. Simmons , Penn State University, USA
ABSTRACT
In this study open source software was examined from an archaeological perspective. The objective: to explore the evolution of a long-lived open source project with the intention of learning how code evolution has progressed over time. This investigation provides a case study of Nethack, an enormously popular open source game that has been in development for more than a decade. The Goal Question Metric approach was employed to derive measurement goals for the evaluation of open source software (OSS) evolution in Nethack. According to Lehman?s laws, the incremental growth size of successive releases tends to decline during the active life of an evolving program. Our results demonstrate that the evolution patterns observed for Nethack do not consistently conform to Lehman?s laws. The growth in Nethack?s tarball distribution size, as well as lines of code, exhibited a linear increase in growth in this investigation. Additionally, Lehman?s laws dictate that the complexity of a system will increase as it ages. Interestingly, in Nethack, the McCabe cyclomatic complexity was found to decrease with successive releases while the Halstead complexity increased. These results suggest that while the structure complexity of Nethack declined with successive releases, the complexity of calculational logic increased. These findings raise questions concerning the evolution of other OSS applications.
INDEX TERMS
null
CITATION
Phillip A. Laplante, Pam Vercellone-Smith, Melissa M. Simmons, "Understanding Open Source Software through Software Archaeology: The Case of Nethack", 2012 35th Annual IEEE Software Engineering Workshop, vol. 00, no. , pp. 47-58, 2006, doi:10.1109/SEW.2006.37
168 ms
(Ver 3.3 (11022016))