Lets look at the data layer. I generate really simple data classes, they have a getter, setter and field for the value/reference. For this example I don't care about change notification or null checking:
data:image/s3,"s3://crabby-images/0ebbe/0ebbe97b1615313c7d6c1ae171a2f62f4e729ca5" alt=""
As an example I defined a data class Person in actifsource:
data:image/s3,"s3://crabby-images/37f54/37f54ceded4b3f1e40c2294205a9b7fc78eec4c6" alt=""
The template that generates the java class using some helper functions "toJavaType" to translate the actifsource types to java:
data:image/s3,"s3://crabby-images/3d54f/3d54fad51723414c95c3932339151a94683d8492" alt=""
For the second layer I generate a simple viewer for each data structure. There is no need to define additional information in the model, I just use the same data. For simplicity I don't care about the type of the properties and create a text field for each one. In a real world example you might create components instead of frames and create specific controls for each attribute/relation type.
The following two screenshots show the viewer template and the output for person:
data:image/s3,"s3://crabby-images/77e9a/77e9a1bf6aa2c450292f5b4c20e417129853dc2e" alt=""
data:image/s3,"s3://crabby-images/68f88/68f88951b48a0334cfb3e6b63ad25be67240cc63" alt=""
In the viewer template I also added a main-method and the createExampleValue-method with a protected region to create an example value to display. The running example looks like this:
data:image/s3,"s3://crabby-images/e0cf8/e0cf8a39c63d81f17f18129ec5cf474291671859" alt=""
Now I have two layers that will updated every time when I change the model. It is ensured that there is always both a text field in the view and a data field in the data class. Think about a third layer: a network layer with the serialization code is stored or different output format implementations. You even might have implementations or clients/servers in different programming languages (c++, c#, java). In all cases actifsource takes care about consistency, no more trouble due to missing fields or different order in the serialization/deserialization code between the different implementations.
No comments:
Post a Comment