The first thing you might think of when you have this use case is creating an ant-script. In our case we wanted to integrate the creating of the diffmodel in the generator-workflow. For that reason we implemented an custom workflow-component.
I was wondering how fast an easy it could be to do that. You only have to extend the Class AbstractEmfWorkflowComponent and fill the method invoke(WorkflowContext ctx, ProgressMonitor monitor,Issues issues). By doing that you could reuse the already done configurations from the workflow. For example the loading of the necessary metamodels and so on .
data:image/s3,"s3://crabby-images/131d5/131d5881eb40b6a1a8930d5b4fd2de6888e96ad2" alt=""
In our special case we wanted to have special parameters. To do that you only have to have getters and setters for that stuff. After implementing the method checkConfiguration(Issues issues) it was possible to check it the necessary parameters have been passed to the Component.
data:image/s3,"s3://crabby-images/bcb8a/bcb8aad3e91986ced56ba6cfc7c0567789e7e35f" alt=""
The next thing that was really cool is that we do not have to persist the diffmodel any more. We only have to pass the result to the modelslot of the Workflow. By doing that the diffmodel could be used by following Components within the Workflow.
data:image/s3,"s3://crabby-images/98bd7/98bd7e70310287e69c9e005667a88bb8662a2fee" alt=""
As you can see from the screenshot of the Workflow the new Component is now well integrated and no extra step is necessary.