メインコンテンツ

MISRA C++:2023 Rule 19.2.2

The #include directive shall be followed by either a <filename> or "filename" sequence

R2024b 以降

説明

ルール定義

The #include directive shall be followed by either a <filename> or "filename" sequence. 1

根拠

このルールはマクロの置換後にのみ適用されます。

#include 命令が次のいずれかの形式を使用していない場合、コードの動作は未定義になります。

  • #include <filename>

  • #include "filename"

ISO/IEC 14882:2003 では、これ以外の形式の #include 命令を使用することは許可されていません。予期しない動作を避けるには、不正な形式の #include ステートメントの使用を避けます。

Polyspace 実装

#include 命令の後に <filename> または "filename" が指定されていない場合、Polyspace® はこのルールの違反を報告します。ここで filename は、有効なヘッダー ファイルまたはヘッダー ファイルのパスです。

トラブルシューティング

ルール違反が想定されるものの、Polyspace から報告されない場合は、コーディング規約違反が想定どおりに表示されない理由の診断を参照してください。

すべて展開する

以下の例は、許容される形式をマクロ置換後に使用した、準拠する #include 命令を示しています。Polyspace は、許容される形式を使用しない不正な形式の #include 命令に対して違反を報告します。


#include "incguard.h"     //Compliant
#include <incguard.h>     //Compliant

#define MH "myheader.h"
#define STR <string>    //Compliant
#include MH             //Compliant
#include STR            //Compliant

#include myfile.h       //Noncompliant
#include iostream       //Noncompliant
#include math.h         //Noncompliant
#include "math.h>       //Noncompliant
#include >myHeader.h<   //Noncompliant
#include <math.h        //Noncompliant
#include math.h>        //Noncompliant

チェック情報

グループ: プリプロセッサ命令
カテゴリ: 必要

バージョン履歴

R2024b で導入


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.