Skip to main content
aboutsummaryrefslogtreecommitdiffstats
blob: 125f76155df90d05832f5ff23ceb997f67cdbf97 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
package org.eclipse.etrice.generator.c.gen;

import com.google.inject.Inject;
import com.google.inject.Singleton;
import org.eclipse.emf.common.util.EList;
import org.eclipse.etrice.core.room.SubSystemClass;
import org.eclipse.etrice.generator.etricegen.Root;
import org.eclipse.etrice.generator.etricegen.SubSystemInstance;
import org.eclipse.etrice.generator.extensions.RoomExtensions;
import org.eclipse.xtext.generator.JavaIoFileSystemAccess;
import org.eclipse.xtext.xbase.lib.StringExtensions;
import org.eclipse.xtext.xtend2.lib.StringConcatenation;

@SuppressWarnings("all")
@Singleton
public class SubSystemRunnerGen {
  @Inject
  private JavaIoFileSystemAccess fileAccess;
  
  @Inject
  private RoomExtensions roomExt;
  
  public void doGenerate(final Root root) {
    EList<SubSystemInstance> _subSystemInstances = root.getSubSystemInstances();
    for (final SubSystemInstance sc : _subSystemInstances) {
      {
        SubSystemClass _subSystemClass = sc.getSubSystemClass();
        String _generationTargetPath = this.roomExt.getGenerationTargetPath(_subSystemClass);
        SubSystemClass _subSystemClass_1 = sc.getSubSystemClass();
        String _path = this.roomExt.getPath(_subSystemClass_1);
        String _operator_plus = StringExtensions.operator_plus(_generationTargetPath, _path);
        this.fileAccess.setOutputPath(_operator_plus);
        String _name = sc.getName();
        String _operator_plus_1 = StringExtensions.operator_plus(_name, "_Runner.c");
        SubSystemClass _subSystemClass_2 = sc.getSubSystemClass();
        StringConcatenation _generateSourceFile = this.generateSourceFile(root, sc, _subSystemClass_2);
        this.fileAccess.generateFile(_operator_plus_1, _generateSourceFile);
      }
    }
  }
  
  public StringConcatenation generateSourceFile(final Root root, final SubSystemInstance ssi, final SubSystemClass ssc) {
    StringConcatenation _builder = new StringConcatenation();
    _builder.append("/**");
    _builder.newLine();
    _builder.append(" ");
    _builder.append("* @author generated by eTrice");
    _builder.newLine();
    _builder.append(" ");
    _builder.append("*");
    _builder.newLine();
    _builder.append(" ");
    _builder.append("* this class contains the main function running component ");
    String _name = ssi.getName();
    _builder.append(_name, " ");
    _builder.newLineIfNotEmpty();
    _builder.append(" ");
    _builder.append("* it instantiates ");
    String _name_1 = ssi.getName();
    _builder.append(_name_1, " ");
    _builder.append(" and starts and ends the lifecycle");
    _builder.newLineIfNotEmpty();
    _builder.append(" ");
    _builder.append("*/");
    _builder.newLine();
    _builder.newLine();
    _builder.newLine();
    _builder.append("#include \"");
    String _name_2 = ssi.getName();
    _builder.append(_name_2, "");
    _builder.append(".h\"");
    _builder.newLineIfNotEmpty();
    _builder.newLine();
    _builder.append("#include \"etLogger.h\"");
    _builder.newLine();
    _builder.append("#include \"etMSCLogger.h\"");
    _builder.newLine();
    _builder.newLine();
    _builder.newLine();
    _builder.append("/**");
    _builder.newLine();
    _builder.append(" ");
    _builder.append("* main function");
    _builder.newLine();
    _builder.append(" ");
    _builder.append("* creates component and starts and stops the lifecycle");
    _builder.newLine();
    _builder.append(" ");
    _builder.append("*/");
    _builder.newLine();
    _builder.newLine();
    _builder.append("int main(void) {");
    _builder.newLine();
    _builder.newLine();
    _builder.append("\t");
    _builder.append("etLogger_logInfo(\"***   T H E   B E G I N   ***\");");
    _builder.newLine();
    _builder.append("\t");
    _builder.append("ET_MSC_LOGGER_OPEN(\"main\");");
    _builder.newLine();
    _builder.newLine();
    _builder.append("\t");
    _builder.append("/* startup sequence  of lifecycle */");
    _builder.newLine();
    _builder.append("\t");
    String _name_3 = ssi.getName();
    _builder.append(_name_3, "	");
    _builder.append("_init(); \t\t/* lifecycle init */");
    _builder.newLineIfNotEmpty();
    _builder.append("\t");
    String _name_4 = ssi.getName();
    _builder.append(_name_4, "	");
    _builder.append("_start(); \t/* lifecycle start */");
    _builder.newLineIfNotEmpty();
    _builder.newLine();
    _builder.append("\t");
    _builder.append("/* run Scheduler */");
    _builder.newLine();
    _builder.append("\t");
    String _name_5 = ssi.getName();
    _builder.append(_name_5, "	");
    _builder.append("_run();");
    _builder.newLineIfNotEmpty();
    _builder.newLine();
    _builder.append("\t");
    _builder.append("/* shutdown sequence of lifecycle */");
    _builder.newLine();
    _builder.append("\t");
    String _name_6 = ssi.getName();
    _builder.append(_name_6, "	");
    _builder.append("_stop(); \t\t/* lifecycle stop */");
    _builder.newLineIfNotEmpty();
    _builder.append("\t");
    String _name_7 = ssi.getName();
    _builder.append(_name_7, "	");
    _builder.append("_destroy(); \t/* lifecycle destroy */");
    _builder.newLineIfNotEmpty();
    _builder.newLine();
    _builder.append("\t");
    _builder.append("ET_MSC_LOGGER_CLOSE");
    _builder.newLine();
    _builder.append("\t");
    _builder.append("etLogger_logInfo(\"***   T H E   E N D   ***\");");
    _builder.newLine();
    _builder.newLine();
    _builder.append("\t");
    _builder.append("return 0;");
    _builder.newLine();
    _builder.append("}");
    _builder.newLine();
    _builder.newLine();
    return _builder;
  }
}

Back to the top