Virtual separation of concerns

Conditional compilation with preprocessors like cpp is a simple but effective means to implement variability. By annotating code fragments with #ifdef and #endif directives, different program variants with or without these annotated fragments can be created, which can be used (among others) to implement software product lines. Although, such annotation-based approaches are frequently used in practice, researchers often criticize them for their negative effect on code quality and maintainability. In contrast to modularized implementations such as components or aspects, annotation-based implementations typically neglect separation of concerns, can entirely obfuscate the source code, and are prone to introduce subtle errors. Our goal is to rehabilitate annotation-based approaches by showing how tool support can address these problems. With views, we emulate modularity; with a visual representation of annotations, we reduce source code obfuscation and increase program comprehension; and with disciplined annotations and a productline–aware type system, we prevent or detect syntax and type errors in the entire software product line. At the same time we emphasize unique benefits of annotations, including simplicity, expressiveness, and being language independent. All in all, we provide tool-based separation of concerns without necessarily dividing source code into physically separated modules; we name this approach virtual separation of concerns. We argue that with these improvements over contemporary preprocessors, virtual separation of concerns can compete with modularized implementation mechanisms. Despite our focus on annotation-based approaches, we do intend not give a definite answer on how to implement software product lines. Modular implementations and annotation-based implementations both have their advantages; we even present an integration and migration path between them. Our goal is to rehabilitate preprocessors and show that they are not a lost cause as many researchers think. On the contrary, we argue that – with the presented improvements – annotation-based approaches are a serious alternative for product-line implementation.

[1]  Matthias Jarke,et al.  Toward Reference Models of Requirements Traceability , 2001, IEEE Trans. Software Eng..

[2]  Yuanyuan Song,et al.  Information hiding interfaces for aspect-oriented design , 2005, ESEC/FSE-13.

[3]  Benjamin C. Pierce,et al.  Relational lenses: a language for updatable views , 2006, PODS '06.

[4]  Clemens A. Szyperski,et al.  Component software - beyond object-oriented programming , 2002 .

[5]  Sven Apel,et al.  An Algebra for Features and Feature Composition , 2008, AMAST.

[6]  H. Ossher,et al.  Concern modeling in the concern manipulation environment , 2005, MACS@ICSE.

[7]  Paul Clements,et al.  Software architecture in practice , 1999, SEI series in software engineering.

[8]  李幼升,et al.  Ph , 1989 .

[9]  Carsten Sinz,et al.  Configuration Lifting: Verification meets Software Configuration , 2008, 2008 23rd IEEE/ACM International Conference on Automated Software Engineering.

[10]  Harold Ossher,et al.  Subject-oriented programming: a critique of pure objects , 1993, OOPSLA '93.

[11]  Clemens A. Szyperski,et al.  Import is Not Inheritance - Why We Need Both: Modules and Classes , 1992, ECOOP.

[12]  Ina Schaefer,et al.  Implementing software product lines using traits , 2010, SAC '10.

[13]  Danilo Beuche,et al.  The PURE family of object-oriented operating systems for deeply embedded systems , 1999, Proceedings 2nd IEEE International Symposium on Object-Oriented Real-Time Distributed Computing (ISORC'99) (Cat. No.99-61702).

[14]  Gary T. Leavens,et al.  MultiJava: Design rationale, compiler implementation, and applications , 2006, TOPL.

[15]  Atsushi Igarashi,et al.  On Inner Classes , 2002, Inf. Comput..

[16]  D. L. Parnas,et al.  On the criteria to be used in decomposing systems into modules , 1972, Software Pioneers.

[17]  Hassan Gomaa,et al.  Separation of concerns in software product line engineering , 2005, ACM SIGSOFT Softw. Eng. Notes.

[18]  Henry Spencer,et al.  #ifdef Considered Harmful, or Portability Experience with C News , 1992, USENIX Summer.

[19]  Robert J. Hall,et al.  Fundamental Nonmodularity in Electronic Mail , 2004, Automated Software Engineering.

[20]  Thomas Leich,et al.  Tailor-made data management for embedded systems: A case study on Berkeley DB , 2009, Data Knowl. Eng..

[21]  Stephan Diehl,et al.  Software Visualization - Visualizing the Structure, Behaviour, and Evolution of Software , 2007 .

[22]  Oscar Nierstrasz,et al.  Traits: A mechanism for fine-grained reuse , 2006, TOPL.

[23]  William G. Griswold,et al.  The structure and value of modularity in software design , 2001, ESEC/FSE-9.

[24]  Krzysztof Czarnecki,et al.  Verifying feature-based model templates against well-formedness OCL constraints , 2006, GPCE '06.

[25]  Oscar Díaz,et al.  Feature Oriented Model Driven Development: A Case Study for Portlets , 2007, 29th International Conference on Software Engineering (ICSE'07).

[26]  Christian Wende,et al.  On Controlled Visualisations in Software Product Line Engineering , 2008, SPLC.

[27]  David Notkin,et al.  Error reporting with graduated color , 1992, IEEE Software.

[28]  David Lorge Parnas,et al.  Review of David L. Parnas' "Designing Software for Ease of Extension and Contraction" , 2004 .

[29]  H. Bastian Sensation and Perception.—I , 1869, Nature.

[30]  Todd D. Millstein,et al.  Statically scoped object adaptation with expanders , 2006, OOPSLA '06.

[31]  Jeffrey G. Gray,et al.  A technique for constructing aspect weavers using a program transformation engine , 2004, AOSD '04.

[32]  Luca Cardelli,et al.  Program fragments, linking, and modularization , 1997, POPL '97.

[33]  Alejandra Garrido,et al.  Program refactoring in the presence of preprocessor directives , 2005 .

[34]  Don S. Batory,et al.  Automating Feature-Oriented Refactoring of Legacy Applications , 2007, WRT.

[35]  Sebastian Günther,et al.  Representing and Composing First-class Features with FeatureJ , 2009 .

[36]  M. Humphrey,et al.  Evaluation of the maintainability of object-oriented software , 1990, IEEE TENCON'90: 1990 IEEE Region 10 Conference on Computer and Communication Systems. Conference Proceedings.

[37]  Stan Jarzabek,et al.  XVCL: a mechanism for handling variants in software product lines , 2004, Sci. Comput. Program..

[38]  Martin P. Robillard,et al.  Concern graphs: finding and describing concerns using structural program dependencies , 2002, Proceedings of the 24th International Conference on Software Engineering. ICSE 2002.

[39]  A. Nico Habermann,et al.  Modularization and hierarchy in a family of operating systems , 1976, CACM.

[40]  Ari Jaaksi,et al.  Developing Mobile Browsers in a Product Line , 2002, IEEE Softw..

[41]  Yvonne Coady,et al.  CViMe: viewing conditionally compiled C/C++ sources through Java , 2006, OOPSLA '06.

[42]  Malte Rosenthal,et al.  Alternative Features in Colored Featherweight Java , 2009 .

[43]  João Araújo,et al.  Early aspects: a model for aspect-oriented requirements engineering , 2002, Proceedings IEEE Joint International Conference on Requirements Engineering.

[44]  Dirk Muthig,et al.  Generic Implementation of Product Line Components , 2002, NetObjectDays.

[45]  Sholom Cohen,et al.  Product Line Practice Workshop Report. , 1998 .

[46]  Hans-Arno Jacobsen,et al.  Quantifying aspects in middleware platforms , 2003, AOSD '03.

[47]  Michel Dagenais,et al.  C/C++ conditional compilation analysis using symbolic execution , 2000, Proceedings 2000 International Conference on Software Maintenance.

[48]  Dewayne E. Perry,et al.  Design of large-scale polylingual systems , 2004, Proceedings. 26th International Conference on Software Engineering.

[49]  Gunter Saake,et al.  On the impact of the optional feature problem: analysis and case studies , 2009, SPLC.

[50]  Olly Gotel,et al.  An analysis of the requirements traceability problem , 1994, Proceedings of IEEE International Conference on Requirements Engineering.

[51]  Wolfgang Schröder-Preikschat,et al.  Dead or Alive: finding zombie features in the Linux kernel , 2009, FOSD '09.

[52]  Charles W. Krueger,et al.  Easing the Transition to Software Mass Customization , 2001, PFE.

[53]  Danilo Beuche,et al.  Variability management with feature models , 2004, Sci. Comput. Program..

[54]  Marc Roper,et al.  A Comparative Evaluation of Program Comprehension Measures , 2000 .

[55]  Renaud Pawlak Spoon: Compile-time Annotation Processing for Middleware , 2006, IEEE Distributed Systems Online.

[56]  Don S. Batory,et al.  Feature Models, Grammars, and Propositional Formulas , 2005, SPLC.

[57]  Andrew C. Myers,et al.  Scalable extensibility via nested inheritance , 2004, OOPSLA.

[58]  Krzysztof Czarnecki,et al.  The Variability Model of The Linux Kernel , 2010, VaMoS.

[59]  Sven Apel,et al.  A model of refactoring physically and virtually separated features , 2009, GPCE '09.

[60]  William R. Cook,et al.  Fitting the pieces together: a machine-checked model of safe composition , 2009, ESEC/FSE '09.

[61]  Gregor Kiczales,et al.  Aspect-oriented programming , 2001, ESEC/FSE-9.

[62]  Rainer Koschke,et al.  Locating Features in Source Code , 2003, IEEE Trans. Software Eng..

[63]  Mik Kersten,et al.  Using task context to improve programmer productivity , 2006, SIGSOFT '06/FSE-14.

[64]  Cláudio Sant'Anna,et al.  Evolving software product lines with aspects , 2008, 2008 ACM/IEEE 30th International Conference on Software Engineering.

[65]  Wolfgang De Meuter,et al.  Can we refactor conditional compilation into aspects? , 2009, AOSD '09.

[66]  Sven Apel,et al.  Type safety for feature-oriented product lines , 2010, Automated Software Engineering.

[67]  Shan Shan Huang,et al.  Expressive and safe static reflection with MorphJ , 2008, PLDI '08.

[68]  G. Kiczales,et al.  Aspect-oriented programming and modular reasoning , 2005, Proceedings. 27th International Conference on Software Engineering, 2005. ICSE 2005..

[69]  Yannis Smaragdakis,et al.  Mixin layers: an object-oriented implementation technique for refinements and collaboration-based designs , 2002, TSEM.

[70]  Sven Apel,et al.  When to use features and aspects?: a case study , 2006, GPCE '06.

[71]  Sebastian Günther,et al.  Feature-oriented programming with Ruby , 2009, FOSD '09.

[72]  Martin P. Robillard,et al.  Separating features in source code: an exploratory study , 2001, Proceedings of the 23rd International Conference on Software Engineering. ICSE 2001.

[73]  Klaus Pohl,et al.  Software Product Line Engineering - Foundations, Principles, and Techniques , 2005 .

[74]  Thomas Leich,et al.  Tool support for feature-oriented software development: featureIDE: an Eclipse-based approach , 2005, eclipse '05.

[75]  Michael Poppleton,et al.  Towards Feature-Oriented Specification and Development with Event-B , 2007, REFSQ.

[76]  Árpád Beszédes,et al.  Opening Up The C/C++ Preprocessor Black Box , 2003, SPLST.

[77]  Don S. Batory,et al.  On the modularity of feature interactions , 2008, GPCE '08.

[78]  Kyo Chul Kang,et al.  Feature-Oriented Domain Analysis (FODA) Feasibility Study , 1990 .

[79]  Andrew M. Sutton,et al.  How We Manage Portability and Configuration with the C Preprocessor , 2007, 2007 IEEE International Conference on Software Maintenance.

[80]  Sven Apel,et al.  A Case Study Implementing Features Using AspectJ , 2007, 11th International Software Product Line Conference (SPLC 2007).

[81]  Thomas Leich,et al.  An orthogonal access modifier model for feature-oriented programming , 2009, FOSD '09.

[82]  Thomas Leich,et al.  Aspectual Feature Modules , 2008, IEEE Transactions on Software Engineering.

[83]  Eelco Visser,et al.  Program Transformation with Stratego/XT: Rules, Strategies, Tools, and Systems in Stratego/XT 0.9 , 2003, Domain-Specific Program Generation.

[84]  Aaron Turon,et al.  Metaprogramming with Traits , 2007, ECOOP.

[85]  Abdul Azim Abdul Ghani,et al.  A Survey on Aspect-Oriented Testing Approaches , 2007, 2007 International Conference on Computational Science and its Applications (ICCSA 2007).

[86]  William G. Griswold,et al.  Exploiting the map metaphor in a tool for software evolution , 2001, Proceedings of the 23rd International Conference on Software Engineering. ICSE 2001.

[87]  David S. Wile,et al.  Abstract Syntax from Concrete Syntax , 1997, Proceedings of the (19th) International Conference on Software Engineering.

[88]  Sophia Drossopoulou,et al.  Java Type Soundness Revisited , 2000 .

[89]  Dachuan Yu,et al.  Variance and Generalized Constraints for C# Generics , 2006, ECOOP.

[90]  簡聰富,et al.  物件導向軟體之架構(Object-Oriented Software Construction)探討 , 1989 .

[91]  Benjamin C. Pierce,et al.  Combinators for bi-directional tree transformations: a linguistic approach to the view update problem , 2005, POPL '05.

[92]  Brian Foote,et al.  Designing Reusable Classes , 2001 .

[93]  Thomas Leich,et al.  FeatureC++: on the symbiosis of feature-oriented and aspect-oriented programming , 2005, GPCE'05.

[94]  Ralph E. Johnson,et al.  Analyzing multiple configurations of a C program , 2005, 21st IEEE International Conference on Software Maintenance (ICSM'05).

[95]  Michael Lawley,et al.  Towards Model Round-Trip Engineering: An Abductive Approach , 2009, ICMT@TOOLS.

[96]  Michal Antkiewicz,et al.  Mapping features to models: a template approach based on superimposed variants , 2005, GPCE'05.

[97]  Ted J. Biggerstaff,et al.  A perspective of generative reuse , 1998, Ann. Softw. Eng..

[98]  Stanley M. Sutton,et al.  N degrees of separation: multi-dimensional separation of concerns , 1999, Proceedings of the 1999 International Conference on Software Engineering (IEEE Cat. No.99CB37002).

[99]  Wolfgang Stolz,et al.  Introducing PLA at Bosch Gasoline Systems: Experiences and Practices , 2004, SPLC.

[100]  Shan Shan Huang,et al.  Statically safe program generation with safegen , 2005, GPCE'05.

[101]  Gail C. Murphy,et al.  Explicit programming , 2002, AOSD '02.

[102]  Krzysztof Czarnecki,et al.  Formalizing cardinality-based feature models and their specialization , 2005, Softw. Process. Improv. Pract..

[103]  James H. Andrews,et al.  Process-Algebraic Foundations of Aspect-Oriented Programming , 2001, Reflection.

[104]  Lianping Chen,et al.  Variability management in software product lines: a systematic review , 2009, SPLC.

[105]  Lerina Aversano,et al.  Handling preprocessor-conditioned declarations , 2002, Proceedings. Second IEEE International Workshop on Source Code Analysis and Manipulation.

[106]  Sven Apel,et al.  How AspectJ is Used: An Analysis of Eleven AspectJ Programs , 2010, J. Object Technol..

[107]  Thomas Leich,et al.  FeatureIDE: A tool framework for feature-oriented software development , 2009, 2009 IEEE 31st International Conference on Software Engineering.

[108]  Ron Cytron,et al.  Footprint and feature management using aspect-oriented programming techniques , 2002, LCTES/SCOPES '02.

[109]  Tobias Nipkow,et al.  Javalight is type-safe—definitely , 1998, POPL '98.

[110]  Andy Clement,et al.  Aspect-Oriented Programming with AJDT , 2003 .

[111]  Klaus Pohl,et al.  Model Checking of Domain Artifacts in Product Line Engineering , 2009, 2009 IEEE/ACM International Conference on Automated Software Engineering.

[112]  Krzysztof Czarnecki,et al.  Generative Programming for Embedded Software: An Industrial Experience Report , 2002, GPCE.

[113]  Sven Apel,et al.  Granularity in software product lines , 2008, 2008 ACM/IEEE 30th International Conference on Software Engineering.

[114]  Mira Mezini,et al.  Variability management with feature-oriented programming and aspects , 2004, SIGSOFT '04/FSE-12.

[115]  Jonathan Aldrich,et al.  Open Modules: Modular Reasoning About Advice , 2005, ECOOP.

[116]  Oscar Díaz,et al.  Feature refactoring a multi-representation program into a product line , 2006, GPCE '06.

[117]  Sven Apel,et al.  Types and modularity for implicit invocation with implicit announcement , 2010, TSEM.

[118]  Hans-Arno Jacobsen,et al.  Horizontal decomposition of Prevayler , 2005, CASCON.

[119]  Martin Fowler. Refactoring Improving the Design of Existing Code , 1999 .

[120]  Stefan Hanenberg,et al.  Refactoring of Aspect-Oriented Software , 2003 .

[121]  Stanley M. Sutton,et al.  Hyper/J™: multi-dimensional separation of concerns for Java™ , 2001, ICSE '02.

[122]  William R. Cook,et al.  Safe composition of product lines , 2007, GPCE '07.

[123]  Mario Latendresse Rewrite systems for symbolic evaluation of C-like preprocessing , 2004, Eighth European Conference on Software Maintenance and Reengineering, 2004. CSMR 2004. Proceedings..

[124]  James R. Cordy Eating our own dog food: DSLs for generative and transformational engineering , 2009, GPCE '09.

[125]  David McComas,et al.  Verifying architectural design rules of the flight software product line , 2009, SPLC.

[126]  Roberto Erick Lopez-Herrejon,et al.  Evaluating Support for Features in Advanced Modularization Technologies , 2005, ECOOP.

[127]  Ilka Philippow,et al.  Details of formalized relations in feature models using OCL , 2003, 10th IEEE International Conference and Workshop on the Engineering of Computer-Based Systems, 2003. Proceedings..

[128]  Mark Chu-Carroll,et al.  Visual separation of concerns through multidimensional program storage , 2003, AOSD '03.

[129]  Iris Groher,et al.  Product Line Implementation using Aspect-Oriented and Model-Driven Software Development , 2007, 11th International Software Product Line Conference (SPLC 2007).

[130]  Holger Giese,et al.  From model transformation to incremental bidirectional model synchronization , 2009, Software & Systems Modeling.

[131]  Charles Simonyi,et al.  Intentional software , 2006, OOPSLA '06.

[132]  Sven Apel,et al.  Refactoring Feature Modules , 2009, ICSR.

[133]  Benjamin C. Pierce,et al.  Types and programming languages: the next generation , 2003, 18th Annual IEEE Symposium of Logic in Computer Science, 2003. Proceedings..

[134]  William G. Griswold,et al.  An Overview of AspectJ , 2001, ECOOP.

[135]  Ralph Johnson,et al.  design patterns elements of reusable object oriented software , 2019 .

[136]  Harold Ossher,et al.  On the Need for On-Demand Remodularization , 2000 .

[137]  Sven Apel,et al.  An Overview of Feature-Oriented Software Development , 2009, J. Object Technol..

[138]  Eric A. Brewer,et al.  ASTEC: a new approach to refactoring C , 2005, ESEC/FSE-13.

[139]  João M. Fernandes,et al.  Towards a catalog of aspect-oriented refactorings , 2005, AOSD '05.

[140]  Andrew C. Myers,et al.  Parameterized types for Java , 1997, POPL '97.

[141]  Wolfgang Schröder-Preikschat,et al.  A quantitative analysis of aspects in the eCos kernel , 2006, EuroSys.

[142]  Gregor Kiczales,et al.  Discussing aspects of AOP , 2001, CACM.

[143]  Iris Groher,et al.  Product Line Implementation using Aspect-Oriented and Model-Driven Software Development , 2007 .

[144]  Sven Apel,et al.  Language-Independent Quantification and Weaving for Feature Composition , 2009, SC@TOOLS.

[145]  R. Rosenthal,et al.  Teachers' Expectancies: Determinants of Pupils' IQ Gains , 1966, Psychological reports.

[146]  Marko Rosenmüller,et al.  Avoiding Variability of Method Signatures in Software Product Lines: A Case Study , 2007 .

[147]  Roberto Erick Lopez-Herrejon,et al.  A Standard Problem for Evaluating Product-Line Methodologies , 2001, GCSE.

[148]  Nicolas Spyratos,et al.  Update semantics of relational views , 1981, TODS.

[149]  Stephen G. Eick,et al.  Seesoft-A Tool For Visualizing Line Oriented Software Statistics , 1992, IEEE Trans. Software Eng..

[150]  Ted J. Biggerstaff,et al.  The library scaling problem and the limits of concrete component reuse , 1994, Proceedings of 1994 3rd International Conference on Software Reuse.

[151]  Kent L. Beck,et al.  Test-driven Development - by example , 2002, The Addison-Wesley signature series.

[152]  Bashar Nuseibeh,et al.  Towards safer composition , 2009, 2009 31st International Conference on Software Engineering - Companion Volume.

[153]  Kris De Volder,et al.  Navigating and querying code without getting lost , 2003, AOSD '03.

[154]  Mira Mezini,et al.  Separation of Concerns with Procedures, Annotations, Advice and Pointcuts , 2005, ECOOP.

[155]  Sven Apel,et al.  Type-Checking Software Product Lines - A Formal Approach , 2008, 2008 23rd IEEE/ACM International Conference on Automated Software Engineering.

[156]  Eduardo Figueiredo,et al.  Early Crosscutting Metrics as Predictors of Software Instability , 2009, TOOLS.

[157]  Vassily Litvinov Contraint-based polymorphism in Cecil: towards a practical and static type system , 1998, OOPSLA '98.

[158]  Gregor Snelting,et al.  On the inference of configuration structures from source code , 1994, Proceedings of 16th International Conference on Software Engineering.

[159]  Matthias Felleisen,et al.  Hygienic macro expansion , 1986, LFP '86.

[160]  Charles W. Krueger,et al.  Software reuse , 1992, CSUR.

[161]  Roberto Erick Lopez-Herrejon,et al.  Generating product-lines of product-families , 2002, Proceedings 17th IEEE International Conference on Automated Software Engineering,.

[162]  Thomas Thüm,et al.  Reasoning about edits to feature models , 2009, 2009 IEEE 31st International Conference on Software Engineering.

[163]  Gunter Saake,et al.  Measuring Non-Functional Properties in Software Product Line for Product Derivation , 2008, 2008 15th Asia-Pacific Software Engineering Conference.

[164]  Adam Kiezun,et al.  Advanced Refactoring in the Eclipse JDT: Past, Present, and Future , 2007, WRT.

[165]  William R. Cook,et al.  Object-Oriented Programming Versus Abstract Data Types , 1990, REX Workshop.

[166]  Mark A. Linton,et al.  Implementing relational views of programs , 1984, SDE 1.

[167]  Sergio Segura,et al.  Automated analysis of feature models 20 years later: A literature review , 2010, Inf. Syst..

[168]  Gunter Saake,et al.  Type checking annotation-based product lines , 2012, TSEM.

[169]  Jean-Marie Favre Understanding-in-the-large , 1997, Proceedings Fifth International Workshop on Program Comprehension. IWPC'97.

[170]  Krzysztof Czarnecki,et al.  SAT-based analysis of feature models is easy , 2009, SPLC.

[171]  Mira Mezini,et al.  Untangling crosscutting models with Caesar , 2005 .

[172]  William R. Cook,et al.  Mixin-based inheritance , 1990, OOPSLA/ECOOP '90.

[173]  David Coppit,et al.  Software Plans for Separation of Concerns , 2004 .

[174]  Charles Simonyi,et al.  The Death of Computer Languages, The Birth of Intentional Programming , 1995 .

[175]  Ramnivas Laddad,et al.  Aspectj in Action: Practical Aspect-Oriented Programming , 2003 .

[176]  John C. Reynolds User-defined types and procedural data structures as complementary approaches to data abstraction , 1994 .

[177]  Pierre-Yves Schobbens,et al.  Disambiguating the Documentation of Variability in Software Product Lines: A Separation of Concerns, Formalization and Automated Analysis , 2007, 15th IEEE International Requirements Engineering Conference (RE 2007).

[178]  Raymie Stata,et al.  Modular reasoning in the presence of subclassing , 1995, OOPSLA.

[179]  Michael Eisenbarth,et al.  A decade of scoping: a survey , 2009, SPLC.

[180]  Mik Kersten,et al.  Mylar: a degree-of-interest model for IDEs , 2005, AOSD '05.

[181]  Sven Apel,et al.  An analysis of the variability in forty preprocessor-based software product lines , 2010, 2010 ACM/IEEE 32nd International Conference on Software Engineering.

[182]  Krzysztof Czarnecki,et al.  Generative programming - methods, tools and applications , 2000 .

[183]  Mario Kolberg,et al.  Feature interaction: a critical review and considered forecast , 2003, Comput. Networks.

[184]  Gilad Bracha,et al.  Modularity meets inheritance , 1992, Proceedings of the 1992 International Conference on Computer Languages.

[185]  Mark Harman,et al.  Automated refactoring of object oriented code into aspects , 2005, 21st IEEE International Conference on Software Maintenance (ICSM'05).

[186]  Niklaus Wirth The Module: A System Structuring Facility in High-Level Programming Languages , 1979, Language Design and Programming Methodology.

[187]  David Lorge Parnas,et al.  On the Design and Development of Program Families , 2001, IEEE Transactions on Software Engineering.

[188]  Sven Apel,et al.  Program refactoring using functional aspects , 2008, GPCE '08.

[189]  Sven Apel,et al.  Guaranteeing Syntactic Correctness for All Product Line Variants: A Language-Independent Approach , 2009, TOOLS.

[190]  Krzysztof Czarnecki,et al.  Feature Diagrams and Logics: There and Back Again , 2007, 11th International Software Product Line Conference (SPLC 2007).

[191]  Wolfgang Schröder-Preikschat,et al.  AspectC++: an aspect-oriented extension to the C++ programming language , 2002 .

[192]  Juha Taina,et al.  Product family testing: a survey , 2004, SOEN.

[193]  Danilo Beuche,et al.  Running a software product line: standing still is going backwards , 2009, SPLC.

[194]  Oscar Nierstrasz,et al.  Classbox/J: controlling the scope of change in Java , 2005, OOPSLA '05.

[195]  Jia Liu,et al.  Feature oriented refactoring of legacy applications , 2006, ICSE.

[196]  Oscar Nierstrasz,et al.  Composing Unit Tests , 2005 .

[197]  David L. Atkins Version Sensitive Editing: Change History as a Programming Tool , 1998, SCM.

[198]  Mira Mezini,et al.  Conquering aspects with Caesar , 2003, AOSD '03.

[199]  Mark Staples,et al.  Experiences adopting software product line development without a product line architecture , 2004, 11th Asia-Pacific Software Engineering Conference.

[200]  Bram Adams,et al.  Aspect mining in the presence of the C preprocessor , 2008, LATE@AOSD.

[201]  J. Favre The CPP paradox , 1995 .

[202]  Gang Chen,et al.  Design Wizards and Visual Programming Environments for GenVoca Generators , 2000, IEEE Trans. Software Eng..

[203]  William R. Cook,et al.  A virtual class calculus , 2006, POPL '06.

[204]  Paul Grünbacher,et al.  Supporting Product Derivation by Adapting and Augmenting Variability Models , 2007, 11th International Software Product Line Conference (SPLC 2007).

[205]  Philip Wadler,et al.  Featherweight Java: a minimal core calculus for Java and GJ , 2001, TOPL.

[206]  Christian Prehofer,et al.  Feature-Oriented Programming: A Fresh Look at Objects , 1997, ECOOP.

[207]  Scott P. Robertson,et al.  Expert problem solving strategies for program comprehension , 1991, CHI.

[208]  Klaus Ostermann,et al.  Reasoning about aspects with common sense , 2008, AOSD.

[209]  Friedrich Steimann The paradoxical success of aspect-oriented programming , 2006, OOPSLA '06.

[210]  Mark Carpenter,et al.  The New Statistical Analysis of Data , 2000, Technometrics.

[211]  Sven Apel,et al.  Integrating Compositional and Annotative Approaches for Product Line Engineering , 2008 .

[212]  Matthias Felleisen,et al.  A Syntactic Approach to Type Soundness , 1994, Inf. Comput..

[213]  Ole Lehrmann Madsen,et al.  Virtual classes: a powerful mechanism in object-oriented programming , 1989, OOPSLA '89.

[214]  Jörgen Hansson,et al.  Application-tailored database systems: a case of aspects in an embedded database , 2004, Proceedings. International Database Engineering and Applications Symposium, 2004. IDEAS '04..

[215]  Matthias Felleisen,et al.  Classes and mixins , 1998, POPL '98.

[216]  Hans-Arno Jacobsen,et al.  Resolving feature convolution in middleware systems , 2004, OOPSLA.

[217]  Donald D. Cowan,et al.  Efficient compilation techniques for large scale feature models , 2008, GPCE '08.

[218]  David W. Binkley,et al.  Program slicing , 2008, 2008 Frontiers of Software Maintenance.

[219]  Ralf Carbon,et al.  Variability management in small development organizations: experiences and lessons learned from a case study , 2009, SPLC.

[220]  Wuu Yang,et al.  How to merge program texts , 1994, J. Syst. Softw..

[221]  Ilka Philippow,et al.  Enabling Automated Traceability Maintenance by Recognizing Development Activities Applied to Models , 2008, 2008 23rd IEEE/ACM International Conference on Automated Software Engineering.

[222]  Burt M. Leavenworth,et al.  Syntax macros and extended translation , 1966, CACM.

[223]  John D. McGregor,et al.  Testing a Software Product Line , 2001, PSSE.

[224]  Cristina Gacek,et al.  Implementing product line variabilities , 2001, SSR '01.

[225]  Gilad Bracha,et al.  The programming language jigsaw: mixins, modularity and multiple inheritance , 1992 .

[226]  DeLesley Hutchins,et al.  Pure subtype systems : a type theory for extensible software , 2009 .

[227]  Paulo Borba,et al.  Deriving refactorings for AspectJ , 2005, AOSD '05.

[228]  Mads Torgersen The expression problem revisited: Four new solutions using generics , 2004 .

[229]  Matthew J. Parkinson,et al.  The java module system: core design and semantic definition , 2007, OOPSLA.

[230]  Kris De Volder,et al.  Programming with Crosscutting Effective Views , 2004, ECOOP.

[231]  Sven Apel,et al.  Feature featherweight java: a calculus for feature-oriented programming and stepwise refinement , 2008, GPCE '08.

[232]  Ira D. Baxter,et al.  Preprocessor conditional removal by simple partial evaluation , 2001, Proceedings Eighth Working Conference on Reverse Engineering.

[233]  Martin Leucker,et al.  Modeling and Model Checking Software Product Lines , 2008, FMOODS.

[234]  Christian Wende,et al.  FeatureMapper: mapping features to models , 2008, ICSE Companion '08.

[235]  Gunter Saake,et al.  08281 Executive Summary - Software Engineering for Tailor-made Data Management , 2008, Software Engineering for Tailor-made Data Management.

[236]  Martin L. Griss,et al.  Integrating feature modeling with the RSEB , 1998, Proceedings. Fifth International Conference on Software Reuse (Cat. No.98TB100203).

[237]  S. Kotha Mass Customization: The New Frontier in Business Competition , 1992 .

[238]  Sven Apel,et al.  Die Rolle von Features und Aspekten in der Softwareentwicklung (The Role of Features and Aspects in Software Development) , 2008, it Inf. Technol..

[239]  Edsger W. Dijkstra,et al.  A Discipline of Programming , 1976 .

[240]  Charles W. Krueger,et al.  Point - Counterpoint: Being Proactive Pays Off - Eliminating the Adoption , 2002, IEEE Softw..

[241]  Sven Apel,et al.  Visualizing Software Product Line Variabilities in Source Code , 2008, SPLC.

[242]  Paul W. Oman,et al.  Experiences developing and maintaining software in a multi-platform environment , 1997, 1997 Proceedings International Conference on Software Maintenance.

[243]  Pierre-Yves Schobbens,et al.  Generic semantics of feature diagrams , 2007, Comput. Networks.

[244]  Yvonne Coady,et al.  C-CLR: a tool for navigating highly configurable system software , 2007, ACP4IS.

[245]  Shan Shan Huang,et al.  cJ: enhancing java with safe type conditions , 2007, AOSD.

[246]  Arie van Deursen,et al.  Simple crosscutting concerns are not so simple: analysing variability in large-scale idioms-based implementations , 2007, AOSD.

[247]  Klaus Pohl,et al.  Software product line testing , 2006, CACM.

[248]  Matthew Flatt,et al.  Jiazzi: new-age components for old-fasioned Java , 2001, OOPSLA '01.

[249]  Yuanyuan Song,et al.  Modular software design with crosscutting interfaces , 2006, IEEE Software.

[250]  Uwe Aßmann,et al.  Invasive Software Composition , 2003, Springer Berlin Heidelberg.

[251]  Kathi Fisler,et al.  A Case Study in Using ACL 2 for Feature-Oriented Verification , 2004 .

[252]  Don S. Batory,et al.  Safe composition of non-monotonic features , 2009, GPCE '09.

[253]  Jan Bosch,et al.  A taxonomy of variability realization techniques , 2005, Softw. Pract. Exp..

[254]  Sven Apel,et al.  FEATUREHOUSE: Language-independent, automated software composition , 2009, 2009 IEEE 31st International Conference on Software Engineering.

[255]  Don S. Batory,et al.  Scaling step-wise refinement , 2004, IEEE Transactions on Software Engineering.

[256]  David Coppit,et al.  Spotlight: A Prototype Tool for Software Plans , 2007, 29th International Conference on Software Engineering (ICSE'07).

[257]  Yann-Gaël Guéhéneuc,et al.  Feature Location Using Probabilistic Ranking of Methods Based on Execution Scenarios and Information Retrieval , 2007, IEEE Transactions on Software Engineering.

[258]  Michael D. Ernst,et al.  An Empirical Analysis of C Preprocessor Use , 2002, IEEE Trans. Software Eng..

[259]  Daniel Weise,et al.  Programmable syntax macros , 1993, PLDI '93.

[260]  Christopher W. Pidgeon,et al.  DMS®: Program Transformations for Practical Scalable Software Evolution , 2002, IWPSE '02.

[261]  Niklaus Wirth,et al.  Program development by stepwise refinement , 1971, CACM.

[262]  Sagar Sunkle,et al.  Enabling Feature-Oriented Programming in Ruby , 2009 .

[263]  Carl K. Chang,et al.  Event-Based Traceability for Managing Evolutionary Change , 2003, IEEE Trans. Software Eng..

[264]  Bo Nørregaard Jørgensen,et al.  Evolution of Ccollective Object Behavior in Presence of Simultaneous Client-Specific Views , 2003, OOIS.

[265]  Michael Stonebraker,et al.  On rules, procedure, caching and views in data base systems , 1990, SIGMOD '90.

[266]  Marian Vittek Refactoring browser with preprocessor , 2003, Seventh European Conference onSoftware Maintenance and Reengineering, 2003. Proceedings..

[267]  Bjarne Stroustrup,et al.  The Design and Evolution of C , 1994 .

[268]  Audris Mockus,et al.  Using Version Control Data to Evaluate the Impact of Software Tools: A Case Study of the Version Editor , 2002, IEEE Trans. Software Eng..

[269]  Jaejoon Lee,et al.  An Approach for Developing Service Oriented Product Lines , 2008, 2008 12th International Software Product Line Conference.

[270]  Robert Grimm,et al.  On the feasibility of an AOSD approach to Linux kernel extensions , 2008, ACP4IS@AOSD.

[271]  Alfred V. Aho,et al.  Do Crosscutting Concerns Cause Defects? , 2008, IEEE Transactions on Software Engineering.