Skip to content

Latest commit

 

History

History
49 lines (35 loc) · 2.41 KB

std.compat.md

File metadata and controls

49 lines (35 loc) · 2.41 KB

std.compat

  • std.compat[meta module]
  • cpp23[meta cpp]

std.compat は、stdに加えて、C言語互換ライブラリの内容をグローバル名前空間にも導入するモジュール

stdと同様に、マクロは含まない。

import std.compat;

int main() {
  std::printf("Hello, world!"); // OK
  printf("Hello, world!");      // OK

  std::size_t x = 0;            // OK
  size_t y = 0;                 // OK
}

備考

std.compatstdの内容をすべて含んでいるので、std.compatをインポートする場合はstdをインポートしなくてよい。

この機能が必要になった背景・経緯

標準ライブラリモジュールstdで、C言語互換ライブラリの内容をグローバル名前空間に導入するかどうかで意見が分かれた結果、別のモジュールとして用意することになった。

  • C言語互換ライブラリの内容をグローバル名前空間に導入しない場合、既存コードベースを移行するのが難しくなる(例えば、std::size_tではなくsize_tと書いているコードは多いだろう)。
  • 一方、「<foobar.h>は確実にグローバル名前空間へ名前を導入する一方、std名前空間に導入するかどうかは未規定。<cfoobar>はその逆」という混乱した状況を、グローバル名前空間へ名前を導入しない方向へ解決する滅多にない機会でもあった。

そこで、2つのモジュールを用意することで両方の課題を解決することとなった。グローバル名前空間を綺麗にしたいユーザーはstdのみを使用すればよい。 一方、既存コードの互換性を重視したいときは、std.compatをインポートすればよい。 ただし、この場合でも標準ライブラリのマクロに依存したコードの互換性はない点には注意が必要である。

バージョン

言語

  • C++23

処理系

関連項目

参照