cFS-Caelum Review, CFS-43: Table Services & Time Services #1420
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
This is a "bookkeeping" Pull Request meant for the cFS-Caelum Review code inspection (full-scale code review).
This PR is solely focused on "CFS-43". For more info see this readme
The Included files are
Objectives
This review starts on 04/26/2021 and ends on 04/30/2021.
Dispositions of findings is on 05/03/2021.
Reviewers only need to review source files, header files & build files.
Use .ppt, .pdf, .txt & .xlsx files for background information about the code.
See the Attachments section for Peer Review Data Package.
See also "The Power of 10" rules for safety-critical code. https://en.wikipedia.org/wiki/The_Power_of_10:_Rules_for_Developing_Safety-Critical_Code#:~:text=The%20Power%20of%2010%20Rules,to%20review%20or%20statically%20analyze
NOTE: Don't spend too much time over coding standard violations. The Static Code Analysis tool will enforce the coding standards. This code is developed by GSFC, so GSFC coding standards will be enforced for this code base.
Notes
Note a few already existing issues (no need to individually comment on occurrences):
Doxygen event documentation doesn't match code: #508
End of function comments out of date (generalized/paraphrased version of #275)
Update code/unit tests to use CFE_Status_t: #921
If there's anything else that is observed as a repeated pattern, feel free to document as a general comment
There are several places that would trigger warnings with some common compilers/warning options. It would be nice to follow #10 rule in "The Power of 10".
Quick summary/references for currently enforced settings on the FSW
Compiler options (note -Wall and -Werror) -
cFE/cmake/sample_defs/arch_build_custom.cmake
Lines 28 to 37 in 0850b19
cppcheck -
cFE/.github/workflows/run_fsw_cppcheck.sh
Line 3 in 0850b19
CodeQL -
cFE/.github/workflows/codeql-build.yml
Lines 35 to 39 in 0850b19
CodeSonar - currently using default set for cFE, extending to JPL and MISRA is future work
For CodeQL and CodeSonar we don't eliminate all warnings, but we do analyze and disposition them all (plan to report dispositions as part of certification package)
This approach is compliant with the latest GSFC 582 standard (that is still going through review). Happy to discuss any additional settings that you have concerns about.