AUTOSAR C++14 Rule A16-0-1
The preprocessor shall only be used for unconditional and conditional file inclusion and include guards, and using specific directives
Description
Rule Definition
The preprocessor shall only be used for unconditional and conditional file inclusion and include guards, and using specific directives.
Rationale
Other than unconditional and conditional file inclusion and include guards, avoid the use of preprocessor directives. Use a safer alternative instead. For instance:
- Instead of: You can use inline functions and function templates.- #define MIN(a,b) ((a < b)? (a) : (b)) 
- Instead of: You can use a constant object.- #define MAX_ARRAY_SIZE 1024U 
In these situations, preprocessor directives do not provide the benefits that the alternatives provide, such as linkage, type checking, overloading, and so on.
Polyspace Implementation
The rule checker does not allow the use of preprocessor directives. The only exceptions are:
- #ifdef,- #ifndef,- #if,- #if defined,- #elif,- #elseand- #endif, only if used for conditional file inclusion and include guards.
- #defineonly if used for defining macros to be used in include guards. For instance, in this example, the macro- __FILE_H__prevents the contents of the header file from being included more than once:- /* aHeader.h */ #ifndef __FILE_H__ #define __FILE_H__ /* Contents of header file */ #endif - When - #ifdef,- #defineand- #endifare used as include guards in a header file, the entire content of the header file must be in the include guard.
- #include
The checker does not allow the #define directives in other contexts.
        If you use #define-s for purposes other than for include guards, do one
        of the following:
- To define macros when compiling your code, instead of - #define-s, use compilation flags (such as the GCC option- -D). When running a Polyspace® analysis, use the equivalent Polyspace option- Preprocessor definitions (-D).
- To retain the use of - #definein your code, justify the violation using comments in your results or code. See Address Results in Polyspace User Interface Through Bug Fixes or Justifications.
Troubleshooting
If you expect a rule violation but Polyspace does not report it, see Diagnose Why Coding Standard Violations Do Not Appear as Expected.
Examples
Check Information
| Group: Preprocessing directives | 
| Category: Required, Automated | 
Version History
Introduced in R2019b