Table of Contents

Towards Round-Trip Engineering in Model-Driven Software Product Lines

Go back to...

Context

In Software Product Lines (SPLs), commonalities between closely related software products are leveraged by integrating all those products in a single production line. Our Instant Messenger case study is an example of such a product line, where multiple versions of an instant messenger are generated from a central specification, as shown below:

Instant Messenger SPL

This particular SPL is a Model-Driven SPL: it uses models to represent the core architecture and the features, and it uses model transformation to generate the products. The core architecture is represented as a Platform-Independent Model (PIM). In the case of our instant messenger, the PIM is specific to Java client platforms, but it is independent of any specific Java client platform, such as J2ME PP or MIDP. Step-wise refinement transformations defined in ATL are used to replace platform-independent parts in the PIM by platform-specific parts – one step at a time. The end result is a Platform-Specific Model (PSM), which can be translated directly into code.

Problem

The current state of model-driven SPLs does not allow for easy feedback of code changes into the PIM, such that other product variants can benefit from it. In the case of our instant messenger example, code changes need to be copied back manually either to the PIM or the corresponding feature. After that, the other products can be re-generated.

In addition to the fact that having to manually copy back code is very tedious and error-prone, the developer also has to find out where the code has to be copied to. This requires in-depth knowledge of the SPL. This is something that the core architecture team has, but the same cannot be expected from the product development teams.

Objective

In order to propagate back code changes to the models from which it was generated, one can use Round-Trip Engineering (RTE). There currently are a number of existing approaches for RTE, but none of them is really generic. As a consequence, the RTE problem must be solved again for each specific situation. Model transformation languages provide a step towards generic RTE, for example by providing bi-directional transformations.

As a first step, you will focus on the model-to-code step in our Instant Messenger case study. At this moment, code is generated as text, which can be parsed by the Java compiler. In order to perform RTE, our model transformations must be able to read back generated Java code. This can be done by providing the code as a low-level model, which is readable by model transformation engines.

Possible candidates for reading back code as a model are:

Based on such a tool, you will build a framework that can keep the model and code representation of a Java program synchronised. Such a framework will provide generic RTE for all Java code, as the remainder of the RTE can then be done by model transformation.

Advisors

References

Links

The following links are provided in addition to the links given above:

Papers

[2006, inproceedings | www]
M. Antkiewicz and K. Czarnecki, "Framework-Specific Modeling Languages with Round-Trip Engineering." 2006, pp. 692-706.
[2006, phdthesis | www]
E. Van Paesschen, "Advanced Round-Trip Engineering: An Agile Analysis-driven Approach for Dynamic Languages," PhD Thesis , Brussels, Belgium, 2006.
[2003, techreport | www]
A. Henriksson and H. Larsson, "A Definition of Round-trip Engineering," Department of Computer and Information Science, Linköpings Universitet, Linköping, Sweden2003.