@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.
- package/.gitignore +117 -0
- package/README.md +70 -15
- package/dist/MISRA.d.ts +129 -0
- package/dist/MISRA.d.ts.map +1 -0
- package/dist/MISRA.js +245 -0
- package/dist/MISRA.js.map +1 -0
- package/dist/MISRAContext.d.ts +21 -0
- package/dist/MISRAContext.d.ts.map +1 -0
- package/dist/MISRAContext.js +75 -0
- package/dist/MISRAContext.js.map +1 -0
- package/dist/MISRARule.d.ts +56 -0
- package/dist/MISRARule.d.ts.map +1 -0
- package/dist/MISRARule.js +45 -0
- package/dist/MISRARule.js.map +1 -0
- package/dist/MISRATool.d.ts +12 -0
- package/dist/MISRATool.d.ts.map +1 -0
- package/dist/MISRATool.js +84 -0
- package/dist/MISRATool.js.map +1 -0
- package/dist/foo.d.ts +2 -0
- package/dist/foo.d.ts.map +1 -0
- package/{src/foo.ts → dist/foo.js} +3 -2
- package/dist/foo.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +5 -0
- package/dist/main.js.map +1 -0
- package/dist/misra/MISRAAnalyser.d.ts +14 -0
- package/dist/misra/MISRAAnalyser.d.ts.map +1 -0
- package/{src/misra/MISRAAnalyser.ts → dist/misra/MISRAAnalyser.js} +13 -23
- package/dist/misra/MISRAAnalyser.js.map +1 -0
- package/dist/misra/MISRAPass.d.ts +27 -0
- package/dist/misra/MISRAPass.d.ts.map +1 -0
- package/dist/misra/MISRAPass.js +60 -0
- package/dist/misra/MISRAPass.js.map +1 -0
- package/dist/misra/MISRAPassResult.d.ts +13 -0
- package/dist/misra/MISRAPassResult.d.ts.map +1 -0
- package/dist/misra/MISRAPassResult.js +11 -0
- package/dist/misra/MISRAPassResult.js.map +1 -0
- package/dist/misra/MISRAReporter.d.ts +20 -0
- package/dist/misra/MISRAReporter.d.ts.map +1 -0
- package/dist/misra/MISRAReporter.js +43 -0
- package/dist/misra/MISRAReporter.js.map +1 -0
- package/dist/misra/passes/S10_EssentialTypePass.d.ts +42 -0
- package/dist/misra/passes/S10_EssentialTypePass.d.ts.map +1 -0
- package/dist/misra/passes/S10_EssentialTypePass.js +370 -0
- package/dist/misra/passes/S10_EssentialTypePass.js.map +1 -0
- package/dist/misra/passes/S12_ExpressionPass.d.ts +18 -0
- package/dist/misra/passes/S12_ExpressionPass.d.ts.map +1 -0
- package/dist/misra/passes/S12_ExpressionPass.js +72 -0
- package/dist/misra/passes/S12_ExpressionPass.js.map +1 -0
- package/dist/misra/passes/S13_SideEffectPass.d.ts +18 -0
- package/dist/misra/passes/S13_SideEffectPass.d.ts.map +1 -0
- package/dist/misra/passes/S13_SideEffectPass.js +105 -0
- package/dist/misra/passes/S13_SideEffectPass.js.map +1 -0
- package/dist/misra/passes/S15_ControlFlowPass.d.ts +19 -0
- package/dist/misra/passes/S15_ControlFlowPass.d.ts.map +1 -0
- package/dist/misra/passes/S15_ControlFlowPass.js +94 -0
- package/dist/misra/passes/S15_ControlFlowPass.js.map +1 -0
- package/dist/misra/passes/S16_SwitchStatementPass.d.ts +17 -0
- package/dist/misra/passes/S16_SwitchStatementPass.d.ts.map +1 -0
- package/dist/misra/passes/S16_SwitchStatementPass.js +152 -0
- package/dist/misra/passes/S16_SwitchStatementPass.js.map +1 -0
- package/dist/misra/passes/S17_FunctionPass.d.ts +12 -0
- package/dist/misra/passes/S17_FunctionPass.d.ts.map +1 -0
- package/dist/misra/passes/S17_FunctionPass.js +38 -0
- package/dist/misra/passes/S17_FunctionPass.js.map +1 -0
- package/dist/misra/passes/S18_PointersArraysPass.d.ts +17 -0
- package/dist/misra/passes/S18_PointersArraysPass.d.ts.map +1 -0
- package/dist/misra/passes/S18_PointersArraysPass.js +115 -0
- package/dist/misra/passes/S18_PointersArraysPass.js.map +1 -0
- package/dist/misra/passes/S19_OverlappingStoragePass.d.ts +11 -0
- package/dist/misra/passes/S19_OverlappingStoragePass.d.ts.map +1 -0
- package/dist/misra/passes/S19_OverlappingStoragePass.js +20 -0
- package/dist/misra/passes/S19_OverlappingStoragePass.js.map +1 -0
- package/dist/misra/passes/S21_StandardLibPass.d.ts +20 -0
- package/dist/misra/passes/S21_StandardLibPass.d.ts.map +1 -0
- package/dist/misra/passes/S21_StandardLibPass.js +77 -0
- package/dist/misra/passes/S21_StandardLibPass.js.map +1 -0
- package/dist/misra/passes/S3_CommentPass.d.ts +12 -0
- package/dist/misra/passes/S3_CommentPass.d.ts.map +1 -0
- package/dist/misra/passes/S3_CommentPass.js +27 -0
- package/dist/misra/passes/S3_CommentPass.js.map +1 -0
- package/dist/misra/passes/S5_IdentifierPass.d.ts +13 -0
- package/dist/misra/passes/S5_IdentifierPass.d.ts.map +1 -0
- package/dist/misra/passes/S5_IdentifierPass.js +60 -0
- package/dist/misra/passes/S5_IdentifierPass.js.map +1 -0
- package/dist/misra/passes/S6_TypePass.d.ts +11 -0
- package/dist/misra/passes/S6_TypePass.d.ts.map +1 -0
- package/dist/misra/passes/S6_TypePass.js +25 -0
- package/dist/misra/passes/S6_TypePass.js.map +1 -0
- package/dist/misra/passes/S7_LiteralsConstantsPass.d.ts +14 -0
- package/dist/misra/passes/S7_LiteralsConstantsPass.d.ts.map +1 -0
- package/dist/misra/passes/S7_LiteralsConstantsPass.js +71 -0
- package/dist/misra/passes/S7_LiteralsConstantsPass.js.map +1 -0
- package/dist/misra/passes/S8_DeclDefPass.d.ts +18 -0
- package/dist/misra/passes/S8_DeclDefPass.d.ts.map +1 -0
- package/dist/misra/passes/S8_DeclDefPass.js +127 -0
- package/dist/misra/passes/S8_DeclDefPass.js.map +1 -0
- package/dist/misra/sections/Section10_EssentialTypeModel.d.ts +33 -0
- package/dist/misra/sections/Section10_EssentialTypeModel.d.ts.map +1 -0
- package/{src/misra/sections/Section10_EssentialTypeModel.ts → dist/misra/sections/Section10_EssentialTypeModel.js} +58 -73
- package/dist/misra/sections/Section10_EssentialTypeModel.js.map +1 -0
- package/dist/misra/sections/Section11_PointerTypeConversions.d.ts +12 -0
- package/dist/misra/sections/Section11_PointerTypeConversions.d.ts.map +1 -0
- package/{src/misra/sections/Section11_PointerTypeConversions.ts → dist/misra/sections/Section11_PointerTypeConversions.js} +16 -27
- package/dist/misra/sections/Section11_PointerTypeConversions.js.map +1 -0
- package/dist/misra/sections/Section12_Expressions.d.ts +15 -0
- package/dist/misra/sections/Section12_Expressions.d.ts.map +1 -0
- package/dist/misra/sections/Section12_Expressions.js +70 -0
- package/dist/misra/sections/Section12_Expressions.js.map +1 -0
- package/dist/misra/sections/Section13_SideEffects.d.ts +14 -0
- package/dist/misra/sections/Section13_SideEffects.d.ts.map +1 -0
- package/dist/misra/sections/Section13_SideEffects.js +90 -0
- package/dist/misra/sections/Section13_SideEffects.js.map +1 -0
- package/dist/misra/sections/Section14_ControlStmtExprs.d.ts +8 -0
- package/dist/misra/sections/Section14_ControlStmtExprs.d.ts.map +1 -0
- package/{src/misra/sections/Section14_ControlStmtExprs.ts → dist/misra/sections/Section14_ControlStmtExprs.js} +8 -10
- package/dist/misra/sections/Section14_ControlStmtExprs.js.map +1 -0
- package/dist/misra/sections/Section15_ControlFlow.d.ts +14 -0
- package/dist/misra/sections/Section15_ControlFlow.d.ts.map +1 -0
- package/dist/misra/sections/Section15_ControlFlow.js +97 -0
- package/dist/misra/sections/Section15_ControlFlow.js.map +1 -0
- package/dist/misra/sections/Section16_SwitchStatements.d.ts +13 -0
- package/dist/misra/sections/Section16_SwitchStatements.d.ts.map +1 -0
- package/{src/misra/sections/Section16_SwitchStatements.ts → dist/misra/sections/Section16_SwitchStatements.js} +49 -74
- package/dist/misra/sections/Section16_SwitchStatements.js.map +1 -0
- package/dist/misra/sections/Section17_Functions.d.ts +9 -0
- package/dist/misra/sections/Section17_Functions.d.ts.map +1 -0
- package/{src/misra/sections/Section17_Functions.ts → dist/misra/sections/Section17_Functions.js} +10 -13
- package/dist/misra/sections/Section17_Functions.js.map +1 -0
- package/dist/misra/sections/Section18_PointersAndArrays.d.ts +13 -0
- package/dist/misra/sections/Section18_PointersAndArrays.d.ts.map +1 -0
- package/{src/misra/sections/Section18_PointersAndArrays.ts → dist/misra/sections/Section18_PointersAndArrays.js} +36 -40
- package/dist/misra/sections/Section18_PointersAndArrays.js.map +1 -0
- package/dist/misra/sections/Section19_OverlappingStorage.d.ts +8 -0
- package/dist/misra/sections/Section19_OverlappingStorage.d.ts.map +1 -0
- package/dist/misra/sections/Section19_OverlappingStorage.js +16 -0
- package/dist/misra/sections/Section19_OverlappingStorage.js.map +1 -0
- package/dist/misra/sections/Section20_PreprocessingDirectives.d.ts +8 -0
- package/dist/misra/sections/Section20_PreprocessingDirectives.d.ts.map +1 -0
- package/{src/misra/sections/Section20_PreprocessingDirectives.ts → dist/misra/sections/Section20_PreprocessingDirectives.js} +7 -9
- package/dist/misra/sections/Section20_PreprocessingDirectives.js.map +1 -0
- package/dist/misra/sections/Section21_StandardLibraries.d.ts +17 -0
- package/dist/misra/sections/Section21_StandardLibraries.d.ts.map +1 -0
- package/dist/misra/sections/Section21_StandardLibraries.js +54 -0
- package/dist/misra/sections/Section21_StandardLibraries.js.map +1 -0
- package/dist/misra/sections/Section2_UnusedCode.d.ts +9 -0
- package/dist/misra/sections/Section2_UnusedCode.d.ts.map +1 -0
- package/{src/misra/sections/Section2_UnusedCode.ts → dist/misra/sections/Section2_UnusedCode.js} +11 -16
- package/dist/misra/sections/Section2_UnusedCode.js.map +1 -0
- package/dist/misra/sections/Section3_Comments.d.ts +9 -0
- package/dist/misra/sections/Section3_Comments.d.ts.map +1 -0
- package/{src/misra/sections/Section3_Comments.ts → dist/misra/sections/Section3_Comments.js} +7 -10
- package/dist/misra/sections/Section3_Comments.js.map +1 -0
- package/dist/misra/sections/Section5_Identifiers.d.ts +12 -0
- package/dist/misra/sections/Section5_Identifiers.d.ts.map +1 -0
- package/dist/misra/sections/Section5_Identifiers.js +139 -0
- package/dist/misra/sections/Section5_Identifiers.js.map +1 -0
- package/dist/misra/sections/Section6_Types.d.ts +8 -0
- package/dist/misra/sections/Section6_Types.d.ts.map +1 -0
- package/dist/misra/sections/Section6_Types.js +23 -0
- package/dist/misra/sections/Section6_Types.js.map +1 -0
- package/dist/misra/sections/Section7_LiteralsConstants.d.ts +11 -0
- package/dist/misra/sections/Section7_LiteralsConstants.d.ts.map +1 -0
- package/{src/misra/sections/Section7_LiteralsConstants.ts → dist/misra/sections/Section7_LiteralsConstants.js} +18 -25
- package/dist/misra/sections/Section7_LiteralsConstants.js.map +1 -0
- package/dist/misra/sections/Section8_DeclarationsDefinitions.d.ts +15 -0
- package/dist/misra/sections/Section8_DeclarationsDefinitions.d.ts.map +1 -0
- package/{src/misra/sections/Section8_DeclarationsDefinitions.ts → dist/misra/sections/Section8_DeclarationsDefinitions.js} +18 -33
- package/dist/misra/sections/Section8_DeclarationsDefinitions.js.map +1 -0
- package/dist/misra/tests/utils.d.ts +10 -0
- package/dist/misra/tests/utils.d.ts.map +1 -0
- package/dist/misra/tests/utils.js +33 -0
- package/dist/misra/tests/utils.js.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.d.ts +15 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.d.ts.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.js +33 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.js.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.d.ts +16 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.d.ts.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.js +60 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.js.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.d.ts +19 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.d.ts.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.js +42 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.js.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.d.ts +43 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.d.ts.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.js +103 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.js.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.d.ts +26 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.d.ts.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.js +49 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.js.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.d.ts +26 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.d.ts.map +1 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.js +49 -0
- package/dist/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.js.map +1 -0
- package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.d.ts +31 -0
- package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.d.ts.map +1 -0
- package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.js +71 -0
- package/dist/rules/Section17_Functions/Rule_17_4_NonVoidReturn.js.map +1 -0
- package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.d.ts +27 -0
- package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.d.ts.map +1 -0
- package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.js +58 -0
- package/dist/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.js.map +1 -0
- package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.d.ts +28 -0
- package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.d.ts.map +1 -0
- package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.js +44 -0
- package/dist/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.js.map +1 -0
- package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.d.ts +55 -0
- package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.d.ts.map +1 -0
- package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.js +108 -0
- package/dist/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.js.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.d.ts +43 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.d.ts.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.js +68 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.js.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.d.ts +29 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.d.ts.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.js +53 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.js.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.d.ts +15 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.d.ts.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.js +35 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.js.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.d.ts +13 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.d.ts.map +1 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.js +53 -0
- package/dist/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.js.map +1 -0
- package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.d.ts +13 -0
- package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.d.ts.map +1 -0
- package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.js +32 -0
- package/dist/rules/Section3_Comments/Rule_3_1_CommentSequences.js.map +1 -0
- package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.d.ts +10 -0
- package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.d.ts.map +1 -0
- package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.js +26 -0
- package/dist/rules/Section3_Comments/Rule_3_2_LineSplicing.js.map +1 -0
- package/dist/rules/index.d.ts +20 -0
- package/dist/rules/index.d.ts.map +1 -0
- package/dist/rules/index.js +38 -0
- package/dist/rules/index.js.map +1 -0
- package/dist/tests/Section17_Functions/misra_config.json +10 -0
- package/dist/tests/utils.d.ts +10 -0
- package/dist/tests/utils.d.ts.map +1 -0
- package/dist/tests/utils.js +29 -0
- package/dist/tests/utils.js.map +1 -0
- package/dist/utils/utils.d.ts +102 -0
- package/dist/utils/utils.d.ts.map +1 -0
- package/dist/utils/utils.js +202 -0
- package/dist/utils/utils.js.map +1 -0
- package/jest.config.js +6 -6
- package/package.json +40 -8
- package/src/MISRA.ts +266 -0
- package/src/MISRAContext.ts +91 -0
- package/src/MISRARule.ts +77 -0
- package/src/MISRATool.ts +96 -0
- package/src/main.ts +4 -33
- package/src/misra-old/MISRAAnalyser.ts +60 -0
- package/src/misra-old/MISRAAnalyserResult.ts +16 -0
- package/src/misra-old/sections/Section10_EssentialTypeModel.ts +377 -0
- package/src/misra-old/sections/Section11_PointerTypeConversions.ts +104 -0
- package/src/{misra → misra-old}/sections/Section12_Expressions.ts +7 -7
- package/src/{misra → misra-old}/sections/Section13_SideEffects.ts +15 -15
- package/src/misra-old/sections/Section14_ControlStmtExprs.ts +27 -0
- package/src/{misra → misra-old}/sections/Section15_ControlFlow.ts +10 -10
- package/src/misra-old/sections/Section18_PointersAndArrays.ts +108 -0
- package/src/{misra → misra-old}/sections/Section19_OverlappingStorage.ts +4 -4
- package/src/misra-old/sections/Section20_PreprocessingDirectives.ts +22 -0
- package/src/misra-old/sections/Section21_StandardLibraries.ts +99 -0
- package/src/{misra → misra-old}/sections/Section5_Identifiers.ts +16 -15
- package/src/{misra → misra-old}/sections/Section6_Types.ts +4 -4
- package/src/misra-old/sections/Section7_LiteralsConstants.ts +76 -0
- package/src/misra-old/sections/Section8_DeclarationsDefinitions.ts +133 -0
- package/src/rules/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.ts +40 -0
- package/src/rules/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.ts +69 -0
- package/src/rules/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.ts +46 -0
- package/src/rules/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.ts +113 -0
- package/src/rules/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.ts +57 -0
- package/src/rules/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.ts +56 -0
- package/src/rules/Section17_Functions/Rule_17_4_NonVoidReturn.ts +78 -0
- package/src/rules/Section17_Functions/Rule_17_6_StaticArraySizeParam.ts +68 -0
- package/src/rules/Section17_Functions/Rule_17_7_UnusedReturnValue.ts +47 -0
- package/src/rules/Section20-PreprocessingDirectives/Rule_20_2_InvalidHeaderFileName.ts +120 -0
- package/src/rules/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.ts +75 -0
- package/src/rules/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.ts +60 -0
- package/src/rules/Section2_UnusedCode/Rule_2_6_UnusedLabels.ts +46 -0
- package/src/rules/Section2_UnusedCode/Rule_2_7_UnusedParameters.ts +65 -0
- package/src/rules/Section3_Comments/Rule_3_1_CommentSequences.ts +41 -0
- package/src/rules/Section3_Comments/Rule_3_2_LineSplicing.ts +36 -0
- package/src/rules/index.ts +40 -0
- package/src/tests/Section16_SwitchStatements/Rule_16_2_TopLevelSwitch.test.ts +55 -0
- package/src/tests/Section16_SwitchStatements/Rule_16_3_UnconditionalBreak.test.ts +70 -0
- package/src/tests/Section16_SwitchStatements/Rule_16_4_SwitchHasDefault.test.ts +128 -0
- package/src/tests/Section16_SwitchStatements/Rule_16_5_DefaultFirstOrLast.test.ts +132 -0
- package/src/tests/Section16_SwitchStatements/Rule_16_6_SwitchMinTwoClauses.test.ts +146 -0
- package/src/tests/Section16_SwitchStatements/Rule_16_7_NonBooleanSwitchCondition.test.ts +102 -0
- package/src/tests/Section17_Functions/Rule_17_4_NonVoidReturn.test.ts +85 -0
- package/src/tests/Section17_Functions/Rule_17_4_NonVoidReturn_MissingConfig.test.ts +77 -0
- package/src/tests/Section17_Functions/Rule_17_6_StaticArraySizeParam.test.ts +36 -0
- package/src/tests/Section17_Functions/Rule_17_7_UnusedReturnValue.test.ts +44 -0
- package/src/tests/Section17_Functions/misra_config.json +10 -0
- package/src/tests/Section2_UnusedCode/Rule_2_3_UnusedTypeDecl.test.ts +175 -0
- package/src/tests/Section2_UnusedCode/Rule_2_4_UnusedTagDecl.test.ts +219 -0
- package/src/tests/Section2_UnusedCode/Rule_2_6_UnusedLabels.test.ts +49 -0
- package/src/tests/Section2_UnusedCode/Rule_2_7_UnusedParameters.test.ts +55 -0
- package/src/tests/Section3_Comments/Rule_3_1_CommentSequences.test.ts +37 -0
- package/src/tests/utils.ts +39 -0
- package/src/utils/utils.ts +221 -0
- package/tsconfig.json +4 -3
- package/typedoc.config.js +1 -1
- package/CxxSources/lib.cpp +0 -3
- package/CxxSources/lib.h +0 -8
- package/CxxSources/main.cpp +0 -40
- package/TODO.md +0 -1
- package/consumer_order.txt +0 -2
- package/enum_integer_type.txt +0 -0
- package/is_temporary.txt +0 -0
- package/omp.txt +0 -0
- package/src/misra/passes/S16_SwitchStatementPass.ts +0 -168
- package/src/misra/passes/S3_CommentPass.ts +0 -40
- package/src/misra/sections/Section21_StandardLibraries.ts +0 -65
- package/src/misra/tests/S10_EssentialTypes.test.ts +0 -253
- package/src/misra/tests/S12_Expressions.test.ts +0 -43
- package/src/misra/tests/S13_SideEffects.test.ts +0 -77
- package/src/misra/tests/S15_ControlFlow.test.ts +0 -144
- package/src/misra/tests/S16_SwitchStatements.test.ts +0 -164
- package/src/misra/tests/S17_Functions.test.ts +0 -46
- package/src/misra/tests/S18_PointersArrays.test.ts +0 -167
- package/src/misra/tests/S19_OverlappingStorage.test.ts +0 -38
- package/src/misra/tests/S3_Comments.test.ts +0 -36
- package/src/misra/tests/S6_Types.test.ts +0 -36
- package/src/misra/tests/S7_LiteralsConstants.test.ts +0 -48
- package/src/misra/tests/utils.ts +0 -47
- package/types_with_templates.txt +0 -0
- /package/src/{misra → misra-old}/MISRAPass.ts +0 -0
- /package/src/{misra → misra-old}/MISRAPassResult.ts +0 -0
- /package/src/{misra → misra-old}/MISRAReporter.ts +0 -0
- /package/src/{misra → misra-old}/passes/S10_EssentialTypePass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S12_ExpressionPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S13_SideEffectPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S15_ControlFlowPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S17_FunctionPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S18_PointersArraysPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S19_OverlappingStoragePass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S21_StandardLibPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S5_IdentifierPass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S6_TypePass.ts +0 -0
- /package/src/{misra → misra-old}/passes/S7_LiteralsConstantsPass.ts +0 -0
- /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":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AAEzB;;;GAGG;AACH,MAAM,CAAC,OAAO,OAAO,YAAY;IAC7B;;OAEG;IACH,YAAY,GAAiB,EAAE,CAAC;IAChC;;OAEG;IACH,cAAc,GAAiB,EAAE,CAAC;IAElC;;OAEG;IACH,OAAO,GAAiC,SAAS,CAAC;IAElD,WAAW,GAAG,CAAC,CAAC;IAChB,YAAY,GAAG,CAAC,CAAC;IACjB,cAAc,GAAG,CAAC,CAAC;IAEnB,UAAU,GAAG,cAAc,CAAC;IAC5B,WAAW,GAAG,eAAe,CAAC;IAC9B,aAAa,GAAG,YAAY,CAAC;IAE7B,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAI,MAAM,CAAC,cAAsB;QAC7B,IAAI,EAAE,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,GAAG,EAAE,CAAC,YAAY,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;YACtD,IAAI,CAAC,OAAO,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7D,CAAC;aAAM,CAAC;YACJ,OAAO,CAAC,KAAK,CAAC,8DAA8D,CAAC,CAAC;YAC9E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;IACL,CAAC;IAED,eAAe;QACX,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;IACrD,CAAC;IAED,gBAAgB;QACZ,OAAO,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;IACvD,CAAC;IAED,sBAAsB;QAClB,OAAO,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC;IAC7D,CAAC;IAED,aAAa,CAAC,MAAc,EAAE,GAAc,EAAE,OAAe;QACzD,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;QAEtD,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;YAC3D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,MAAc,EAAE,GAAc,EAAE,OAAe;QAC3D,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;QAExD,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;YACnE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzC,CAAC;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;IAED,aAAa;QACT,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC;QACrE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;CACJ"}
|
@@ -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 @@
|
|
1
|
+
{"version":3,"file":"foo.d.ts","sourceRoot":"","sources":["../src/foo.ts"],"names":[],"mappings":"AAGA,wBAAgB,GAAG,WAElB"}
|
package/dist/foo.js.map
ADDED
@@ -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 @@
|
|
1
|
+
{"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":""}
|
package/dist/main.js
ADDED
package/dist/main.js.map
ADDED
@@ -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
|
5
|
-
|
6
|
-
|
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
|
-
|
14
|
-
|
15
|
-
|
16
|
-
constructor(rules: number[]) {
|
8
|
+
#results = [];
|
9
|
+
constructor(rules) {
|
17
10
|
super();
|
18
11
|
this.#rules = rules;
|
19
12
|
}
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
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":"AAEA,OAAO,UAAU,MAAM,8CAA8C,CAAC;AAGtE,OAAO,eAAe,MAAM,sBAAsB,CAAC;AAGnD,MAAM,CAAC,OAAO,OAAgB,SAAU,SAAQ,UAAU;IAC5C,WAAW,GAA0C,IAAI,GAAG,EAAE,CAAC;IACjE,cAAc,GAAyB,IAAI,GAAG,EAAE,CAAC;IACjD,MAAM,CAAW;IACjB,YAAY,GAAW,CAAC,CAAC,CAAC;IACxB,cAAc,CAA4B;IAC5C,OAAO,CAA8B;IAG7C,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACnC,CAAC;IAID,gBAAgB,CAAC,cAA6B;QAC1C,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACzC,CAAC;IAES,aAAa,CAAC,OAAe,EAAE,GAAS;QAC9C,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,EAAC,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,GAAG,EAAC,CAAC,CAAC;IACrE,CAAC;IAEO,UAAU;QACd,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,MAAe,EAAE,IAAY,EAAE,EAAE;YAC1D,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACzC,CAAC,EAAE,IAAI,CAAC,CAAC;IACb,CAAC;IAED,YAAY,qBAA8B,IAAI,EAAE,KAAe;QAC3D,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,cAAc,EAAE,CAAC;QAEtB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,MAAgC,EAAE,IAAY,EAAE,EAAE;YACxE,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACzC,CAAC,EAAE,IAAI,CAAC,CAAC;IACb,CAAC;IAEO,WAAW,CAAC,GAAW,EAAE,GAAc;QAC3C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC7B,MAAM,IAAI,KAAK,CAAC,8BAA8B,GAAG,EAAE,CAAC,CAAC;QACzD,CAAC;QAEA,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAA8B,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAES,SAAS,CAAC,GAAW,EAAE,GAAc;QAC3C,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;QACjC,IAAI,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,KAAK,EAAE,CAAC;YACzC,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/B,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;IAC/B,CAAC;IAID,kBAAkB,CAAC,GAAkB;QACjC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;QAC9D,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,eAAe,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC9C,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACtB,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,GAAgB,CAAC,CAAC;QAC5C,CAAC,EAAE,IAAI,CAAC,CAAC;QAET,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;CAIJ"}
|
@@ -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"}
|