powertrain-build 1.13.1__py3-none-any.whl → 1.13.3.dev3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. powertrain_build/__init__.py +40 -40
  2. powertrain_build/__main__.py +6 -6
  3. powertrain_build/a2l.py +582 -582
  4. powertrain_build/a2l_merge.py +650 -650
  5. powertrain_build/a2l_templates.py +717 -717
  6. powertrain_build/build.py +985 -985
  7. powertrain_build/build_defs.py +309 -309
  8. powertrain_build/build_proj_config.py +690 -690
  9. powertrain_build/check_interface.py +575 -575
  10. powertrain_build/cli.py +141 -141
  11. powertrain_build/config.py +542 -542
  12. powertrain_build/core.py +395 -395
  13. powertrain_build/core_dummy.py +343 -343
  14. powertrain_build/create_conversion_table.py +73 -73
  15. powertrain_build/dids.py +916 -916
  16. powertrain_build/dummy.py +157 -157
  17. powertrain_build/dummy_spm.py +252 -252
  18. powertrain_build/environmentcheck.py +52 -52
  19. powertrain_build/ext_dbg.py +255 -255
  20. powertrain_build/ext_var.py +327 -327
  21. powertrain_build/feature_configs.py +301 -301
  22. powertrain_build/gen_allsysteminfo.py +227 -227
  23. powertrain_build/gen_label_split.py +449 -449
  24. powertrain_build/handcode_replacer.py +124 -124
  25. powertrain_build/html_report.py +133 -133
  26. powertrain_build/interface/__init__.py +4 -4
  27. powertrain_build/interface/application.py +511 -511
  28. powertrain_build/interface/base.py +500 -500
  29. powertrain_build/interface/csp_api.py +490 -490
  30. powertrain_build/interface/device_proxy.py +677 -677
  31. powertrain_build/interface/ems.py +67 -67
  32. powertrain_build/interface/export_global_vars.py +121 -121
  33. powertrain_build/interface/generate_adapters.py +132 -132
  34. powertrain_build/interface/generate_hi_interface.py +87 -87
  35. powertrain_build/interface/generate_service.py +69 -69
  36. powertrain_build/interface/generate_wrappers.py +147 -147
  37. powertrain_build/interface/generation_utils.py +142 -142
  38. powertrain_build/interface/hal.py +194 -194
  39. powertrain_build/interface/model_yaml_verification.py +348 -348
  40. powertrain_build/interface/service.py +296 -296
  41. powertrain_build/interface/simulink.py +249 -249
  42. powertrain_build/interface/update_call_sources.py +180 -180
  43. powertrain_build/interface/update_model_yaml.py +186 -186
  44. powertrain_build/interface/zone_controller.py +362 -362
  45. powertrain_build/lib/__init__.py +4 -4
  46. powertrain_build/lib/helper_functions.py +127 -127
  47. powertrain_build/lib/logger.py +55 -55
  48. powertrain_build/matlab_scripts/CodeGen/BuildAutomationPyBuild.m +78 -78
  49. powertrain_build/matlab_scripts/CodeGen/Generate_A2L.m +154 -154
  50. powertrain_build/matlab_scripts/CodeGen/generateTLUnit.m +239 -239
  51. powertrain_build/matlab_scripts/CodeGen/getAsilClassification.m +28 -28
  52. powertrain_build/matlab_scripts/CodeGen/modelConfiguredForTL.m +28 -28
  53. powertrain_build/matlab_scripts/CodeGen/moveDefOutports.m +88 -88
  54. powertrain_build/matlab_scripts/CodeGen/parseCalMeasData.m +410 -410
  55. powertrain_build/matlab_scripts/CodeGen/parseCoreIdentifiers.m +139 -139
  56. powertrain_build/matlab_scripts/CodeGen/parseDIDs.m +141 -141
  57. powertrain_build/matlab_scripts/CodeGen/parseInPorts.m +106 -106
  58. powertrain_build/matlab_scripts/CodeGen/parseIncludeConfigs.m +25 -25
  59. powertrain_build/matlab_scripts/CodeGen/parseModelInfo.m +38 -38
  60. powertrain_build/matlab_scripts/CodeGen/parseNVM.m +81 -81
  61. powertrain_build/matlab_scripts/CodeGen/parseOutPorts.m +120 -120
  62. powertrain_build/matlab_scripts/CodeGen/parsePreProcBlks.m +23 -23
  63. powertrain_build/matlab_scripts/CodeGen/struct2JSON.m +128 -128
  64. powertrain_build/matlab_scripts/CodeGen/updateCodeSwConfig.m +31 -31
  65. powertrain_build/matlab_scripts/Init_PyBuild.m +91 -91
  66. powertrain_build/matlab_scripts/__init__.py +2 -2
  67. powertrain_build/matlab_scripts/helperFunctions/Get_Full_Name.m +46 -46
  68. powertrain_build/matlab_scripts/helperFunctions/Get_SrcLines.m +12 -12
  69. powertrain_build/matlab_scripts/helperFunctions/Init_Models.m +78 -78
  70. powertrain_build/matlab_scripts/helperFunctions/Init_Projects.m +67 -67
  71. powertrain_build/matlab_scripts/helperFunctions/Read_Units.m +34 -34
  72. powertrain_build/matlab_scripts/helperFunctions/SetProjectTimeSamples.m +26 -26
  73. powertrain_build/matlab_scripts/helperFunctions/Strip_Suffix.m +16 -16
  74. powertrain_build/matlab_scripts/helperFunctions/followLink.m +118 -118
  75. powertrain_build/matlab_scripts/helperFunctions/getCodeSwitches.m +50 -50
  76. powertrain_build/matlab_scripts/helperFunctions/getConsumerBlocks.m +30 -30
  77. powertrain_build/matlab_scripts/helperFunctions/getDefBlock.m +39 -39
  78. powertrain_build/matlab_scripts/helperFunctions/getDefOutport.m +58 -58
  79. powertrain_build/matlab_scripts/helperFunctions/getDstBlocks.m +19 -19
  80. powertrain_build/matlab_scripts/helperFunctions/getDstLines.m +13 -13
  81. powertrain_build/matlab_scripts/helperFunctions/getInterfaceSignals.m +37 -37
  82. powertrain_build/matlab_scripts/helperFunctions/getName.m +37 -37
  83. powertrain_build/matlab_scripts/helperFunctions/getPath.m +6 -6
  84. powertrain_build/matlab_scripts/helperFunctions/getProperValue.m +21 -21
  85. powertrain_build/matlab_scripts/helperFunctions/getSrcBlocks.m +19 -19
  86. powertrain_build/matlab_scripts/helperFunctions/getSrcLines.m +13 -13
  87. powertrain_build/matlab_scripts/helperFunctions/loadLibraries.m +10 -10
  88. powertrain_build/matlab_scripts/helperFunctions/loadjson.m +6 -6
  89. powertrain_build/matlab_scripts/helperFunctions/modifyEnumStructField.m +21 -21
  90. powertrain_build/matlab_scripts/helperFunctions/removeConfigDuplicates.m +31 -31
  91. powertrain_build/matlab_scripts/helperFunctions/sortSystemByClass.m +26 -26
  92. powertrain_build/matlab_scripts/helperFunctions/tl_getfast.m +89 -89
  93. powertrain_build/matlab_scripts/helperFunctions/topLevelSystem.m +20 -20
  94. powertrain_build/matlab_scripts/helperFunctions/updateModels.m +131 -131
  95. powertrain_build/memory_section.py +224 -224
  96. powertrain_build/nvm_def.py +729 -729
  97. powertrain_build/problem_logger.py +86 -86
  98. powertrain_build/pt_matlab.py +430 -430
  99. powertrain_build/pt_win32.py +144 -144
  100. powertrain_build/replace_compu_tab_ref.py +105 -105
  101. powertrain_build/rte_dummy.py +254 -254
  102. powertrain_build/sched_funcs.py +209 -207
  103. powertrain_build/signal.py +7 -7
  104. powertrain_build/signal_if_html_rep.py +221 -221
  105. powertrain_build/signal_if_html_rep_all.py +302 -302
  106. powertrain_build/signal_incons_html_rep.py +180 -180
  107. powertrain_build/signal_incons_html_rep_all.py +366 -366
  108. powertrain_build/signal_incons_html_rep_base.py +168 -168
  109. powertrain_build/signal_inconsistency_check.py +641 -641
  110. powertrain_build/signal_interfaces.py +864 -864
  111. powertrain_build/templates/Index_SigCheck_All.html +22 -22
  112. powertrain_build/templates/Index_SigIf_All.html +19 -19
  113. powertrain_build/types.py +218 -218
  114. powertrain_build/unit_configs.py +419 -419
  115. powertrain_build/user_defined_types.py +660 -660
  116. powertrain_build/versioncheck.py +66 -66
  117. powertrain_build/wrapper.py +512 -512
  118. powertrain_build/xlrd_csv.py +87 -87
  119. powertrain_build/zone_controller/__init__.py +4 -4
  120. powertrain_build/zone_controller/calibration.py +176 -176
  121. powertrain_build/zone_controller/composition_yaml.py +880 -878
  122. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/METADATA +100 -100
  123. powertrain_build-1.13.3.dev3.dist-info/RECORD +130 -0
  124. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/WHEEL +1 -1
  125. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/licenses/LICENSE +202 -202
  126. powertrain_build-1.13.3.dev3.dist-info/pbr.json +1 -0
  127. powertrain_build-1.13.1.dist-info/RECORD +0 -130
  128. powertrain_build-1.13.1.dist-info/pbr.json +0 -1
  129. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/entry_points.txt +0 -0
  130. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/licenses/AUTHORS +0 -0
  131. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/licenses/NOTICE +0 -0
  132. {powertrain_build-1.13.1.dist-info → powertrain_build-1.13.3.dev3.dist-info}/top_level.txt +0 -0
@@ -1,180 +1,180 @@
1
- # Copyright 2024 Volvo Car Corporation
2
- # Licensed under Apache 2.0.
3
-
4
- """Module containing classes for generation of signal consistency check report."""
5
- from powertrain_build.signal_incons_html_rep_base import SigConsHtmlReportBase
6
-
7
-
8
- class SigConsHtmlReport(SigConsHtmlReportBase):
9
- """Generate html report from the signal consistency check result.
10
-
11
- (see :doc:`signal_interfaces`)
12
-
13
- Inherits :doc:`SigConsHtmlReportBase <signal_incons_html_rep_base>`.
14
- """
15
-
16
- __intro = """<h2 class="nocount">Table of contents</h2>
17
- <ol>
18
- <li><a href="#introduction">Introduction</a></li>
19
- <li><a href="#unit_details">Detailed unit information</a></li>
20
- <li><a href="#ext_sigs">External signals</a>
21
- <ol>
22
- <li><a href="#ext_missing">Missing external signals</a></li>
23
- <li><a href="#ext_unused">Unused external signals</a></li>
24
- </ol></li>
25
- <li><a href="#unit_index">Unit index</a></li>
26
- </ol>
27
- <h2 id="introduction">Introduction</h2>
28
- <p>This documents lists inconsistencies in the internal and external signal configuration.</p>
29
- """
30
-
31
- def __init__(self, res_dict=None):
32
- """Initialize class instance.
33
-
34
- Args:
35
- res_dict (dict): result dict from the signal interface consistency check
36
-
37
- The dict shall have the following format::
38
-
39
- {
40
- "sigs": { "ext": {"missing": {},
41
- "unused": {},
42
- "inconsistent_defs": {}},
43
- "int": {"UNIT_NAME": {"missing": {},
44
- "unused": {},
45
- "multiple_defs": {}
46
- "inconsistent_defs": {}}
47
- }
48
- }
49
- """
50
- super().__init__(res_dict)
51
- self.set_res_dict(res_dict)
52
-
53
- def _gen_unit_toc(self):
54
- """Generate a unit TOC for the unit with signal inconsistencies.
55
-
56
- Hyperlinks to more in depth unit information.
57
- """
58
- out = ' <h2 id="unit_index">Unit index</h2>\n'
59
- for unit in sorted(self._ext_units | self._int_units):
60
- out += f' <div><a href="#{unit}">{unit}</a></div>\n'
61
- return out
62
-
63
- def _gen_units(self):
64
- """Generate all the information regarding all the units."""
65
- out = ' <h2 id="unit_details">Detailed Unit Information</h2>\n'
66
- for unit in sorted(self._ext_units | self._int_units):
67
- out += self._gen_unit(unit)
68
- return out
69
-
70
- def _gen_unit(self, unit):
71
- """Generate the html-report for the unit specific information."""
72
- out = f' <h3 id="{unit}">{unit}</h3>\n'
73
- if unit in self._int_units:
74
- unit_data = self._res_dict['sigs']['int'][unit]
75
- out += self._gen_missing_sigs(unit_data)
76
- out += self._gen_unused_sigs(unit_data)
77
- out += self._gen_multiple_def_sigs(unit_data)
78
- out += self._gen_int_inconsistent_defs(unit_data)
79
- if unit in self._ext_units:
80
- out += self._gen_ext_inconsistent_defs(unit)
81
- return out
82
-
83
- def _gen_missing_sigs(self, unit_data, out=''):
84
- """Generate the unit specific information for missing signal in a unit."""
85
- out = ' <h4>Missing signals</h4>\n' \
86
- ' <p>Inports whose signals are not generated in the ' \
87
- 'listed configuration(s).</p>'
88
- return super()._gen_missing_sigs(unit_data, out)
89
-
90
- def _gen_unused_sigs(self, unit_data, out=''):
91
- """Generate the unit specific information for the unused signals wihtin a unit."""
92
- out = ' <h4>Unused signals</h4>\n' \
93
- ' <p>Outports that are generated, but not used in the ' \
94
- 'listed configuration(s).</p>'
95
- return super()._gen_unused_sigs(unit_data, out)
96
-
97
- def _gen_multiple_def_sigs(self, unit_data, out=''):
98
- """Generate unit specific information for the signals that are generated more than once."""
99
- out = ' <h4>Multiple defined signals</h4>\n' \
100
- ' <p>Outports that are generated more than once in ' \
101
- 'the listed configuration(s).</p>'
102
- return super()._gen_multiple_def_sigs(unit_data, out)
103
-
104
- def _gen_ext_inconsistent_defs(self, unit, out=''):
105
- """Generate a report of inconsistent variable definition parameters.
106
-
107
- Report inconsistencies between the producing signal definition, and the
108
- signal definitions in the external interface definition.
109
- """
110
- out = ' <h4>External signal inconsistencies</h4>\n' \
111
- ' <p>In-/Out-ports that have different variable definitions ' \
112
- 'than in the interface definition file.</p>'
113
- return super()._gen_ext_inconsistent_defs(unit, out)
114
-
115
- def _gen_int_inconsistent_defs(self, unit_data, out=''):
116
- """Generate a report of inconsistent variable definition parameters.
117
-
118
- Inconsistent for between the producing signal definition, and the
119
- consuming signal definitions for SPM internal signals.
120
- """
121
- out = ' <h4>Internal signal inconsistencies</h4>\n' \
122
- ' <p>Inports that have different variable definitions ' \
123
- 'than the producing outport.</p>'
124
- return super()._gen_int_inconsistent_defs(unit_data, out)
125
-
126
- def _gen_ext_signals_report(self, type_, comment):
127
- """Generate report for external signals."""
128
- out = f' <h3 id="ext_{type_}">{type_.capitalize()} external signals</h3>\n'
129
- out += f'<p>{comment}</p>'
130
- try:
131
- ext_data = self._res_dict['sigs']['ext'][type_]
132
- out += self._table_unused
133
- for var in sorted(ext_data.keys()):
134
- configs = ext_data[var]
135
- out += ' <tr>\n'
136
- out += f' <td>{var}</td>\n'
137
- out += f' <td>{self._set_to_str(configs)}</td>\n'
138
- out += ' </tr>\n'
139
- out += ' </tbody>\n'
140
- out += ' </table>\n'
141
- except KeyError:
142
- pass
143
- return out
144
-
145
- def set_res_dict(self, res_dict):
146
- """Set the result dictionary used to generate the html-report.
147
-
148
- Args:
149
- res_dict (dict): result dict from the signal interface consistency check
150
-
151
- See class constructor for dict structure.
152
- """
153
- self._res_dict = res_dict
154
- self._ext_units = set()
155
- self._int_units = set()
156
- if res_dict is not None and 'sigs' in res_dict:
157
- if 'ext' in res_dict['sigs'] and 'inconsistent_defs' in res_dict['sigs']['ext']:
158
- self._ext_units = set(self._res_dict['sigs']['ext']['inconsistent_defs'].keys())
159
- if 'int' in res_dict['sigs']:
160
- self._int_units = set(self._res_dict['sigs']['int'].keys())
161
-
162
- def gen_contents(self):
163
- """Generate report contents from the signal inconsistency check result dictionary.
164
-
165
- Overrides HtmlReport.gen_contents()
166
- """
167
- html = []
168
- html += self.__intro
169
- html += self._gen_units()
170
- html += ' <h2 id="ext_sigs">Signals missing and unused in the ' \
171
- 'interface definition</h2>\n'
172
- html += self._gen_ext_signals_report('missing', 'Signals not generated by '
173
- 'Vcc SW, but are defined in '
174
- 'the Interface definition to be '
175
- 'generated')
176
- html += self._gen_ext_signals_report('unused', 'Signals defined to be generated by '
177
- 'supplier SW, but are not used '
178
- 'by VCC SW')
179
- html += self._gen_unit_toc()
180
- return ''.join(html)
1
+ # Copyright 2024 Volvo Car Corporation
2
+ # Licensed under Apache 2.0.
3
+
4
+ """Module containing classes for generation of signal consistency check report."""
5
+ from powertrain_build.signal_incons_html_rep_base import SigConsHtmlReportBase
6
+
7
+
8
+ class SigConsHtmlReport(SigConsHtmlReportBase):
9
+ """Generate html report from the signal consistency check result.
10
+
11
+ (see :doc:`signal_interfaces`)
12
+
13
+ Inherits :doc:`SigConsHtmlReportBase <signal_incons_html_rep_base>`.
14
+ """
15
+
16
+ __intro = """<h2 class="nocount">Table of contents</h2>
17
+ <ol>
18
+ <li><a href="#introduction">Introduction</a></li>
19
+ <li><a href="#unit_details">Detailed unit information</a></li>
20
+ <li><a href="#ext_sigs">External signals</a>
21
+ <ol>
22
+ <li><a href="#ext_missing">Missing external signals</a></li>
23
+ <li><a href="#ext_unused">Unused external signals</a></li>
24
+ </ol></li>
25
+ <li><a href="#unit_index">Unit index</a></li>
26
+ </ol>
27
+ <h2 id="introduction">Introduction</h2>
28
+ <p>This documents lists inconsistencies in the internal and external signal configuration.</p>
29
+ """
30
+
31
+ def __init__(self, res_dict=None):
32
+ """Initialize class instance.
33
+
34
+ Args:
35
+ res_dict (dict): result dict from the signal interface consistency check
36
+
37
+ The dict shall have the following format::
38
+
39
+ {
40
+ "sigs": { "ext": {"missing": {},
41
+ "unused": {},
42
+ "inconsistent_defs": {}},
43
+ "int": {"UNIT_NAME": {"missing": {},
44
+ "unused": {},
45
+ "multiple_defs": {}
46
+ "inconsistent_defs": {}}
47
+ }
48
+ }
49
+ """
50
+ super().__init__(res_dict)
51
+ self.set_res_dict(res_dict)
52
+
53
+ def _gen_unit_toc(self):
54
+ """Generate a unit TOC for the unit with signal inconsistencies.
55
+
56
+ Hyperlinks to more in depth unit information.
57
+ """
58
+ out = ' <h2 id="unit_index">Unit index</h2>\n'
59
+ for unit in sorted(self._ext_units | self._int_units):
60
+ out += f' <div><a href="#{unit}">{unit}</a></div>\n'
61
+ return out
62
+
63
+ def _gen_units(self):
64
+ """Generate all the information regarding all the units."""
65
+ out = ' <h2 id="unit_details">Detailed Unit Information</h2>\n'
66
+ for unit in sorted(self._ext_units | self._int_units):
67
+ out += self._gen_unit(unit)
68
+ return out
69
+
70
+ def _gen_unit(self, unit):
71
+ """Generate the html-report for the unit specific information."""
72
+ out = f' <h3 id="{unit}">{unit}</h3>\n'
73
+ if unit in self._int_units:
74
+ unit_data = self._res_dict['sigs']['int'][unit]
75
+ out += self._gen_missing_sigs(unit_data)
76
+ out += self._gen_unused_sigs(unit_data)
77
+ out += self._gen_multiple_def_sigs(unit_data)
78
+ out += self._gen_int_inconsistent_defs(unit_data)
79
+ if unit in self._ext_units:
80
+ out += self._gen_ext_inconsistent_defs(unit)
81
+ return out
82
+
83
+ def _gen_missing_sigs(self, unit_data, out=''):
84
+ """Generate the unit specific information for missing signal in a unit."""
85
+ out = ' <h4>Missing signals</h4>\n' \
86
+ ' <p>Inports whose signals are not generated in the ' \
87
+ 'listed configuration(s).</p>'
88
+ return super()._gen_missing_sigs(unit_data, out)
89
+
90
+ def _gen_unused_sigs(self, unit_data, out=''):
91
+ """Generate the unit specific information for the unused signals wihtin a unit."""
92
+ out = ' <h4>Unused signals</h4>\n' \
93
+ ' <p>Outports that are generated, but not used in the ' \
94
+ 'listed configuration(s).</p>'
95
+ return super()._gen_unused_sigs(unit_data, out)
96
+
97
+ def _gen_multiple_def_sigs(self, unit_data, out=''):
98
+ """Generate unit specific information for the signals that are generated more than once."""
99
+ out = ' <h4>Multiple defined signals</h4>\n' \
100
+ ' <p>Outports that are generated more than once in ' \
101
+ 'the listed configuration(s).</p>'
102
+ return super()._gen_multiple_def_sigs(unit_data, out)
103
+
104
+ def _gen_ext_inconsistent_defs(self, unit, out=''):
105
+ """Generate a report of inconsistent variable definition parameters.
106
+
107
+ Report inconsistencies between the producing signal definition, and the
108
+ signal definitions in the external interface definition.
109
+ """
110
+ out = ' <h4>External signal inconsistencies</h4>\n' \
111
+ ' <p>In-/Out-ports that have different variable definitions ' \
112
+ 'than in the interface definition file.</p>'
113
+ return super()._gen_ext_inconsistent_defs(unit, out)
114
+
115
+ def _gen_int_inconsistent_defs(self, unit_data, out=''):
116
+ """Generate a report of inconsistent variable definition parameters.
117
+
118
+ Inconsistent for between the producing signal definition, and the
119
+ consuming signal definitions for SPM internal signals.
120
+ """
121
+ out = ' <h4>Internal signal inconsistencies</h4>\n' \
122
+ ' <p>Inports that have different variable definitions ' \
123
+ 'than the producing outport.</p>'
124
+ return super()._gen_int_inconsistent_defs(unit_data, out)
125
+
126
+ def _gen_ext_signals_report(self, type_, comment):
127
+ """Generate report for external signals."""
128
+ out = f' <h3 id="ext_{type_}">{type_.capitalize()} external signals</h3>\n'
129
+ out += f'<p>{comment}</p>'
130
+ try:
131
+ ext_data = self._res_dict['sigs']['ext'][type_]
132
+ out += self._table_unused
133
+ for var in sorted(ext_data.keys()):
134
+ configs = ext_data[var]
135
+ out += ' <tr>\n'
136
+ out += f' <td>{var}</td>\n'
137
+ out += f' <td>{self._set_to_str(configs)}</td>\n'
138
+ out += ' </tr>\n'
139
+ out += ' </tbody>\n'
140
+ out += ' </table>\n'
141
+ except KeyError:
142
+ pass
143
+ return out
144
+
145
+ def set_res_dict(self, res_dict):
146
+ """Set the result dictionary used to generate the html-report.
147
+
148
+ Args:
149
+ res_dict (dict): result dict from the signal interface consistency check
150
+
151
+ See class constructor for dict structure.
152
+ """
153
+ self._res_dict = res_dict
154
+ self._ext_units = set()
155
+ self._int_units = set()
156
+ if res_dict is not None and 'sigs' in res_dict:
157
+ if 'ext' in res_dict['sigs'] and 'inconsistent_defs' in res_dict['sigs']['ext']:
158
+ self._ext_units = set(self._res_dict['sigs']['ext']['inconsistent_defs'].keys())
159
+ if 'int' in res_dict['sigs']:
160
+ self._int_units = set(self._res_dict['sigs']['int'].keys())
161
+
162
+ def gen_contents(self):
163
+ """Generate report contents from the signal inconsistency check result dictionary.
164
+
165
+ Overrides HtmlReport.gen_contents()
166
+ """
167
+ html = []
168
+ html += self.__intro
169
+ html += self._gen_units()
170
+ html += ' <h2 id="ext_sigs">Signals missing and unused in the ' \
171
+ 'interface definition</h2>\n'
172
+ html += self._gen_ext_signals_report('missing', 'Signals not generated by '
173
+ 'Vcc SW, but are defined in '
174
+ 'the Interface definition to be '
175
+ 'generated')
176
+ html += self._gen_ext_signals_report('unused', 'Signals defined to be generated by '
177
+ 'supplier SW, but are not used '
178
+ 'by VCC SW')
179
+ html += self._gen_unit_toc()
180
+ return ''.join(html)