This paper presents a novel and simple solution to Wadler’s Expression Problem that works in conventional object-oriented languages. Unlike all existing solutions in Java-like languages, this new solution does not use any kind of generics: it relies only on subtyping. The key to the solution is the use of covariant type refinement of return types (or fields): a simple feature available in many object-oriented languages, but not as widely known or used as it should be. We believe that our results present valuable insights for researchers and programming language designers interested in extensibility. Furthermore our results have immediate applicability as practical design patterns for programmers interested in improving extensibility of their programs.
Wed 16 MarDisplayed time zone: Belfast change
| 10:30 - 12:30 | Modular Design and ReasoningResearch Results at MODULARITY  Chair(s): Hridesh Rajan Iowa State University | ||
| 10:3030m Talk | Segregating Feature Interfaces to Support Software Product Line Maintenance Research Results Bruno B. P. Cafeo PUC-Rio, Brazil, Claus Hunsen University of Passau, Germany, Alessandro Garcia PUC-Rio, Brazil, Sven Apel University of Passau, Jaejoon Lee Lancaster University, UKDOI | ||
| 11:0030m Talk | Reasoning Tradeoffs in Languages with Enhanced Modularity Features Research ResultsDOI | ||
| 11:3030m Talk | Unveiling and Reasoning about Co-change Dependencies Research Results Marcos César de Oliveira MPOG, Brazil, Rodrigo Bonifácio University of Brasília, Brazil, Guilherme N. Ramos University of Brasília, Brazil, Márcio Ribeiro Federal University of Alagoas (UFAL)DOI | ||
| 12:0030m Talk | The Expression Problem, Trivially! Research ResultsDOI | ||

