Do background colors improve program comprehension in the #ifdef hell?

  • Authors:
  • Janet Feigenspan;Christian Kästner;Sven Apel;Jörg Liebig;Michael Schulze;Raimund Dachselt;Maria Papendieck;Thomas Leich;Gunter Saake

  • Affiliations:
  • School of Computer Science, University of Magdeburg, Magdeburg, Germany;Philipps University Marburg, Marburg, Germany;University of Passau, Passau, Germany;University of Passau, Passau, Germany;pure-systems, Magdeburg, Germany;School of Computer Science, University of Magdeburg, Magdeburg, Germany;School of Computer Science, University of Magdeburg, Magdeburg, Germany;Metop Research Institute, Magdeburg, Germany;School of Computer Science, University of Magdeburg, Magdeburg, Germany

  • Venue:
  • Empirical Software Engineering
  • Year:
  • 2013

Quantified Score

Hi-index 0.00

Visualization

Abstract

Software-product-line engineering aims at the development of variable and reusable software systems. In practice, software product lines are often implemented with preprocessors. Preprocessor directives are easy to use, and many mature tools are available for practitioners. However, preprocessor directives have been heavily criticized in academia and even referred to as "#ifdef hell", because they introduce threats to program comprehension and correctness. There are many voices that suggest to use other implementation techniques instead, but these voices ignore the fact that a transition from preprocessors to other languages and tools is tedious, erroneous, and expensive in practice. Instead, we and others propose to increase the readability of preprocessor directives by using background colors to highlight source code annotated with ifdef directives. In three controlled experiments with over 70 subjects in total, we evaluate whether and how background colors improve program comprehension in preprocessor-based implementations. Our results demonstrate that background colors have the potential to improve program comprehension, independently of size and programming language of the underlying product. Additionally, we found that subjects generally favor background colors. We integrate these and other findings in a tool called FeatureCommander, which facilitates program comprehension in practice and which can serve as a basis for further research.