Show last authors
1 == Deprecated since 0.14 ==
2 This article is deprecated. The described features are no longer available in current releases.
3
4 = Prom - Project Management in KIELER =
5
6 **Topics**
7
8
9
10 {{toc minLevel="2"/}}
11
12 ----
13
14 == Overview ==
15
16 The KIELER Compiler (KiCo) can generate different code targets from models. For example it is possible to generate C and Java code from an SCT file. As a result KIELER has to integrate with existing development tools and practices for the C and Java world. In the context of embedded systems, the target device also varies heavily.
17
18 Therefore the KIELER Project Management (Prom) has been developed. It eases the creation, compilation and deployment of projects, when using models that can be compiled via KiCo (e.g. SCCharts, Esterel). Furthermore it eases the creation of wrapper code, which is used to deploy, run, or simulate the model.
19
20 The features provided by prom include:
21
22 * Project and file creation **wizards**
23 * An incremental **project builder** that performs several tasks, namely
24 ** Compilation of model files using KiCo
25 ** Template processing to generate code for deployment or simulation
26 ** Compilation of simulation code to an executable
27 * A **DSL** **for configuration** of the project build
28
29 In the following it is explained in further detail how to use and extend these features.
30
31
32 ----
33
34 == Project Wizards ==
35
36 SCCharts can be compiled for example to C using the KIELER Compiler and there is existing tooling for the C language in Eclipse. Using the SCCharts project wizard, such existing tooling for a target language or platform can be re-used.
37
38 Therefore the actual project creation is delegated to another project wizard. Afterwards additional files are created within this newly created project by the SCCharts project wizard. For instance a model file and files for configuration of the build or templates for wrapper code might be added to the project. Further the created project properties are extended with information specific to SCCharts projects, e.g., that the Prom project builder should be used. This approach makes it possible to re-use project wizards from the CDT or JDT and get a working setup with a model file that can be compiled, simulated and deployed with low configuration effort.
39
40 Which project wizard from existing tooling should be used and which files should be created afterwards can be configured in the Eclipse preferences. Pre-defined setups for various languages and target platforms can be created this way.
41
42 == File Wizards ==
43
44 There are various file wizards for the DSL that come with KIELER. These create a file with some default content.
45
46 File wizards exist for
47
48 * SCCharts text files (**sctx** files)
49 * Build configurations (**kibuild** files)
50 * Simulation configurations (**kisim** files)
51 * Simulation visualization configurations (**kivis** files)
52 * Freemarker Templates (**ftl** files)
53
54
55 ----
56
57 == The Project Builder ==
58
59 The incremental project builder is run by Eclipse either in the background when resources changes (//Project > Build automatically//), or manually by the user (//Project > Build Project//). What and how files are built can be configured using a new DSL (kibuild files). Errors and warnings that occur during the build are added as //markers// to the resources where they occur, which is a known concept in the Eclipse IDE. For instance when working with Java, compiler errors are added as markers to files when they are saved. This is now also possible for SCCharts text files and provides faster compiler feedback to users, e.g. because a model can not be compiled, as long as the automatic build is active.
60
61 Several actions are performed when a project is built:
62
63 * Model files are compiled
64 ** Optionally a template is processed for each model to generate the simulation code for the model.
65 * Simulation code is compiled to an executable, which can be started using the new simulation
66 * Freemarker templates are processed to generate code.
67 Depending of the type of the template, additional variables are injected into the template
68 ** //Wrapper code templates// are used to create the wrapper code for a specific model.
69 Annotations on inputs and outputs in the model can be used to define which code snippets are injected as part of the build. These code snippets typically contain code to read or write the corresponding inputs and outputs.
70 ** //Simulation code templates// are used to create wrapper code for simulation of models.
71 Thus it is a special form of wrapper code template. Instead of user defined annotations, the injected code snippets are determined by the variables in the model.
72 This kind of template can be configured as part of a model compiler to automatically generate the simulation for all compiled models.
73 ** //Simple templates// are self contained and no additional variables are injected.
74
75 If all of these are defined, an incremental project build could consist for example of the following steps:
76
77 * Build a model file //A.sctx//
78 ** Afterwards process a simulation template to generate its simulation code //Sim_A.c//
79 * Compile the simulation code //Sim_A.c// to an executable using gcc
80 * Create wrapper code for the model, that is ready to be deployed
81
82 Note that if the //Build automatically// option is set, it is possible to (re-)start a simulation without the need to (re-)compile the corresponding model beforehand. This is because the simulation executable has been created in the background as part of the build and is updated if the model changes. This results in a faster code-test-workflow compared to the previous approach, in which a model was always re-compiled before its simulation was started.
83
84 === Build Configuration via KiBuild ===
85
86 The new project builder is configured using a domain specific language, namely KiBuild. Corresponding to the actions that are performed during the build, its configuration consists of //model compilers//, //simulation compilers// and //template processors//. A template processor is either a //simple template processor//, //wrapper code template processor// or //simulation template processor//.
87
88 When writing the configuration, use code completion to see available attributes for the entities. The following table describes the available attributes.
89
90 (% class="relative-table wrapped" style="width:99.937%" %)
91 |=(((
92 **Attribute**
93 )))|=(((
94 Domain
95 )))|=(% colspan="1" %)(% colspan="1" %)
96 (((
97 Default Value
98 )))|=(((
99 Description
100 )))
101 |(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
102 (((
103 **KiCo Model Compiler**
104 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
105 (((
106
107 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
108 (((
109
110 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
111 (((
112
113 )))
114 |(% colspan="1" %)(% colspan="1" %)
115 (((
116 outputFolder
117 )))|(% colspan="1" %)(% colspan="1" %)
118 (((
119 String
120 )))|(% colspan="1" %)(% colspan="1" %)
121 (((
122 kieler-gen
123 )))|(% colspan="1" %)(% colspan="1" %)
124 (((
125 {{{The folder in which compilation output is saved}}}
126 )))
127 |(% colspan="1" %)(% colspan="1" %)
128 (((
129 whitelist
130 )))|(% colspan="1" %)(% colspan="1" %)
131 (((
132 String, Regular expression
133 )))|(% colspan="1" %)(% colspan="1" %)
134 (((
135 -
136 )))|(% colspan="1" %)(% colspan="1" %)
137 (((
138 Only model files that have a location matching this regular expression are compiled. Thus to compile only a specific model, one can use the expression "ModelName.sctx"
139 )))
140 |(% colspan="1" %)(% colspan="1" %)
141 (((
142 blacklist
143 )))|(% colspan="1" %)(% colspan="1" %)
144 (((
145 String, Regular expression
146 )))|(% colspan="1" %)(% colspan="1" %)
147 (((
148 -
149 )))|(% colspan="1" %)(% colspan="1" %)
150 (((
151 Model files that have a location matching this regular expression are exluded from the build. Thus to exclued all models and skip compilation, one can use ".*", which matches everything.
152 )))
153 |(% colspan="1" %)(% colspan="1" %)
154 (((
155 outputFileExtension
156 )))|(% colspan="1" %)(% colspan="1" %)
157 (((
158 String
159 )))|(% colspan="1" %)(% colspan="1" %)
160 (((
161 c
162 )))|(% colspan="1" %)(% colspan="1" %)
163 (((
164 Compiled models are saved with using this file extension. Thus this attribute should match the code format that is generated by KiCo at the end of the compilation.
165 )))
166 |(% colspan="1" %)(% colspan="1" %)
167 (((
168 outputTemplate
169 )))|(% colspan="1" %)(% colspan="1" %)
170 (((
171 String, Project relative file path
172 )))|(% colspan="1" %)(% colspan="1" %)
173 (((
174 -
175 )))|(% colspan="1" %)(% colspan="1" %)
176 (((
177 An optional template to add surrounding code to KiCo generated output for every compiled file. In the template the placeholder **${kico_code}** can be used an will be replaced with the compiled code.
178 )))
179 |(% colspan="1" %)(% colspan="1" %)
180 (((
181 compileChain
182 )))|(% colspan="1" %)(% colspan="1" %)
183 (((
184 (% class="content-wrapper" %)
185 (((
186 String, Id of a pre-defined compilation system or processor id or a project relative file path to a kico file
187
188 Can also be a list of the above to compile models in several steps
189
190 Can also be a map to define the compilation of different model types
191
192 {{code}}
193 compileChain {
194 sctx: de.cau.cs.kieler.sccharts.netlist.simple
195 strl: de.cau.cs.kieler.esterel.netlist.simple
196 }
197 {{/code}}
198
199
200
201 )))
202 )))|(% colspan="1" %)(% colspan="1" %)
203 (((
204 de.cau.cs.kieler.sccharts.netlist.simple
205 )))|(% colspan="1" %)(% colspan="1" %)
206 (((
207 The compilation system that is used by KiCo to determine the compile chain.
208 )))
209 |(% colspan="1" %)(% colspan="1" %)
210 (((
211 communicateRegisterVariables
212 )))|(% colspan="1" %)(% colspan="1" %)
213 (((
214 Boolean
215 )))|(% colspan="1" %)(% colspan="1" %)
216 (((
217 true
218 )))|(% colspan="1" %)(% colspan="1" %)
219 (((
220 Determines if the variables that save the internal state of a model should be communicated to the simulation generation. If set to false, stepping back and forth in the simulation history will not change the internal state of the model.
221 )))
222 |(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
223 (((
224 **Simulation Compiler**
225 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
226 (((
227
228 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
229 (((
230
231 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
232 (((
233
234 )))
235 |(% colspan="1" %)(% colspan="1" %)
236 (((
237 command
238 )))|(% colspan="1" %)(% colspan="1" %)
239 (((
240 String
241 )))|(% colspan="1" %)(% colspan="1" %)
242 (((
243 For C:
244
245 "gcc -std=c99 -Werror=int-conversion -o \"./${outputFolder}/${executable_name}\""
246
247 For Java:
248
249 "jar cvfe \"../${outputFolder}/${executable_name}\""
250 )))|(% colspan="1" %)(% colspan="1" %)
251 (((
252 The command that is called to compile simulation code to an executable.
253
254 In case of the C simulation, the compiled file is added implicitly as additional parameter, to create an executable.
255
256 In case of Java, all class files and the class file of the compiled model are added implicitly to create an executable JAR file.
257 )))
258 |(% colspan="1" %)(% colspan="1" %)
259 (((
260 outputFolder
261 )))|(% colspan="1" %)(% colspan="1" %)
262 (((
263 String, Project relative folder path
264 )))|(% colspan="1" %)(% colspan="1" %)
265 (((
266 kieler-gen/sim/bin
267 )))|(% colspan="1" %)(% colspan="1" %)
268 (((
269 The folder in which compiled output will be saved.
270
271 Note that it is possible to use a command that creates the compiled files in a different location. However the folder specified in this attribute is created before the command is executed and refreshed afterwards. This ensures that the folder exists and changes will be noticed in the Eclipse workspace.
272 )))
273 |(% colspan="1" %)(% colspan="1" %)
274 (((
275 libFolder
276 )))|(% colspan="1" %)(% colspan="1" %)
277 (((
278 String, Project relative folder path
279 )))|(% colspan="1" %)(% colspan="1" %)
280 (((
281 kieler-gen/sim/lib
282 )))|(% colspan="1" %)(% colspan="1" %)
283 (((
284 The folder where additional files are saved before the command is run. These files can be linked into the simulation code, e.g., for JSON handling.
285 )))
286 |(% colspan="1" %)(% colspan="1" %)
287 (((
288 timeout
289 )))|(% colspan="1" %)(% colspan="1" %)
290 (((
291 int
292 )))|(% colspan="1" %)(% colspan="1" %)
293 (((
294 10
295 )))|(% colspan="1" %)(% colspan="1" %)
296 (((
297 Time in seconds that is waited for the executed command to finish. If the command runs longer, it is assumed to be failed and aborted.
298 )))
299 |(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
300 (((
301 **Template Processor**
302 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
303 (((
304
305 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
306 (((
307
308 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
309 (((
310
311 )))
312 |(% colspan="1" %)(% colspan="1" %)
313 (((
314 file
315 )))|(% colspan="1" %)(% colspan="1" %)
316 (((
317 String, Project relative file path
318 )))|(% colspan="1" %)(% colspan="1" %)
319 (((
320 -
321 )))|(% colspan="1" %)(% colspan="1" %)
322 (((
323 The template file that should be processed
324 )))
325 |(% colspan="1" %)(% colspan="1" %)
326 (((
327 target
328 )))|(% colspan="1" %)(% colspan="1" %)
329 (((
330 String, Project relative file path
331 )))|(% colspan="1" %)(% colspan="1" %)
332 (((
333 -
334 )))|(% colspan="1" %)(% colspan="1" %)
335 (((
336 The file in which the output should be saved
337 )))
338 |(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
339 (((
340 **Wrapper Code Template Processor**
341 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
342 (((
343
344 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
345 (((
346
347 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
348 (((
349
350 )))
351 |(% colspan="1" %)(% colspan="1" %)
352 (((
353 modelFile
354 )))|(% colspan="1" %)(% colspan="1" %)
355 (((
356 String, Project relative file path
357 )))|(% colspan="1" %)(% colspan="1" %)
358 (((
359 -
360 )))|(% colspan="1" %)(% colspan="1" %)
361 (((
362 The model file that is searched for annotations to determine the code snippets to be injected.
363 )))
364 |(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
365 (((
366 **Simulation Code Template Processor**
367 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
368 (((
369
370 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
371 (((
372
373 )))|(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)(% class="highlight-blue" colspan="1" data-highlight-colour="blue" %)
374 (((
375
376 )))
377 |(% colspan="1" %)(% colspan="1" %)
378 (((
379 modelFile
380 )))|(% colspan="1" %)(% colspan="1" %)
381 (((
382 String, Project relative file path
383 )))|(% colspan="1" %)(% colspan="1" %)
384 (((
385 -
386 )))|(% colspan="1" %)(% colspan="1" %)
387 (((
388 The model file that is searched for annotations to determine the code snippets to be injected
389 )))
390 |(% colspan="1" %)(% colspan="1" %)
391 (((
392 compiledModelFile
393 )))|(% colspan="1" %)(% colspan="1" %)
394 (((
395 String, Absolute file system path
396 )))|(% colspan="1" %)(% colspan="1" %)
397 (((
398 -
399 )))|(% colspan="1" %)(% colspan="1" %)
400 (((
401 The absolute path of the compiled model file for which the simulation is created. This is used to replace the placeholder ${compiled_model_loc} in the simulation code template
402 )))
403 |(% colspan="1" %)(% colspan="1" %)
404 (((
405 variables
406 )))|(% colspan="1" %)(% colspan="1" %)
407 (((
408 (% class="content-wrapper" %)
409 (((
410 Map, e.g.,
411
412 {{code}}
413 variables {
414 input: myVar1
415 output: {
416 bool: myVar2
417 int: myVar3[2][3]
418 }
419 }
420 {{/code}}
421 )))
422 )))|(% colspan="1" %)(% colspan="1" %)
423 (((
424 -
425 )))|(% colspan="1" %)(% colspan="1" %)
426 (((
427 Optional additional variables that should be communicated to the outside
428 )))
429 |(% colspan="1" %)(% colspan="1" %)
430 (((
431 interfaceTypes
432 )))|(% colspan="1" %)(% colspan="1" %)
433 (((
434 String, List of Strings
435 )))|(% colspan="1" %)(% colspan="1" %)
436 (((
437 -
438 )))|(% colspan="1" %)(% colspan="1" %)
439 (((
440 The interface types that should be communicated in the simulation, e.g., input, output, internal
441 )))
442
443
444 Example for KiBuild files:
445
446 {{code linenumbers="true" title="Simple KiBuild Example"}}
447 // Compile models to C code
448 model compiler kico {
449 outputFolder: kieler-gen // The folder, in which the compilation output is saved
450 outputFileExtension: c // The file extension for compiled files
451 compileChain: de.cau.cs.kieler.sccharts.netlist.simple // The system that determines the compile chain within the KIELER compiler
452
453 // Generate C simulation for compiled models
454 process simulation template {
455 file: assets/CSimulation.ftl // A template for simulation code
456 }
457 }
458
459 // Compile simulation code
460 simulation compiler c {
461 libFolder: kieler-gen/sim/lib // Create additional libraries required for compilation in this folder
462 outputFolder: kieler-gen/sim/bin // Create the executables in this folder
463 command: "gcc -std=c99 -o ./${outputFolder}/${executable_name} ${file_path} " // Use gcc to compile the code
464 }
465
466
467 {{/code}}
468
469 {{code title="Complex KiBuild Example"}}
470 // Compile models to Java code
471 model compiler kico {
472 outputFolder: kieler-gen
473 outputFileExtension: java
474 outputTemplate: assets/OutputTemplate.ftl
475 compileChain: de.cau.cs.kieler.sccharts.netlist.simple
476 whitelist: "ModelA|ModelB" // Only compile models that match this regex
477
478 // Generate C simulation for compiled models
479 process simulation template {
480 file: assets/JavaSimulation.ftl
481 }
482 }
483
484 // Compile simulation code
485 simulation compiler java {
486 libFolder: kieler-gen/org/json
487 outputFolder: kieler-gen/sim/bin
488 command: "javac -cp kieler-gen -d bin \"${file_path}\" "
489 jarCommand: "jar cvfe \"./${outputFolder}/${executable_name}\" sim.code.${file_basename} -C bin . "
490 }
491
492 // Process a simple template
493 process template {
494 file: Template.ftl
495 target: Output.txt
496 }
497
498 // Process a template to generate a main file that can be deployed.
499 process wrapper template {
500 file: Main.ftl
501 target: kieler-gen/Main.c
502 modelFile: MyModel.sctx
503 }
504
505 // Process a template to generate a simulation for a model that has been compiled with some other framework
506 process simulation template {
507 file: assets/JavaSimulationForOtherModel.ftl
508 target: kieler-gen/Sim_OtherModel.java
509 variables: { // These variables should be communicated to the outside
510 input: a,b,c
511 output: x,y,z
512 }
513 interfaceTypes: input, output // Only communicate these interface types. In this case, internal variables are not communicated.
514 }
515 {{/code}}
516
517
518 ----
519
520 == Project Drafts ==
521
522 Project drafts are used to provide default settings for project creation. They are configured in the **preferences** (//Window //>// Preferences > KIELER SCCharts > Project Drafts//).
523
524 An project draft consists of
525
526 1. a unique **name**, which may not contain a comma
527 1. an **associated** project wizard
528 1. the path of the default **model file** for the project
529 1. the path of the default **main file** for the project
530 1. information about **folders and files** that should be imported at project setup
531
532 Besides the name, all of these are optional, but can improve the workflow.
533
534 The associated project wizard is run as part of the Prom project wizard and takes care of the actual project creation. Afterwards the model file is created and finally other folders and files are imported.
535
536 === Placeholders ===
537
538 There are some placeholders that can be used in initial resources for projects, which are listed below.
539
540 (% class="wrapped" %)
541 |=(((
542 Placeholder
543 )))|=(((
544 Description
545 )))
546 |(((
547 ${project_name}
548 )))|(((
549 Will be replaced with the name of the project that is created
550 )))
551 |(((
552 ${modelFile_path}
553 )))|(((
554 The project relative path of the initial model file
555 )))
556 |(% colspan="1" %)(% colspan="1" %)
557 (((
558 ${modelFile_name}
559 )))|(% colspan="1" %)(% colspan="1" %)
560 (((
561 The name of the initial model file
562 )))
563 |(% colspan="1" %)(% colspan="1" %)
564 (((
565 ${modelFile_basename}
566 )))|(% colspan="1" %)(% colspan="1" %)
567 (((
568 The name of the initial model file without file extension
569 )))
570
571 === Paths for imported resources ===
572
573 To import a resource (folder or file), its project relative path has to be specified. The resource will be created at this location in the project. Furthermore, it is possible to specify initial content for these resources. This is done in the field //origin//. Without an origin specifed, an empty resource will be created.
574
575 To specify intial content for a file, the origin has to be an **absolute file path** or an **URI** with the platform scheme of Eclipse. Such an URI has the form //[[plaftorm:/plugin/a.plugin.name/folder/in/the/plugin/file.txt>>url:http://plaftorm/plugin/a.plugin.name/folder/in/the/plugin/file.txt||shape="rect"]]// Specifying intial content for a folder is analog. Its origin has to be an **absolute directory path** or an **URI** in the form //[[plaftorm:/plugin/a.plugin.name/folder/in/the/plugin>>url:http://plaftorm/plugin/a.plugin.name/folder/in/the/plugin||shape="rect"]]//
576
577 ----
578
579 == Wrapper Code Generation ==
580
581 When modeling a program for an embedded system, it is necessary to set inputs and outputs of physical components (sensors/actuators) to inputs and outputs of the model. This is typically done using wrapper code. However, **wrapper code is often similar** for a specific device and programming language.
582
583 Therefore one can write **wrapper code snippets** for a target device. These can then be injected to a **template file**. What snippets are injected is defined using **annotations on inputs and outputs** directly in the model file.
584
585 In SCT files, annotations are added as in java, with an at-sign e.g. //@Wrapper Clock, "500"//. You can write implicit and explicit wrapper code annotations.
586
587 Explicit annotations have the form **{{code language="none"}}@Wrapper SnippetName, arg1, arg2, ..., argN{{/code}}**. An explicit wrapper annotation raises an error if the snippet does not exist, thus it is **recommened** to use the explicit **@Wrapper** annotation. Every other annotation is tried as wrapper code annotation as well, but will be ignored, if no such snippet could be found. Thus you can write the above explicit annotation as **@SnippetName arg1, arg2, ..., argN**{{code language="none"}}{{/code}}, but there will be no error if the snippet with this name does not exist or could not be found, for example because of a typo.
588
589 **//Note~://** Annotation **names** and parameters are **case sensitive**. That means that //Clock, clock, Floodlight, FloodLight// are all different annotations.
590
591 [[image:attach:wrapper_code_generation_scheme.png]]
592
593 In the **template file** one can use special **placeholders**.
594
595 **${file_name}** is replaced with the name withouth extension of the file that is generated (e.g. //Main.java// will be //Main//).
596
597 **${model_name}** is replaced with the name of the last compiled model.
598
599 **${declarations}** and** ${decls}** will be replaced with additional declarations of variables and functions (<@decl>...</@decl> of a snippet definition). Declarations should occur before the tick loop of the model file. In general they are not required for Java code but may be useful in C applications (e.g. for //extern// calls).
600
601 **${initializations}** and **${inits}** will be replaced with initialization code for components (<@init>...</@init> of a snippet definition). Initialization should occur before the tick loop of the model file.
602
603 **${inputs}** will be replaced with code to set inputs for the model (<@input>...</@input> of a snippet definition). Setting model inputs should occur in the tick loop, before the tick function call.
604
605 **${outputs}** will be replaced with code to read outputs of the model. (<@output>...</@output> of a snippet definition). Reading outputs of the model should occur in the tick loop, after the tick function call.
606
607 **${releases}** will be replaced with code to free allocated resources. (<@release>...</@release> of a snippet definition). Releasing resources should occur after the tick loop at the end of the program.
608
609 [[image:attach:template_file_structure.png]]
610
611 To ease the modification of the template file, one can open it with the text editor the final code will be for. This will enable syntax highlighting and code completion for the langauge, but it will not show any errors. You can open the file for example with the Java Editor of Eclipse using //Right Click > Open With > Other > Java Editor//
612
613 === Simulation templates ===
614
615 The task of the simulation code is to read the inputs from the KIELER user for the simulation, execute a tick, then send the outputs that have been produced back to KIELER. The communication with KIELER is done using a JSON format.
616
617 To create the simulation code, a template is used in which code is injected for each variable in the model to fill the JSON object with the current variable values. This way, the state of the model is communicated to the outside. Before the tick, inputs can be set in the model. Thus there is also code injected for each variable in the model to change its value using a JSON input.
618
619 In conclusion, the simulation code generation is a special form of wrapper code generation. For a simulation template, the injected code snippets are not selected from annotations in the model. Instead code is injected in a specified form for all variables to communicate their states using a JSON format.
620
621 === FreeMarker ===
622
623 The wrapper code injection is done using the open source **template engine [[FreeMarker>>url:http://freemarker.org/||shape="rect"]]**. A wrapper code snippet is basically a [[Macro>>url:http://freemarker.org/docs/ref_directive_macro.html||shape="rect"]] definition of FreeMarker. The Macro is called when the corresponding annotation is found in the model file. The file extension of FreeMarker templates is **.ftl**.
624
625 There is an [[Eclipse plugin>>url:http://freemarker.org/editors.html||shape="rect"]] for FreeMarker as part of the JBoss Tools Project. It can be installed using the Eclipse Marketplace.
626
627
628 Example for wrapper code generation from annotations:
629
630 === [[image:attach:wrapper_code_generation_example.png]] ===
631
632 ----
633
634 == Problem Solving ==
635
636 === CDT Projects ===
637
638 When working with the CDT, the folder that contains the simulation code has to be excluded from the CDT build, because this code is compiled using the compiler specified in the kibuild file, and every simulation file has an additional main function, which is not the use-case that a CDT project is made for. These files are self contained and do not interact with other files in the CDT project, thus they should not be built.
639
640 [[image:attach:cdt_exlude_from_build.png]]
641
642
643 ----