@specs-feup/clava-misra 1.0.0 → 1.0.1

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 (350) hide show
  1. package/.gitignore +117 -0
  2. package/README.md +70 -15
  3. package/dist/MISRA.d.ts +129 -0
  4. package/dist/MISRA.d.ts.map +1 -0
  5. package/dist/MISRA.js +245 -0
  6. package/dist/MISRA.js.map +1 -0
  7. package/dist/MISRAContext.d.ts +21 -0
  8. package/dist/MISRAContext.d.ts.map +1 -0
  9. package/dist/MISRAContext.js +75 -0
  10. package/dist/MISRAContext.js.map +1 -0
  11. package/dist/MISRARule.d.ts +56 -0
  12. package/dist/MISRARule.d.ts.map +1 -0
  13. package/dist/MISRARule.js +45 -0
  14. package/dist/MISRARule.js.map +1 -0
  15. package/dist/MISRATool.d.ts +12 -0
  16. package/dist/MISRATool.d.ts.map +1 -0
  17. package/dist/MISRATool.js +84 -0
  18. package/dist/MISRATool.js.map +1 -0
  19. package/dist/foo.d.ts +2 -0
  20. package/dist/foo.d.ts.map +1 -0
  21. package/{src/foo.ts → dist/foo.js} +3 -2
  22. package/dist/foo.js.map +1 -0
  23. package/dist/main.d.ts +2 -0
  24. package/dist/main.d.ts.map +1 -0
  25. package/dist/main.js +5 -0
  26. package/dist/main.js.map +1 -0
  27. package/dist/misra/MISRAAnalyser.d.ts +14 -0
  28. package/dist/misra/MISRAAnalyser.d.ts.map +1 -0
  29. package/{src/misra/MISRAAnalyser.ts → dist/misra/MISRAAnalyser.js} +13 -23
  30. package/dist/misra/MISRAAnalyser.js.map +1 -0
  31. package/dist/misra/MISRAPass.d.ts +27 -0
  32. package/dist/misra/MISRAPass.d.ts.map +1 -0
  33. package/dist/misra/MISRAPass.js +60 -0
  34. package/dist/misra/MISRAPass.js.map +1 -0
  35. package/dist/misra/MISRAPassResult.d.ts +13 -0
  36. package/dist/misra/MISRAPassResult.d.ts.map +1 -0
  37. package/dist/misra/MISRAPassResult.js +11 -0
  38. package/dist/misra/MISRAPassResult.js.map +1 -0
  39. package/dist/misra/MISRAReporter.d.ts +20 -0
  40. package/dist/misra/MISRAReporter.d.ts.map +1 -0
  41. package/dist/misra/MISRAReporter.js +43 -0
  42. package/dist/misra/MISRAReporter.js.map +1 -0
  43. package/dist/misra/passes/S10_EssentialTypePass.d.ts +42 -0
  44. package/dist/misra/passes/S10_EssentialTypePass.d.ts.map +1 -0
  45. package/dist/misra/passes/S10_EssentialTypePass.js +370 -0
  46. package/dist/misra/passes/S10_EssentialTypePass.js.map +1 -0
  47. package/dist/misra/passes/S12_ExpressionPass.d.ts +18 -0
  48. package/dist/misra/passes/S12_ExpressionPass.d.ts.map +1 -0
  49. package/dist/misra/passes/S12_ExpressionPass.js +72 -0
  50. package/dist/misra/passes/S12_ExpressionPass.js.map +1 -0
  51. package/dist/misra/passes/S13_SideEffectPass.d.ts +18 -0
  52. package/dist/misra/passes/S13_SideEffectPass.d.ts.map +1 -0
  53. package/dist/misra/passes/S13_SideEffectPass.js +105 -0
  54. package/dist/misra/passes/S13_SideEffectPass.js.map +1 -0
  55. package/dist/misra/passes/S15_ControlFlowPass.d.ts +19 -0
  56. package/dist/misra/passes/S15_ControlFlowPass.d.ts.map +1 -0
  57. package/dist/misra/passes/S15_ControlFlowPass.js +94 -0
  58. package/dist/misra/passes/S15_ControlFlowPass.js.map +1 -0
  59. package/dist/misra/passes/S16_SwitchStatementPass.d.ts +17 -0
  60. package/dist/misra/passes/S16_SwitchStatementPass.d.ts.map +1 -0
  61. package/dist/misra/passes/S16_SwitchStatementPass.js +152 -0
  62. package/dist/misra/passes/S16_SwitchStatementPass.js.map +1 -0
  63. package/dist/misra/passes/S17_FunctionPass.d.ts +12 -0
  64. package/dist/misra/passes/S17_FunctionPass.d.ts.map +1 -0
  65. package/dist/misra/passes/S17_FunctionPass.js +38 -0
  66. package/dist/misra/passes/S17_FunctionPass.js.map +1 -0
  67. package/dist/misra/passes/S18_PointersArraysPass.d.ts +17 -0
  68. package/dist/misra/passes/S18_PointersArraysPass.d.ts.map +1 -0
  69. package/dist/misra/passes/S18_PointersArraysPass.js +115 -0
  70. package/dist/misra/passes/S18_PointersArraysPass.js.map +1 -0
  71. package/dist/misra/passes/S19_OverlappingStoragePass.d.ts +11 -0
  72. package/dist/misra/passes/S19_OverlappingStoragePass.d.ts.map +1 -0
  73. package/dist/misra/passes/S19_OverlappingStoragePass.js +20 -0
  74. package/dist/misra/passes/S19_OverlappingStoragePass.js.map +1 -0
  75. package/dist/misra/passes/S21_StandardLibPass.d.ts +20 -0
  76. package/dist/misra/passes/S21_StandardLibPass.d.ts.map +1 -0
  77. package/dist/misra/passes/S21_StandardLibPass.js +77 -0
  78. package/dist/misra/passes/S21_StandardLibPass.js.map +1 -0
  79. package/dist/misra/passes/S3_CommentPass.d.ts +12 -0
  80. package/dist/misra/passes/S3_CommentPass.d.ts.map +1 -0
  81. package/dist/misra/passes/S3_CommentPass.js +27 -0
  82. package/dist/misra/passes/S3_CommentPass.js.map +1 -0
  83. package/dist/misra/passes/S5_IdentifierPass.d.ts +13 -0
  84. package/dist/misra/passes/S5_IdentifierPass.d.ts.map +1 -0
  85. package/dist/misra/passes/S5_IdentifierPass.js +60 -0
  86. package/dist/misra/passes/S5_IdentifierPass.js.map +1 -0
  87. package/dist/misra/passes/S6_TypePass.d.ts +11 -0
  88. package/dist/misra/passes/S6_TypePass.d.ts.map +1 -0
  89. package/dist/misra/passes/S6_TypePass.js +25 -0
  90. package/dist/misra/passes/S6_TypePass.js.map +1 -0
  91. package/dist/misra/passes/S7_LiteralsConstantsPass.d.ts +14 -0
  92. package/dist/misra/passes/S7_LiteralsConstantsPass.d.ts.map +1 -0
  93. package/dist/misra/passes/S7_LiteralsConstantsPass.js +71 -0
  94. package/dist/misra/passes/S7_LiteralsConstantsPass.js.map +1 -0
  95. package/dist/misra/passes/S8_DeclDefPass.d.ts +18 -0
  96. package/dist/misra/passes/S8_DeclDefPass.d.ts.map +1 -0
  97. package/dist/misra/passes/S8_DeclDefPass.js +127 -0
  98. package/dist/misra/passes/S8_DeclDefPass.js.map +1 -0
  99. package/dist/misra/sections/Section10_EssentialTypeModel.d.ts +33 -0
  100. package/dist/misra/sections/Section10_EssentialTypeModel.d.ts.map +1 -0
  101. package/{src/misra/sections/Section10_EssentialTypeModel.ts → dist/misra/sections/Section10_EssentialTypeModel.js} +58 -73
  102. package/dist/misra/sections/Section10_EssentialTypeModel.js.map +1 -0
  103. package/dist/misra/sections/Section11_PointerTypeConversions.d.ts +12 -0
  104. package/dist/misra/sections/Section11_PointerTypeConversions.d.ts.map +1 -0
  105. package/{src/misra/sections/Section11_PointerTypeConversions.ts → dist/misra/sections/Section11_PointerTypeConversions.js} +16 -27
  106. package/dist/misra/sections/Section11_PointerTypeConversions.js.map +1 -0
  107. package/dist/misra/sections/Section12_Expressions.d.ts +15 -0
  108. package/dist/misra/sections/Section12_Expressions.d.ts.map +1 -0
  109. package/dist/misra/sections/Section12_Expressions.js +70 -0
  110. package/dist/misra/sections/Section12_Expressions.js.map +1 -0
  111. package/dist/misra/sections/Section13_SideEffects.d.ts +14 -0
  112. package/dist/misra/sections/Section13_SideEffects.d.ts.map +1 -0
  113. package/dist/misra/sections/Section13_SideEffects.js +90 -0
  114. package/dist/misra/sections/Section13_SideEffects.js.map +1 -0
  115. package/dist/misra/sections/Section14_ControlStmtExprs.d.ts +8 -0
  116. package/dist/misra/sections/Section14_ControlStmtExprs.d.ts.map +1 -0
  117. package/{src/misra/sections/Section14_ControlStmtExprs.ts → dist/misra/sections/Section14_ControlStmtExprs.js} +8 -10
  118. package/dist/misra/sections/Section14_ControlStmtExprs.js.map +1 -0
  119. package/dist/misra/sections/Section15_ControlFlow.d.ts +14 -0
  120. package/dist/misra/sections/Section15_ControlFlow.d.ts.map +1 -0
  121. package/dist/misra/sections/Section15_ControlFlow.js +97 -0
  122. package/dist/misra/sections/Section15_ControlFlow.js.map +1 -0
  123. package/dist/misra/sections/Section16_SwitchStatements.d.ts +13 -0
  124. package/dist/misra/sections/Section16_SwitchStatements.d.ts.map +1 -0
  125. package/{src/misra/sections/Section16_SwitchStatements.ts → dist/misra/sections/Section16_SwitchStatements.js} +49 -74
  126. package/dist/misra/sections/Section16_SwitchStatements.js.map +1 -0
  127. package/dist/misra/sections/Section17_Functions.d.ts +9 -0
  128. package/dist/misra/sections/Section17_Functions.d.ts.map +1 -0
  129. package/{src/misra/sections/Section17_Functions.ts → dist/misra/sections/Section17_Functions.js} +10 -13
  130. package/dist/misra/sections/Section17_Functions.js.map +1 -0
  131. package/dist/misra/sections/Section18_PointersAndArrays.d.ts +13 -0
  132. package/dist/misra/sections/Section18_PointersAndArrays.d.ts.map +1 -0
  133. package/{src/misra/sections/Section18_PointersAndArrays.ts → dist/misra/sections/Section18_PointersAndArrays.js} +36 -40
  134. package/dist/misra/sections/Section18_PointersAndArrays.js.map +1 -0
  135. package/dist/misra/sections/Section19_OverlappingStorage.d.ts +8 -0
  136. package/dist/misra/sections/Section19_OverlappingStorage.d.ts.map +1 -0
  137. package/dist/misra/sections/Section19_OverlappingStorage.js +16 -0
  138. package/dist/misra/sections/Section19_OverlappingStorage.js.map +1 -0
  139. package/dist/misra/sections/Section20_PreprocessingDirectives.d.ts +8 -0
  140. package/dist/misra/sections/Section20_PreprocessingDirectives.d.ts.map +1 -0
  141. package/{src/misra/sections/Section20_PreprocessingDirectives.ts → dist/misra/sections/Section20_PreprocessingDirectives.js} +7 -9
  142. package/dist/misra/sections/Section20_PreprocessingDirectives.js.map +1 -0
  143. package/dist/misra/sections/Section21_StandardLibraries.d.ts +17 -0
  144. package/dist/misra/sections/Section21_StandardLibraries.d.ts.map +1 -0
  145. package/dist/misra/sections/Section21_StandardLibraries.js +54 -0
  146. package/dist/misra/sections/Section21_StandardLibraries.js.map +1 -0
  147. package/dist/misra/sections/Section2_UnusedCode.d.ts +9 -0
  148. package/dist/misra/sections/Section2_UnusedCode.d.ts.map +1 -0
  149. package/{src/misra/sections/Section2_UnusedCode.ts → dist/misra/sections/Section2_UnusedCode.js} +11 -16
  150. package/dist/misra/sections/Section2_UnusedCode.js.map +1 -0
  151. package/dist/misra/sections/Section3_Comments.d.ts +9 -0
  152. package/dist/misra/sections/Section3_Comments.d.ts.map +1 -0
  153. package/{src/misra/sections/Section3_Comments.ts → dist/misra/sections/Section3_Comments.js} +7 -10
  154. package/dist/misra/sections/Section3_Comments.js.map +1 -0
  155. package/dist/misra/sections/Section5_Identifiers.d.ts +12 -0
  156. package/dist/misra/sections/Section5_Identifiers.d.ts.map +1 -0
  157. package/dist/misra/sections/Section5_Identifiers.js +139 -0
  158. package/dist/misra/sections/Section5_Identifiers.js.map +1 -0
  159. package/dist/misra/sections/Section6_Types.d.ts +8 -0
  160. package/dist/misra/sections/Section6_Types.d.ts.map +1 -0
  161. package/dist/misra/sections/Section6_Types.js +23 -0
  162. package/dist/misra/sections/Section6_Types.js.map +1 -0
  163. package/dist/misra/sections/Section7_LiteralsConstants.d.ts +11 -0
  164. package/dist/misra/sections/Section7_LiteralsConstants.d.ts.map +1 -0
  165. package/{src/misra/sections/Section7_LiteralsConstants.ts → dist/misra/sections/Section7_LiteralsConstants.js} +18 -25
  166. package/dist/misra/sections/Section7_LiteralsConstants.js.map +1 -0
  167. package/dist/misra/sections/Section8_DeclarationsDefinitions.d.ts +15 -0
  168. package/dist/misra/sections/Section8_DeclarationsDefinitions.d.ts.map +1 -0
  169. package/{src/misra/sections/Section8_DeclarationsDefinitions.ts → dist/misra/sections/Section8_DeclarationsDefinitions.js} +18 -33
  170. package/dist/misra/sections/Section8_DeclarationsDefinitions.js.map +1 -0
  171. package/dist/misra/tests/utils.d.ts +10 -0
  172. package/dist/misra/tests/utils.d.ts.map +1 -0
  173. package/dist/misra/tests/utils.js +33 -0
  174. package/dist/misra/tests/utils.js.map +1 -0
  175. package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.d.ts +15 -0
  176. package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.d.ts.map +1 -0
  177. package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.js +33 -0
  178. package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.js.map +1 -0
  179. package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.d.ts +16 -0
  180. package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.d.ts.map +1 -0
  181. package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.js +60 -0
  182. package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.js.map +1 -0
  183. package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.d.ts +19 -0
  184. package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.d.ts.map +1 -0
  185. package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.js +42 -0
  186. package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.js.map +1 -0
  187. package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.d.ts +43 -0
  188. package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.d.ts.map +1 -0
  189. package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.js +103 -0
  190. package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.js.map +1 -0
  191. package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.d.ts +26 -0
  192. package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.d.ts.map +1 -0
  193. package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.js +49 -0
  194. package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.js.map +1 -0
  195. package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.d.ts +26 -0
  196. package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.d.ts.map +1 -0
  197. package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.js +49 -0
  198. package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.js.map +1 -0
  199. package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.d.ts +31 -0
  200. package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.d.ts.map +1 -0
  201. package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.js +71 -0
  202. package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.js.map +1 -0
  203. package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.d.ts +27 -0
  204. package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.d.ts.map +1 -0
  205. package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.js +58 -0
  206. package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.js.map +1 -0
  207. package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.d.ts +28 -0
  208. package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.d.ts.map +1 -0
  209. package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.js +44 -0
  210. package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.js.map +1 -0
  211. package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.d.ts +55 -0
  212. package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.d.ts.map +1 -0
  213. package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.js +108 -0
  214. package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.js.map +1 -0
  215. package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.d.ts +43 -0
  216. package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.d.ts.map +1 -0
  217. package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.js +68 -0
  218. package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.js.map +1 -0
  219. package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.d.ts +29 -0
  220. package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.d.ts.map +1 -0
  221. package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.js +53 -0
  222. package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.js.map +1 -0
  223. package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.d.ts +15 -0
  224. package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.d.ts.map +1 -0
  225. package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.js +35 -0
  226. package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.js.map +1 -0
  227. package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.d.ts +13 -0
  228. package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.d.ts.map +1 -0
  229. package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.js +53 -0
  230. package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.js.map +1 -0
  231. package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.d.ts +13 -0
  232. package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.d.ts.map +1 -0
  233. package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.js +32 -0
  234. package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.js.map +1 -0
  235. package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.d.ts +10 -0
  236. package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.d.ts.map +1 -0
  237. package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.js +26 -0
  238. package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.js.map +1 -0
  239. package/dist/rules/index.d.ts +20 -0
  240. package/dist/rules/index.d.ts.map +1 -0
  241. package/dist/rules/index.js +38 -0
  242. package/dist/rules/index.js.map +1 -0
  243. package/dist/tests/Section17_Functions/misra_config.json +10 -0
  244. package/dist/tests/utils.d.ts +10 -0
  245. package/dist/tests/utils.d.ts.map +1 -0
  246. package/dist/tests/utils.js +29 -0
  247. package/dist/tests/utils.js.map +1 -0
  248. package/dist/utils/utils.d.ts +102 -0
  249. package/dist/utils/utils.d.ts.map +1 -0
  250. package/dist/utils/utils.js +202 -0
  251. package/dist/utils/utils.js.map +1 -0
  252. package/jest.config.js +6 -6
  253. package/package.json +40 -8
  254. package/src/MISRA.ts +266 -0
  255. package/src/MISRAContext.ts +91 -0
  256. package/src/MISRARule.ts +77 -0
  257. package/src/MISRATool.ts +96 -0
  258. package/src/main.ts +4 -33
  259. package/src/misra-old/MISRAAnalyser.ts +60 -0
  260. package/src/misra-old/MISRAAnalyserResult.ts +16 -0
  261. package/src/misra-old/sections/Section10_EssentialTypeModel.ts +377 -0
  262. package/src/misra-old/sections/Section11_PointerTypeConversions.ts +104 -0
  263. package/src/{misra → misra-old}/sections/Section12_Expressions.ts +7 -7
  264. package/src/{misra → misra-old}/sections/Section13_SideEffects.ts +15 -15
  265. package/src/misra-old/sections/Section14_ControlStmtExprs.ts +27 -0
  266. package/src/{misra → misra-old}/sections/Section15_ControlFlow.ts +10 -10
  267. package/src/misra-old/sections/Section18_PointersAndArrays.ts +108 -0
  268. package/src/{misra → misra-old}/sections/Section19_OverlappingStorage.ts +4 -4
  269. package/src/misra-old/sections/Section20_PreprocessingDirectives.ts +22 -0
  270. package/src/misra-old/sections/Section21_StandardLibraries.ts +99 -0
  271. package/src/{misra → misra-old}/sections/Section5_Identifiers.ts +16 -15
  272. package/src/{misra → misra-old}/sections/Section6_Types.ts +4 -4
  273. package/src/misra-old/sections/Section7_LiteralsConstants.ts +76 -0
  274. package/src/misra-old/sections/Section8_DeclarationsDefinitions.ts +133 -0
  275. package/src/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.ts +40 -0
  276. package/src/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.ts +69 -0
  277. package/src/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.ts +46 -0
  278. package/src/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.ts +113 -0
  279. package/src/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.ts +57 -0
  280. package/src/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.ts +56 -0
  281. package/src/rules/Section17_Functions/Rule_17_4_NonVoidReturn.ts +78 -0
  282. package/src/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.ts +68 -0
  283. package/src/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.ts +47 -0
  284. package/src/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.ts +120 -0
  285. package/src/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.ts +75 -0
  286. package/src/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.ts +60 -0
  287. package/src/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.ts +46 -0
  288. package/src/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.ts +65 -0
  289. package/src/rules/Section3_Comments/Rule_3_1_CommentSequences.ts +41 -0
  290. package/src/rules/Section3_Comments/Rule_3_2_LineSplicing.ts +36 -0
  291. package/src/rules/index.ts +40 -0
  292. package/src/tests/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.test.ts +55 -0
  293. package/src/tests/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.test.ts +70 -0
  294. package/src/tests/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.test.ts +128 -0
  295. package/src/tests/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.test.ts +132 -0
  296. package/src/tests/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.test.ts +146 -0
  297. package/src/tests/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.test.ts +102 -0
  298. package/src/tests/Section17_Functions/Rule_17_4_NonVoidReturn.test.ts +85 -0
  299. package/src/tests/Section17_Functions/Rule_17_4_NonVoidReturn_MissingConfig.test.ts +77 -0
  300. package/src/tests/Section17_Functions/Rule_17_6_StaticArraySizeParam.test.ts +36 -0
  301. package/src/tests/Section17_Functions/Rule_17_7_UnusedReturnValue.test.ts +44 -0
  302. package/src/tests/Section17_Functions/misra_config.json +10 -0
  303. package/src/tests/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.test.ts +175 -0
  304. package/src/tests/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.test.ts +219 -0
  305. package/src/tests/Section2_UnusedCode/Rule_2_6_UnusedLabels.test.ts +49 -0
  306. package/src/tests/Section2_UnusedCode/Rule_2_7_UnusedParameters.test.ts +55 -0
  307. package/src/tests/Section3_Comments/Rule_3_1_CommentSequences.test.ts +37 -0
  308. package/src/tests/utils.ts +39 -0
  309. package/src/utils/utils.ts +221 -0
  310. package/tsconfig.json +4 -3
  311. package/typedoc.config.js +1 -1
  312. package/CxxSources/lib.cpp +0 -3
  313. package/CxxSources/lib.h +0 -8
  314. package/CxxSources/main.cpp +0 -40
  315. package/TODO.md +0 -1
  316. package/consumer_order.txt +0 -2
  317. package/enum_integer_type.txt +0 -0
  318. package/is_temporary.txt +0 -0
  319. package/omp.txt +0 -0
  320. package/src/misra/passes/S16_SwitchStatementPass.ts +0 -168
  321. package/src/misra/passes/S3_CommentPass.ts +0 -40
  322. package/src/misra/sections/Section21_StandardLibraries.ts +0 -65
  323. package/src/misra/tests/S10_EssentialTypes.test.ts +0 -253
  324. package/src/misra/tests/S12_Expressions.test.ts +0 -43
  325. package/src/misra/tests/S13_SideEffects.test.ts +0 -77
  326. package/src/misra/tests/S15_ControlFlow.test.ts +0 -144
  327. package/src/misra/tests/S16_SwitchStatements.test.ts +0 -164
  328. package/src/misra/tests/S17_Functions.test.ts +0 -46
  329. package/src/misra/tests/S18_PointersArrays.test.ts +0 -167
  330. package/src/misra/tests/S19_OverlappingStorage.test.ts +0 -38
  331. package/src/misra/tests/S3_Comments.test.ts +0 -36
  332. package/src/misra/tests/S6_Types.test.ts +0 -36
  333. package/src/misra/tests/S7_LiteralsConstants.test.ts +0 -48
  334. package/src/misra/tests/utils.ts +0 -47
  335. package/types_with_templates.txt +0 -0
  336. /package/src/{misra → misra-old}/MISRAPass.ts +0 -0
  337. /package/src/{misra → misra-old}/MISRAPassResult.ts +0 -0
  338. /package/src/{misra → misra-old}/MISRAReporter.ts +0 -0
  339. /package/src/{misra → misra-old}/passes/S10_EssentialTypePass.ts +0 -0
  340. /package/src/{misra → misra-old}/passes/S12_ExpressionPass.ts +0 -0
  341. /package/src/{misra → misra-old}/passes/S13_SideEffectPass.ts +0 -0
  342. /package/src/{misra → misra-old}/passes/S15_ControlFlowPass.ts +0 -0
  343. /package/src/{misra → misra-old}/passes/S17_FunctionPass.ts +0 -0
  344. /package/src/{misra → misra-old}/passes/S18_PointersArraysPass.ts +0 -0
  345. /package/src/{misra → misra-old}/passes/S19_OverlappingStoragePass.ts +0 -0
  346. /package/src/{misra → misra-old}/passes/S21_StandardLibPass.ts +0 -0
  347. /package/src/{misra → misra-old}/passes/S5_IdentifierPass.ts +0 -0
  348. /package/src/{misra → misra-old}/passes/S6_TypePass.ts +0 -0
  349. /package/src/{misra → misra-old}/passes/S7_LiteralsConstantsPass.ts +0 -0
  350. /package/src/{misra → misra-old}/passes/S8_DeclDefPass.ts +0 -0
@@ -0,0 +1,75 @@
1
+ import { MISRAError } from "./MISRA.js";
2
+ import * as fs from 'fs';
3
+ /**
4
+ * Tracks MISRA errors and warnings during the analysis and/or transformation of the code.
5
+ * Also generated unique variable and function names.
6
+ */
7
+ export default class MISRAContext {
8
+ /**
9
+ * List of MISRA errors, that could not be resolved during the transformation process
10
+ */
11
+ #misraErrors = [];
12
+ /**
13
+ * List of MISRA warnings generated by transformations that may alter the program's behavior
14
+ */
15
+ #misraWarnings = [];
16
+ /**
17
+ * Configuration provided by the user to assist in rule corrections
18
+ */
19
+ #config = undefined;
20
+ #varCounter = 0;
21
+ #funcCounter = 0;
22
+ #headerCounter = 0;
23
+ #varPrefix = "__misra_var_";
24
+ #funcPrefix = "__misra_func_";
25
+ #headerPrefix = "misra_hdr_";
26
+ get errors() {
27
+ return this.#misraErrors;
28
+ }
29
+ get warnings() {
30
+ return this.#misraWarnings;
31
+ }
32
+ get config() {
33
+ return this.#config;
34
+ }
35
+ set config(configFilePath) {
36
+ if (fs.existsSync(configFilePath)) {
37
+ const data = fs.readFileSync(configFilePath, 'utf-8');
38
+ this.#config = new Map(Object.entries(JSON.parse(data)));
39
+ }
40
+ else {
41
+ console.error(`[Clava-MISRATool] Provided configuration file was not found.`);
42
+ process.exit(1);
43
+ }
44
+ }
45
+ generateVarName() {
46
+ return `${this.#varPrefix}${this.#varCounter++}`;
47
+ }
48
+ generateFuncName() {
49
+ return `${this.#funcPrefix}${this.#funcCounter++}`;
50
+ }
51
+ generateHeaderFilename() {
52
+ return `${this.#headerPrefix}${this.#headerCounter++}.h`;
53
+ }
54
+ addMISRAError(ruleID, $jp, message) {
55
+ const newError = new MISRAError(ruleID, $jp, message);
56
+ if (!this.#misraErrors.some(error => error.equals(newError))) {
57
+ this.#misraErrors.push(newError);
58
+ }
59
+ }
60
+ addMISRAWarning(ruleID, $jp, message) {
61
+ const newWarning = new MISRAError(ruleID, $jp, message);
62
+ if (!this.#misraWarnings.some(warning => warning.equals(newWarning))) {
63
+ this.#misraWarnings.push(newWarning);
64
+ }
65
+ }
66
+ printErrors() {
67
+ this.#misraErrors.forEach(error => console.log(error.message));
68
+ console.log('\n');
69
+ }
70
+ printWarnings() {
71
+ this.#misraWarnings.forEach(warning => console.log(warning.message));
72
+ console.log('\n');
73
+ }
74
+ }
75
+ //# sourceMappingURL=MISRAContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAContext.js","sourceRoot":"","sources":["../src/MISRAContext.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,56 @@
1
+ import { Joinpoint } from "@specs-feup/clava/api/Joinpoints.js";
2
+ import MISRAContext from "./MISRAContext.js";
3
+ import { MISRATransformationReport } from "./MISRA.js";
4
+ /**
5
+ * Represents a MISRA Rule that detects and corrects violations in the code according to MISRA standards.
6
+ *
7
+ * Need to implement:
8
+ * - match($jp, logErrors)
9
+ * - transform($jp)
10
+ */
11
+ export default abstract class MISRARule {
12
+ /**
13
+ * Unique identifier for the MISRA rule.
14
+ */
15
+ readonly ruleID: string;
16
+ /**
17
+ * MISRA context for error tracking and rule transformations state
18
+ */
19
+ protected context: MISRAContext;
20
+ /**
21
+ *
22
+ * @param ruleID - Unique identifier for the MISRA-C rule
23
+ * @param context - MISRA context for error tracking and rule transformations state
24
+ */
25
+ constructor(ruleID: string, context: MISRAContext);
26
+ /**
27
+ * Checks if the joinpoint violates the rule
28
+ *
29
+ * @param $jp - Joinpoint to analyze
30
+ * @param logErrors - [logErrors=false] - Whether to log errors if a violation is detected
31
+ * @returns Returns true if the joinpoint violates the rule, false otherwise
32
+ */
33
+ abstract match($jp: Joinpoint, logErrors: boolean): boolean;
34
+ /**
35
+ * Transforms the joinpoint to comply with the MISRA-C rule
36
+ *
37
+ * @param $jp - Joinpoint to transform
38
+ * @returns Report detailing the transformation result
39
+ */
40
+ abstract transform($jp: Joinpoint): MISRATransformationReport;
41
+ /**
42
+ * Logs a MISRA-C rule violation error
43
+ *
44
+ * @param $jp - The joinpoint where the violation occurred
45
+ * @param msg - Description of the violation
46
+ */
47
+ protected logMISRAError($jp: Joinpoint, msg: string): void;
48
+ /**
49
+ * Logs a warning from automatic MISRA-C correction, which may change the program's behavior
50
+ *
51
+ * @param $jp - The joinpoint where the correction was applied
52
+ * @param msg - Description of the warning
53
+ */
54
+ protected logMISRAWarning($jp: Joinpoint, msg: string): void;
55
+ }
56
+ //# sourceMappingURL=MISRARule.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRARule.d.ts","sourceRoot":"","sources":["../src/MISRARule.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAChE,OAAO,YAAY,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,yBAAyB,EAAE,MAAM,YAAY,CAAC;AAEvD;;;;;;GAMG;AACH,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,SAAS;IACnC;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IAExB;;OAEG;IACH,SAAS,CAAC,OAAO,EAAE,YAAY,CAAC;IAEhC;;;;OAIG;gBACS,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY;IAKjD;;;;;;OAMG;IACH,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,GAAG,OAAO;IAE3D;;;;;OAKG;IACH,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,GAAG,yBAAyB;IAE7D;;;;;OAKG;IACH,SAAS,CAAC,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,GAAG,IAAI;IAQzD;;;;;OAKG;IACH,SAAS,CAAC,eAAe,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,GAAG,IAAI;CAO9D"}
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Represents a MISRA Rule that detects and corrects violations in the code according to MISRA standards.
3
+ *
4
+ * Need to implement:
5
+ * - match($jp, logErrors)
6
+ * - transform($jp)
7
+ */
8
+ export default class MISRARule {
9
+ /**
10
+ * Unique identifier for the MISRA rule.
11
+ */
12
+ ruleID;
13
+ /**
14
+ * MISRA context for error tracking and rule transformations state
15
+ */
16
+ context;
17
+ /**
18
+ *
19
+ * @param ruleID - Unique identifier for the MISRA-C rule
20
+ * @param context - MISRA context for error tracking and rule transformations state
21
+ */
22
+ constructor(ruleID, context) {
23
+ this.ruleID = ruleID;
24
+ this.context = context;
25
+ }
26
+ /**
27
+ * Logs a MISRA-C rule violation error
28
+ *
29
+ * @param $jp - The joinpoint where the violation occurred
30
+ * @param msg - Description of the violation
31
+ */
32
+ logMISRAError($jp, msg) {
33
+ this.context.addMISRAError(this.ruleID, $jp, `MISRA-C Rule ${this.ruleID} violation at ${$jp.filepath}@${$jp.line}:${$jp.column}: ${msg}`);
34
+ }
35
+ /**
36
+ * Logs a warning from automatic MISRA-C correction, which may change the program's behavior
37
+ *
38
+ * @param $jp - The joinpoint where the correction was applied
39
+ * @param msg - Description of the warning
40
+ */
41
+ logMISRAWarning($jp, msg) {
42
+ this.context.addMISRAWarning(this.ruleID, $jp, `Warning: MISRA-C Rule ${this.ruleID} correction at ${$jp.filepath}@${$jp.line}:${$jp.column}: ${msg}.`);
43
+ }
44
+ }
45
+ //# sourceMappingURL=MISRARule.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRARule.js","sourceRoot":"","sources":["../src/MISRARule.ts"],"names":[],"mappings":"AAIA;;;;;;GAMG;AACH,MAAM,CAAC,OAAO,OAAgB,SAAS;IACnC;;OAEG;IACM,MAAM,CAAS;IAExB;;OAEG;IACO,OAAO,CAAe;IAEhC;;;;OAIG;IACH,YAAY,MAAc,EAAE,OAAqB;QAC7C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IAC3B,CAAC;IAmBD;;;;;OAKG;IACO,aAAa,CAAC,GAAc,EAAE,GAAU;QAC9C,IAAI,CAAC,OAAO,CAAC,aAAa,CACtB,IAAI,CAAC,MAAM,EACX,GAAG,EACH,gBAAgB,IAAI,CAAC,MAAM,iBAAiB,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,EAAE,CAC/F,CAAA;IACL,CAAC;IAED;;;;;OAKG;IACO,eAAe,CAAC,GAAc,EAAE,GAAU;QAChD,IAAI,CAAC,OAAO,CAAC,eAAe,CACxB,IAAI,CAAC,MAAM,EACX,GAAG,EACH,yBAAyB,IAAI,CAAC,MAAM,kBAAkB,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,GAAG,CAC1G,CAAA;IACL,CAAC;CACJ"}
@@ -0,0 +1,12 @@
1
+ import { FileJp, Program } from "@specs-feup/clava/api/Joinpoints.js";
2
+ import { MISRAError } from "./MISRA.js";
3
+ export default class MISRATool {
4
+ #private;
5
+ private static init;
6
+ private static validateStdVersion;
7
+ static checkCompliance(startingPoint?: Program | FileJp): void;
8
+ static applyCorrections(configFilePath?: string, startingPoint?: Program | FileJp): void;
9
+ private static transformAST;
10
+ static getMISRAErrors(): MISRAError[];
11
+ }
12
+ //# sourceMappingURL=MISRATool.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRATool.d.ts","sourceRoot":"","sources":["../src/MISRATool.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAa,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAIjF,OAAO,EAAE,UAAU,EAA2B,MAAM,YAAY,CAAC;AAEjE,MAAM,CAAC,OAAO,OAAO,SAAS;;IAI1B,OAAO,CAAC,MAAM,CAAC,IAAI;IAMnB,OAAO,CAAC,MAAM,CAAC,kBAAkB;WAUnB,eAAe,CAAC,aAAa,GAAE,OAAO,GAAG,MAAgC;WAgBzE,gBAAgB,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,aAAa,GAAE,OAAO,GAAG,MAAgC;IA2BjH,OAAO,CAAC,MAAM,CAAC,YAAY;WAsBb,cAAc,IAAI,UAAU,EAAE;CAG/C"}
@@ -0,0 +1,84 @@
1
+ import Query from "@specs-feup/lara/api/weaver/Query.js";
2
+ import { Program } from "@specs-feup/clava/api/Joinpoints.js";
3
+ import misraRules from "./rules/index.js";
4
+ import MISRAContext from "./MISRAContext.js";
5
+ import { MISRATransformationType } from "./MISRA.js";
6
+ export default class MISRATool {
7
+ static #misraRules;
8
+ static #context;
9
+ static init(startingPoint) {
10
+ this.validateStdVersion(startingPoint);
11
+ this.#context = new MISRAContext();
12
+ this.#misraRules = misraRules(this.#context);
13
+ }
14
+ static validateStdVersion(startingPoint) {
15
+ const allowedVersions = ["c90", "c99", "c11"];
16
+ const stdVersion = startingPoint instanceof Program ? startingPoint.standard : startingPoint.root.standard;
17
+ if (!allowedVersions.includes(stdVersion)) {
18
+ console.error(`[Clava-MISRATool] Invalid --std value. Allowed values: ${allowedVersions.join(", ")}`);
19
+ process.exit(1);
20
+ }
21
+ }
22
+ static checkCompliance(startingPoint = Query.root()) {
23
+ this.init(startingPoint);
24
+ const nodes = startingPoint.descendants;
25
+ for (const node of nodes) {
26
+ for (const rule of this.#misraRules) {
27
+ rule.match(node, true);
28
+ }
29
+ }
30
+ if (this.#context.errors.length > 0) {
31
+ this.#context.printErrors();
32
+ }
33
+ else {
34
+ console.log("[Clava-MISRATool] No MISRA-C violations detected.");
35
+ }
36
+ }
37
+ static applyCorrections(configFilePath, startingPoint = Query.root()) {
38
+ this.init(startingPoint);
39
+ if (configFilePath) {
40
+ this.#context.config = configFilePath;
41
+ }
42
+ let iteration = 0;
43
+ let modified = false;
44
+ do {
45
+ console.log(`[Clava-MISRATool] Iteration #${++iteration}: Applying MISRA-C transformations...`);
46
+ modified = this.transformAST(startingPoint);
47
+ } while (modified);
48
+ if (this.#context.errors.length === 0 && this.#context.warnings.length === 0) {
49
+ console.log("[Clava-MISRATool] All detected violations were corrected.");
50
+ }
51
+ else {
52
+ if (this.#context.warnings.length > 0) {
53
+ console.log("\n[Clava-MISRATool] Warnings from automatic MISRA-C corrections (these may change the program's behavior):");
54
+ this.#context.printWarnings();
55
+ }
56
+ if (this.#context.errors.length > 0) {
57
+ console.log("\n[Clava-MISRATool] Remaining MISRA-C violations:");
58
+ this.#context.printErrors();
59
+ }
60
+ }
61
+ }
62
+ static transformAST($jp) {
63
+ let modified = false;
64
+ for (const rule of this.#misraRules) {
65
+ const transformReport = rule.transform($jp);
66
+ if (transformReport.type !== MISRATransformationType.NoChange) {
67
+ modified = true;
68
+ if (transformReport.type === MISRATransformationType.Removal)
69
+ return modified;
70
+ else if (transformReport.type === MISRATransformationType.Replacement)
71
+ $jp = transformReport.newNode;
72
+ }
73
+ }
74
+ for (const child of $jp.children) {
75
+ if (this.transformAST(child))
76
+ modified = true;
77
+ }
78
+ return modified;
79
+ }
80
+ static getMISRAErrors() {
81
+ return this.#context.errors;
82
+ }
83
+ }
84
+ //# sourceMappingURL=MISRATool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRATool.js","sourceRoot":"","sources":["../src/MISRATool.ts"],"names":[],"mappings":"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"}
package/dist/foo.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export declare function foo(): number;
2
+ //# sourceMappingURL=foo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"foo.d.ts","sourceRoot":"","sources":["../src/foo.ts"],"names":[],"mappings":"AAGA,wBAAgB,GAAG,WAElB"}
@@ -1,6 +1,7 @@
1
1
  import { FunctionJp } from "@specs-feup/clava/api/Joinpoints.js";
2
2
  import Query from "@specs-feup/lara/api/weaver/Query.js";
3
-
4
3
  export function foo() {
5
4
  return Query.search(FunctionJp).get().length;
6
- };
5
+ }
6
+ ;
7
+ //# sourceMappingURL=foo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"foo.js","sourceRoot":"","sources":["../src/foo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAC;AACjE,OAAO,KAAK,MAAM,sCAAsC,CAAC;AAEzD,MAAM,UAAU,GAAG;IACf,OAAO,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC;AACjD,CAAC;AAAA,CAAC"}
package/dist/main.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=main.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":""}
package/dist/main.js ADDED
@@ -0,0 +1,5 @@
1
+ import MISRATool from "./MISRATool.js";
2
+ MISRATool.checkCompliance();
3
+ MISRATool.applyCorrections();
4
+ //await VisualizationTool.visualize();
5
+ //# sourceMappingURL=main.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,gBAAgB,CAAC;AAEvC,SAAS,CAAC,eAAe,EAAE,CAAC;AAC5B,SAAS,CAAC,gBAAgB,EAAE,CAAC;AAE7B,sCAAsC"}
@@ -0,0 +1,14 @@
1
+ import Analyser from "@specs-feup/clava/api/clava/analysis/Analyser.js";
2
+ import { FileJp, Joinpoint, Program } from "@specs-feup/clava/api/Joinpoints.js";
3
+ import Fix from "@specs-feup/clava/api/clava/analysis/Fix.js";
4
+ type T = Program | FileJp;
5
+ export default abstract class MISRAAnalyser extends Analyser {
6
+ #private;
7
+ protected abstract ruleMapper: Map<number, (jp: T) => void>;
8
+ constructor(rules: number[]);
9
+ get rules(): number[];
10
+ protected logMISRAError(jp: Joinpoint, message: string, fix?: Fix): void;
11
+ analyse($startNode?: T): import("@specs-feup/clava/api/clava/analysis/ResultList.js").default | undefined;
12
+ }
13
+ export {};
14
+ //# sourceMappingURL=MISRAAnalyser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAAnalyser.d.ts","sourceRoot":"","sources":["../../src/misra/MISRAAnalyser.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,MAAM,kDAAkD,CAAC;AAExE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAEjF,OAAO,GAAG,MAAM,6CAA6C,CAAC;AAE9D,KAAK,CAAC,GAAG,OAAO,GAAG,MAAM,CAAC;AAE1B,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,aAAc,SAAQ,QAAQ;;IAGxD,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC;gBAGhD,KAAK,EAAE,MAAM,EAAE;IAK3B,IAAI,KAAK,IAAI,MAAM,EAAE,CAAqC;IAE1D,SAAS,CAAC,aAAa,CAAC,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG;IAIjE,OAAO,CAAC,UAAU,GAAE,CAA2B;CAgBlD"}
@@ -1,43 +1,33 @@
1
1
  import Query from "@specs-feup/lara/api/weaver/Query.js";
2
2
  import Analyser from "@specs-feup/clava/api/clava/analysis/Analyser.js";
3
3
  import AnalyserResult from "@specs-feup/clava/api/clava/analysis/AnalyserResult.js";
4
- import { FileJp, Joinpoint, Program } from "@specs-feup/clava/api/Joinpoints.js";
5
- import ResultFormatManager from "@specs-feup/clava/api/clava/analysis/ResultFormatManager.js"
6
- import Fix from "@specs-feup/clava/api/clava/analysis/Fix.js";
7
-
8
- type T = Program | FileJp;
9
-
10
- export default abstract class MISRAAnalyser extends Analyser {
11
- #rules: number[];
4
+ import ResultFormatManager from "@specs-feup/clava/api/clava/analysis/ResultFormatManager.js";
5
+ export default class MISRAAnalyser extends Analyser {
6
+ #rules;
12
7
  #resultFormatManager = new ResultFormatManager();
13
- protected abstract ruleMapper: Map<number, (jp: T) => void>;
14
- #results: AnalyserResult[] = [];
15
-
16
- constructor(rules: number[]) {
8
+ #results = [];
9
+ constructor(rules) {
17
10
  super();
18
11
  this.#rules = rules;
19
12
  }
20
-
21
- get rules(): number[] {return this.#rules.map(num => num)};
22
-
23
- protected logMISRAError(jp: Joinpoint, message: string, fix?: Fix) {
24
- this.#results.push(new AnalyserResult(`Non-compliant code at ${jp?.filename}@${jp?.line}:${jp?.column}.`, jp, message, fix))
13
+ get rules() { return this.#rules.map(num => num); }
14
+ ;
15
+ logMISRAError(jp, message, fix) {
16
+ this.#results.push(new AnalyserResult(`Non-compliant code at ${jp?.filename}@${jp?.line}:${jp?.column}.`, jp, message, fix));
25
17
  }
26
-
27
- analyse($startNode: T = Query.root() as Program) {
18
+ analyse($startNode = Query.root()) {
28
19
  for (const rule of this.rules) {
29
20
  const rulePass = this.ruleMapper.get(rule);
30
21
  if (rulePass) {
31
22
  rulePass($startNode);
32
23
  }
33
24
  else {
34
- throw new Error("Analyser doesn't support rule number " + rule)
25
+ throw new Error("Analyser doesn't support rule number " + rule);
35
26
  }
36
27
  }
37
-
38
28
  this.#resultFormatManager.setAnalyserResultList(this.#results);
39
29
  const fileResult = this.#resultFormatManager.formatResultList($startNode);
40
-
41
30
  return fileResult;
42
31
  }
43
- }
32
+ }
33
+ //# sourceMappingURL=MISRAAnalyser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAAnalyser.js","sourceRoot":"","sources":["../../src/misra/MISRAAnalyser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,sCAAsC,CAAC;AACzD,OAAO,QAAQ,MAAM,kDAAkD,CAAC;AACxE,OAAO,cAAc,MAAM,wDAAwD,CAAC;AAEpF,OAAO,mBAAmB,MAAM,6DAA6D,CAAA;AAK7F,MAAM,CAAC,OAAO,OAAgB,aAAc,SAAQ,QAAQ;IACxD,MAAM,CAAW;IACjB,oBAAoB,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAEjD,QAAQ,GAAqB,EAAE,CAAC;IAEhC,YAAY,KAAe;QACvB,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,IAAI,KAAK,KAAc,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAA,CAAA,CAAC;IAAA,CAAC;IAEjD,aAAa,CAAC,EAAa,EAAE,OAAe,EAAE,GAAS;QAC7D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,cAAc,CAAC,yBAAyB,EAAE,EAAE,QAAQ,IAAI,EAAE,EAAE,IAAI,IAAI,EAAE,EAAE,MAAM,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC,CAAA;IAChI,CAAC;IAED,OAAO,CAAC,aAAgB,KAAK,CAAC,IAAI,EAAa;QAC3C,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC3C,IAAI,QAAQ,EAAE,CAAC;gBACX,QAAQ,CAAC,UAAU,CAAC,CAAC;YACzB,CAAC;iBACI,CAAC;gBACF,MAAM,IAAI,KAAK,CAAC,uCAAuC,GAAG,IAAI,CAAC,CAAA;YACnE,CAAC;QACL,CAAC;QAED,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/D,MAAM,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;QAE1E,OAAO,UAAU,CAAC;IACtB,CAAC;CACJ"}
@@ -0,0 +1,27 @@
1
+ import { Joinpoint } from "@specs-feup/clava/api/Joinpoints.js";
2
+ import { LaraJoinPoint } from "@specs-feup/lara/api/LaraJoinPoint.js";
3
+ import SimplePass from "@specs-feup/lara/api/lara/pass/SimplePass.js";
4
+ import { Preprocessing, PreprocessingReqs } from "./MISRAReporter.js";
5
+ import MISRAPassResult from "./MISRAPassResult.js";
6
+ import Fix from "@specs-feup/clava/api/clava/analysis/Fix.js";
7
+ export default abstract class MISRAPass extends SimplePass {
8
+ protected _ruleMapper: Map<number, ($jp: Joinpoint) => void>;
9
+ private _executedRules;
10
+ private _rules;
11
+ private _currentRule;
12
+ protected _preprocessing: Preprocessing | undefined;
13
+ private _result;
14
+ protected abstract _preprocessingReqs: PreprocessingReqs[];
15
+ get preprocessingReqs(): PreprocessingReqs[];
16
+ abstract initRuleMapper(): void;
17
+ setPreprocessing($preprocessing: Preprocessing): void;
18
+ protected logMISRAError(message: string, fix?: Fix): void;
19
+ private resetRules;
20
+ constructor(includeDescendants: boolean | undefined, rules: number[]);
21
+ private executeRule;
22
+ protected dependsOn($id: number, $jp: Joinpoint): void;
23
+ abstract matchJoinpoint($jp: LaraJoinPoint): boolean;
24
+ transformJoinpoint($jp: LaraJoinPoint): MISRAPassResult;
25
+ protected abstract _name: string;
26
+ }
27
+ //# sourceMappingURL=MISRAPass.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAPass.d.ts","sourceRoot":"","sources":["../../src/misra/MISRAPass.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAC;AACtE,OAAO,UAAU,MAAM,8CAA8C,CAAC;AAEtE,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACtE,OAAO,eAAe,MAAM,sBAAsB,CAAC;AACnD,OAAO,GAAG,MAAM,6CAA6C,CAAC;AAE9D,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,SAAU,SAAQ,UAAU;IACtD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,IAAI,CAAC,CAAa;IACzE,OAAO,CAAC,cAAc,CAAmC;IACzD,OAAO,CAAC,MAAM,CAAW;IACzB,OAAO,CAAC,YAAY,CAAc;IAClC,SAAS,CAAC,cAAc,EAAE,aAAa,GAAG,SAAS,CAAC;IACpD,OAAO,CAAC,OAAO,CAA8B;IAC7C,SAAS,CAAC,QAAQ,CAAC,kBAAkB,EAAE,iBAAiB,EAAE,CAAC;IAE3D,IAAI,iBAAiB,wBAEpB;IAED,QAAQ,CAAC,cAAc,IAAI,IAAI;IAE/B,gBAAgB,CAAC,cAAc,EAAE,aAAa,GAAG,IAAI;IAIrD,SAAS,CAAC,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG;IAIlD,OAAO,CAAC,UAAU;gBAMN,kBAAkB,qBAAgB,EAAE,KAAK,EAAE,MAAM,EAAE;IAU/D,OAAO,CAAC,WAAW;IASnB,SAAS,CAAC,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS;IAS/C,QAAQ,CAAC,cAAc,CAAC,GAAG,EAAE,aAAa,GAAG,OAAO;IAEpD,kBAAkB,CAAC,GAAG,EAAE,aAAa,GAAG,eAAe;IAevD,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;CAEpC"}
@@ -0,0 +1,60 @@
1
+ import SimplePass from "@specs-feup/lara/api/lara/pass/SimplePass.js";
2
+ import MISRAPassResult from "./MISRAPassResult.js";
3
+ export default class MISRAPass extends SimplePass {
4
+ _ruleMapper = new Map();
5
+ _executedRules = new Map();
6
+ _rules;
7
+ _currentRule = -1;
8
+ _preprocessing;
9
+ _result;
10
+ get preprocessingReqs() {
11
+ return this._preprocessingReqs;
12
+ }
13
+ setPreprocessing($preprocessing) {
14
+ this._preprocessing = $preprocessing;
15
+ }
16
+ logMISRAError(message, fix) {
17
+ this._result?.addReport({ rule: this._currentRule, message, fix });
18
+ }
19
+ resetRules() {
20
+ this._executedRules.forEach(($value, $key) => {
21
+ this._executedRules.set($key, false);
22
+ }, this);
23
+ }
24
+ constructor(includeDescendants = true, rules) {
25
+ super(includeDescendants);
26
+ this._rules = rules;
27
+ this.initRuleMapper();
28
+ this._ruleMapper.forEach(($value, $key) => {
29
+ this._executedRules.set($key, false);
30
+ }, this);
31
+ }
32
+ executeRule($id, $jp) {
33
+ if (!this._ruleMapper.has($id)) {
34
+ throw new Error(`Pass does not support rule ${$id}`);
35
+ }
36
+ this._ruleMapper.get($id)($jp);
37
+ this._executedRules.set($id, true);
38
+ }
39
+ dependsOn($id, $jp) {
40
+ const tempId = this._currentRule;
41
+ if (this._executedRules.get($id) === false) {
42
+ this._currentRule = $id;
43
+ this.executeRule($id, $jp);
44
+ }
45
+ this._currentRule = tempId;
46
+ }
47
+ transformJoinpoint($jp) {
48
+ if (!this._preprocessing) {
49
+ throw new Error("Preprocessing object has not been set.");
50
+ }
51
+ this._result = new MISRAPassResult(this, $jp);
52
+ this.resetRules();
53
+ this._rules.forEach($id => {
54
+ this._currentRule = $id;
55
+ this.executeRule($id, $jp);
56
+ }, this);
57
+ return this._result;
58
+ }
59
+ }
60
+ //# sourceMappingURL=MISRAPass.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAPass.js","sourceRoot":"","sources":["../../src/misra/MISRAPass.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import Fix from "@specs-feup/clava/api/clava/analysis/Fix.js";
2
+ import PassResult from "@specs-feup/lara/api/lara/pass/results/PassResult.js";
3
+ export interface MISRAReport {
4
+ rule: number;
5
+ message: string;
6
+ fix?: Fix;
7
+ }
8
+ export default class MISRAPassResult extends PassResult {
9
+ protected _reports: MISRAReport[];
10
+ get reports(): MISRAReport[];
11
+ addReport($report: MISRAReport): void;
12
+ }
13
+ //# sourceMappingURL=MISRAPassResult.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAPassResult.d.ts","sourceRoot":"","sources":["../../src/misra/MISRAPassResult.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,6CAA6C,CAAC;AAC9D,OAAO,UAAU,MAAM,sDAAsD,CAAC;AAE9E,MAAM,WAAW,WAAW;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,GAAG,CAAA;CACZ;AAED,MAAM,CAAC,OAAO,OAAO,eAAgB,SAAQ,UAAU;IACnD,SAAS,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAM;IAEvC,IAAI,OAAO,IAAI,WAAW,EAAE,CAE3B;IAED,SAAS,CAAC,OAAO,EAAE,WAAW;CAGjC"}
@@ -0,0 +1,11 @@
1
+ import PassResult from "@specs-feup/lara/api/lara/pass/results/PassResult.js";
2
+ export default class MISRAPassResult extends PassResult {
3
+ _reports = [];
4
+ get reports() {
5
+ return this._reports;
6
+ }
7
+ addReport($report) {
8
+ this._reports.push($report);
9
+ }
10
+ }
11
+ //# sourceMappingURL=MISRAPassResult.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAPassResult.js","sourceRoot":"","sources":["../../src/misra/MISRAPassResult.ts"],"names":[],"mappings":"AACA,OAAO,UAAU,MAAM,sDAAsD,CAAC;AAQ9E,MAAM,CAAC,OAAO,OAAO,eAAgB,SAAQ,UAAU;IACzC,QAAQ,GAAkB,EAAE,CAAC;IAEvC,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,SAAS,CAAC,OAAoB;QAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;CACJ"}
@@ -0,0 +1,20 @@
1
+ import { FunctionJp, Joinpoint, TypedefNameDecl, Vardecl } from "@specs-feup/clava/api/Joinpoints.js";
2
+ import MISRAPass from "./MISRAPass.js";
3
+ import AggregatePassResult from "@specs-feup/lara/api/lara/pass/results/AggregatePassResult.js";
4
+ export declare enum PreprocessingReqs {
5
+ TYPEDEF_DECLS = "typedefDecls",
6
+ EXTERNAL_LINKAGE_DECLS = "externalLinkageDecls"
7
+ }
8
+ export interface Preprocessing {
9
+ typedefDecls?: TypedefNameDecl[];
10
+ externalLinkageDecls?: (FunctionJp | Vardecl)[];
11
+ }
12
+ export default class MISRAReporter {
13
+ private _preprocessing;
14
+ private _preprocessingMapper;
15
+ private initTypedefs;
16
+ private static hasExternalLinkage;
17
+ private initExternals;
18
+ applyPass($pass: MISRAPass, $jp: Joinpoint): AggregatePassResult | undefined;
19
+ }
20
+ //# sourceMappingURL=MISRAReporter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAReporter.d.ts","sourceRoot":"","sources":["../../src/misra/MISRAReporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,UAAU,EAAE,SAAS,EAAgB,eAAe,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAC5H,OAAO,SAAS,MAAM,gBAAgB,CAAC;AAGvC,OAAO,mBAAmB,MAAM,+DAA+D,CAAC;AAGhG,oBAAY,iBAAiB;IACzB,aAAa,iBAAiB;IAC9B,sBAAsB,yBAAyB;CAClD;AAED,MAAM,WAAW,aAAa;IAC1B,YAAY,CAAC,EAAE,eAAe,EAAE,CAAC;IACjC,oBAAoB,CAAC,EAAE,CAAC,UAAU,GAAG,OAAO,CAAC,EAAE,CAAA;CAClD;AAED,MAAM,CAAC,OAAO,OAAO,aAAa;IAC9B,OAAO,CAAC,cAAc,CAAqB;IAC3C,OAAO,CAAC,oBAAoB,CAGzB;IAEH,OAAO,CAAC,YAAY;IAIpB,OAAO,CAAC,MAAM,CAAC,kBAAkB;IAIjC,OAAO,CAAC,aAAa;IAWrB,SAAS,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,EAAE,SAAS,GAAG,mBAAmB,GAAG,SAAS;CAa/E"}
@@ -0,0 +1,43 @@
1
+ import { FileJp, FunctionJp, StorageClass, TypedefNameDecl, Vardecl } from "@specs-feup/clava/api/Joinpoints.js";
2
+ import Query from "@specs-feup/lara/api/weaver/Query.js";
3
+ export var PreprocessingReqs;
4
+ (function (PreprocessingReqs) {
5
+ PreprocessingReqs["TYPEDEF_DECLS"] = "typedefDecls";
6
+ PreprocessingReqs["EXTERNAL_LINKAGE_DECLS"] = "externalLinkageDecls";
7
+ })(PreprocessingReqs || (PreprocessingReqs = {}));
8
+ export default class MISRAReporter {
9
+ _preprocessing = {};
10
+ _preprocessingMapper = new Map([
11
+ [PreprocessingReqs.TYPEDEF_DECLS, this.initTypedefs.bind(this)],
12
+ [PreprocessingReqs.EXTERNAL_LINKAGE_DECLS, this.initExternals.bind(this)]
13
+ ]);
14
+ initTypedefs() {
15
+ this._preprocessing.typedefDecls = Query.search(TypedefNameDecl).get();
16
+ }
17
+ static hasExternalLinkage($class) {
18
+ return $class !== StorageClass.STATIC && $class !== StorageClass.EXTERN;
19
+ }
20
+ initExternals() {
21
+ this._preprocessing.externalLinkageDecls = [];
22
+ Query.search(FileJp).get().forEach(file => {
23
+ file.children.forEach(child => {
24
+ if ((child instanceof Vardecl || child instanceof FunctionJp) && MISRAReporter.hasExternalLinkage(child.storageClass)) {
25
+ this._preprocessing.externalLinkageDecls?.push(child);
26
+ }
27
+ }, this);
28
+ }, this);
29
+ }
30
+ applyPass($pass, $jp) {
31
+ $pass.preprocessingReqs.forEach($req => {
32
+ if (!this._preprocessing[$req]) {
33
+ this._preprocessingMapper.get($req)();
34
+ }
35
+ });
36
+ $pass.setPreprocessing(this._preprocessing);
37
+ const result = $pass.apply($jp);
38
+ if (result.results.some(res => res.reports.length > 0)) {
39
+ return result;
40
+ }
41
+ }
42
+ }
43
+ //# sourceMappingURL=MISRAReporter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MISRAReporter.js","sourceRoot":"","sources":["../../src/misra/MISRAReporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAa,YAAY,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAE5H,OAAO,KAAK,MAAM,sCAAsC,CAAC;AAKzD,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IACzB,mDAA8B,CAAA;IAC9B,oEAA+C,CAAA;AACnD,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B;AAOD,MAAM,CAAC,OAAO,OAAO,aAAa;IACtB,cAAc,GAAkB,EAAE,CAAC;IACnC,oBAAoB,GAAuC,IAAI,GAAG,CAAC;QACvE,CAAC,iBAAiB,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/D,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KAC5E,CAAC,CAAC;IAEK,YAAY;QAChB,IAAI,CAAC,cAAc,CAAC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,GAAG,EAAE,CAAC;IAC3E,CAAC;IAEO,MAAM,CAAC,kBAAkB,CAAC,MAAoB;QAClD,OAAO,MAAM,KAAK,YAAY,CAAC,MAAM,IAAI,MAAM,KAAK,YAAY,CAAC,MAAM,CAAC;IAC5E,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,cAAc,CAAC,oBAAoB,GAAG,EAAE,CAAC;QAC9C,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBAC1B,IAAI,CAAC,KAAK,YAAY,OAAO,IAAI,KAAK,YAAY,UAAU,CAAC,IAAI,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC;oBACpH,IAAI,CAAC,cAAc,CAAC,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC1D,CAAC;YACL,CAAC,EAAE,IAAI,CAAC,CAAC;QACb,CAAC,EAAE,IAAI,CAAC,CAAC;IACb,CAAC;IAED,SAAS,CAAC,KAAgB,EAAE,GAAc;QACtC,KAAK,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAgB,EAAE,CAAC;YAC1D,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC5C,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAwB,CAAC;QACvD,IAAK,MAAM,CAAC,OAA6B,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;YAC5E,OAAO,MAAM,CAAC;QAClB,CAAC;IACL,CAAC;CACJ"}