Modular visitor components: A practical solution to the expression families problem (2009)
| Venue: | In ECOOP ’09 |
| Citations: | 4 - 2 self |
BibTeX
@INPROCEEDINGS{Oliveira09modularvisitor,
author = {Bruno C. D. S. Oliveira},
title = {Modular visitor components: A practical solution to the expression families problem},
booktitle = {In ECOOP ’09},
year = {2009}
}
OpenURL
Abstract
Abstract. The expression families problem can be defined as the problem of achieving reusability and composability across the components involved in a family of related datatypes and corresponding operations over those datatypes. Like the traditional expression problem, adding new components (either variants or operations) should be possible while preserving modular and static type-safety. Moreover, different combinations of components should have different type identities and the subtyping relationships between components should be preserved. By generalizing previous work exploring the connection between type-theoretic encodings of datatypes and visitors, we propose two solutions for this problem in Scala using modular visitor components. These components can be grouped into features that can be easily composed in a feature-oriented programming style to obtain customized datatypes and operations. 1







