주요 콘텐츠

MISRA C:2023 Rule 20.6

Tokens that look like a preprocessing directive shall not occur within a macro argument

Since R2024a

Description

Rule Definition

Tokens that look like a preprocessing directive shall not occur within a macro argument1 .

Rationale

An argument containing sequences of tokens that otherwise act as preprocessing directives leads to undefined behavior.

Polyspace Implementation

Polyspace® looks for the # character in a macro arguments (outside a string or character constant).

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

expand all

#define M( A ) printf ( #A )

#include <stdio.h>

void foo(void){
    M(
#ifdef SW         /* Non-compliant */
    "Message 1"
#else
    "Message 2"   /* Compliant - SW not defined */
#endif            
    );
}

This example shows a macro definition and the macro usage. #ifdef SW is noncompliant because it look like a preprocessing directive. Polyspace does not flag #else "Message 2" because after macro expansion, Polyspace knows SW is not defined. The expanded macro is printf ("\"Message 2\"");

Check Information

Group: Preprocessing Directives
Category: Required
AGC Category: Required

Version History

Introduced in R2024a

expand all


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.