MISRA C:2023 Rule 20.1
#include directives should only be preceded by preprocessor directives or comments
Since R2024a
Description
Rule Definition
#include directives should only be preceded by preprocessor directives or comments1 .
Rationale
For better code readability, group all #include directives in a file at the
                top of the source file. Undefined behavior can occur if you use
                    #include to include a standard header file within a
                declaration or definition or if you use part of the Standard Library before
                including the related standard header files.
Polyspace Implementation
        Polyspace® flags text that precedes an #include directive.
                    Polyspace ignores preprocessor directives, comments, spaces, or new line
                characters. Polyspace also ignores code that is hidden by using conditional compilation
                directives such as #if or #ifdef.
Troubleshooting
If you expect a rule violation but do not see it, refer to Diagnose Why Coding Standard Violations Do Not Appear as Expected.
Examples
Check Information
| Group: Preprocessing Directives | 
| Category: Advisory | 
| AGC Category: Advisory | 
Version History
Introduced in R2024a
1 All MISRA coding rules and directives are © Copyright The MISRA Consortium Limited 2021.
The MISRA coding standards referenced in the Polyspace Bug Finder™ documentation are from the following MISRA standards:
- MISRA C:2004 
- MISRA C:2012 
- MISRA C:2023 
- MISRA C++:2008 
- MISRA C++:2023 
MISRA and MISRA C are registered trademarks of The MISRA Consortium Limited 2021.