#はじめに(Introduction)
C++N4741 Working Draft, Standard for Programming Language C++
http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/
http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/n4741.pdf
C++N4741は、ISO/IEC JTC1 SC22 WG21の作業原案(Working Draft)です。
公式のISO/IEC 14882原本ではありません。
ISO/IEC JTC1 SC22 WG21では、可能な限り作業文書を公開し、幅広い意見を求めています。
一連の記事はコード断片をコンパイルできる形にする方法を検討してコンパイル、リンク、実行して、規格案の原文と処理系(g++, Clang++)との違いを確認し、技術内容を検討し、ISO/IEC JTC1 SC22 WG21にフィードバックするために用います。
また、CERT C++, MISRA C++等のコーディング標準のコード断片をコンパイルする際の参考にさせていただこうと考えています。CERT C++, MISRA C++が標準化の動きとの時間的なずれがあれば確認できれば幸いです。また、boostライブラリとの関連、Linux OS, TOPPERSカーネル、g++(GCC), clang++(LLVM)との関係も調査中です。
何か、抜け漏れ、耳より情報がありましたらおしらせくださると幸いです。
##背景(back ground)
C/C++でコンパイルエラーが出ると、途方にくれることがしばしばあります。
何回かに1回は、該当するエラーが検索できます。
ただ、条件が違っていて、そこでの修正方法では目的を達成しないこともしばしばです。いろいろな条件のコンパイルエラーとその対応方法について、広く記録することによって、いつか同じエラーに遭遇した時にやくに立つことを目指しています。
この半年の間で、三度、自分のネットでの記録に助けられたことがあります。
また過去に解決できなかった記録を10種類以上、最近になって解決できたことがあります。それは、主に次の4つの情報に基づいています。
https://stackoverflow.com
https://cpprefjp.github.io
http://ja.cppreference.com/
https://teratail.com/
また
https://researchmap.jp/joub9b3my-1797580/#_1797580
に記載したサイトのお世話になっています。
##作業方針(sequence)
Clang++では-std=c++03, c++17, C++2aの3種類
g++では-std=c++03, c++17の2種類
でコンパイルし、
1)コンパイルエラーを収集する。
2)コンパイルエラーをなくす方法を検討する。
コンパイルエラーになる例を示すだけが目的のコードは、コンパイルエラーをなくすのではなく、コンパイルエラーの種類を収集するだけにする。
文法を示すのが目的のコード場合に、コンパイルエラーをなくすのに手間がかかる場合は、順次作業します。
3)リンクエラーをなくす方法を検討する。
文法を示すのが目的のコード場合に、リンクエラーをなくすのに手間がかかる場合は、順次作業します。
4)意味のある出力を作る。
コンパイル、リンクが通っても、意味のある出力を示そうとすると、コンパイル・リンクエラーが出て収拾できそうにない場合がある。順次作業します。
1)だけのものから4)まで進んだものと色々ある状態です。一歩でも前に進むご助言をお待ちしています。「検討事項」の欄に現状を記録するようにしています。
初めての CEDD(Compile Error Driven Design) 8回直してコンパイル。
https://qiita.com/kaizen_nagoya/items/9494236aa1753f3fd1e1
##C++N4741, 2018 Standard Working Draft on ISO/IEC 14882 sample code compile list
https://qiita.com/kaizen_nagoya/items/3294c014044550896010
C++N4606, 2016符号断片編纂一覧(example code compile list)
C++N4606, 2016 Working Draft 2016, ISO/IEC 14882, C++ standard(1) Example code compile list
https://qiita.com/kaizen_nagoya/items/df5d62c35bd6ed1c3d43/
##C++N3242, 2011 sample code compile list on clang++ and g++
https://qiita.com/kaizen_nagoya/items/685b5c1a2c17c1bf1318
編纂器(Compiler)
###clang++ --version
clang version 6.0.0 (tags/RELEASE_600/final)
Target: x86_64-apple-darwin17.4.0
###g++-7 --version
g++-7 (Homebrew GCC 7.3.0_1) 7.3.0
Copyright (C) 2017 Free Software Foundation, Inc.
#(83)10.2 Enumeration declarations [dcl.enum]p157
C++N4606, 2016(75)7.2 Enumeration declarations [dcl.enum]p174
https://qiita.com/kaizen_nagoya/items/87ffe48b316037fbe1ec
C++N3242, 2011 (60) 7.2 Enumeration declarations
https://researchmap.jp/jodns8ays-1797580/#_1797580
##p157.cpp
###算譜(source code)
// C++N4741 Committee Draft, Standard for Programming Language C++
// http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/n741.pdf
const char* msg= "C++N4741(83)10.2 Enumeration declarations [dcl.enum]p157.cpp";
// Edited by Dr. Ogawa Kiyoshi. Compile procedure and results record.
#include <iostream>
#include <cstdlib>
using namespace std;
struct S {
enum E : int {};
enum E : int {}; // error: redeclaration of enumeration
};
enum { a, b, c=0 };
enum { d, e, f=e+2 };
enum color { red, yellow, green=20, blue };
color col = red;
color* cp = &col;
if (*cp == blue) // ...
color c = 1; // error: type mismatch, no conversion from int to color
int i = yellow; // OK: yellow converted to integral value 1, integral promotion
enum class Col { red, yellow, green };
int x = Col::red; // error: no Col to int conversion
Col y = Col::red;
if (y) { } // error: no Col to bool conversion
enum direction { left='l', right='r' };
void g() {
direction d; // OK
d = left; // OK
d = direction::right; // OK
}
enum class altitude { high='h', low='l' };
void h() {
altitude a; // OK
a = high; // error: high not in scope
a = altitude::low; // OK
}
struct X {
enum direction { left='l', right='r' };
int f(int i) {
return i==left ? 0 : i==right ? 1 : 2;
}
};
void g(X* p) {
direction d; // error: direction not in scope
int i;
i = p->f(left); // error: left not in scope
i = p->f(X::right); // OK
i = p->f(p->left); // OK
// ...
}
int main() {
cout<< msg << endl;
return EXIT_SUCCESS;
}
###編纂・実行結果(compile and go)
$ ../c1.sh p157
$ clang++ p157.cpp -std=c++2a -Wall
p157.cpp:14:6: error: redefinition of 'E'
enum E : int {}; // error: redeclaration of enumeration
^
p157.cpp:13:6: note: previous definition is here
enum E : int {};
^
p157.cpp:23:1: error: expected unqualified-id
if (*cp == blue) // ...
^
p157.cpp:29:5: error: cannot initialize a variable of type 'int' with an rvalue of type 'Col'
int x = Col::red; // error: no Col to int conversion
^ ~~~~~~~~
p157.cpp:31:1: error: expected unqualified-id
if (y) { } // error: no Col to bool conversion
^
p157.cpp:36:5: error: reference to 'left' is ambiguous
d = left; // OK
^
p157.cpp:33:18: note: candidate found by name lookup is 'left'
enum direction { left='l', right='r' };
^
/usr/local/Cellar/llvm/6.0.0/include/c++/v1/ios:946:1: note: candidate found by name lookup is
'std::__1::left'
left(ios_base& __str)
^
p157.cpp:42:5: error: use of undeclared identifier 'high'
a = high; // error: high not in scope
^
p157.cpp:54:10: error: reference to 'left' is ambiguous
i = p->f(left); // error: left not in scope
^
p157.cpp:33:18: note: candidate found by name lookup is 'left'
enum direction { left='l', right='r' };
^
/usr/local/Cellar/llvm/6.0.0/include/c++/v1/ios:946:1: note: candidate found by name lookup is
'std::__1::left'
left(ios_base& __str)
^
7 errors generated.
#p157a.cpp
コンパイルエラーを想定している行を///注釈に。
###算譜(source code)
// C++N4741 Committee Draft, Standard for Programming Language C++
// http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2017/n741.pdf
const char* msg= "C++N4741(83)10.2 Enumeration declarations [dcl.enum]p157.cpp";
// Edited by Dr. Ogawa Kiyoshi. Compile procedure and results record.
#include <iostream>
#include <cstdlib>
using namespace std;
struct S {
enum E : int {};
///enum E : int {}; // error: redeclaration of enumeration
};
enum { a, b, c=0 };
enum { d, e, f=e+2 };
enum color { red, yellow, green=20, blue };
void j() {
color col = red;
color* cp = &col;
if (*cp == blue) // ...
;
}
///color c = 1; // error: type mismatch, no conversion from int to color
int i = yellow; // OK: yellow converted to integral value 1, integral promotion
enum class Col { red, yellow, green };
///int x = Col::red; // error: no Col to int conversion
Col y = Col::red;
///if (y) { } // error: no Col to bool conversion
namespace N {
enum direction { left='l', right='r' };
void g() {
direction d; // OK
d = left; // OK
d = direction::right; // OK
}
enum class altitude { high='h', low='l' };
void h() {
altitude a; // OK
///a = high; // error: high not in scope
a = altitude::low; // OK
}
}
struct X {
enum direction { left='l', right='r' };
int f(int i) {
return i==left ? 0 : i==right ? 1 : 2;
}
};
void g(X* p) {
///direction d; // error: direction not in scope
int i;
///i = p->f(left); // error: left not in scope
i = p->f(X::right); // OK
i = p->f(p->left); // OK
// ...
}
int main() {
X x;
int i=3;
j();
N::g();
N::h();
g(&x);
cout << "x.f(i)="<< x.f(i) << endl;
cout<< msg << endl;
return EXIT_SUCCESS;
}
###編纂・実行結果(compile and go)
$ ../cpla.sh p157a
$ clang++ p157a.cpp -std=c++03 -Wall
p157a.cpp:12:6: error: ISO C++ forbids forward references to 'enum' types
enum E : int {};
^
p157a.cpp:12:14: error: expected '(' for function-style cast or type construction
enum E : int {};
~~~ ^
p157a.cpp:12:8: error: field has incomplete type 'enum E'
enum E : int {};
^
p157a.cpp:12:6: note: forward declaration of 'E'
enum E : int {};
^
p157a.cpp:31:6: warning: scoped enumerations are a C++11 extension [-Wc++11-extensions]
enum class Col { red, yellow, green };
^
p157a.cpp:33:9: warning: use of enumeration in a nested name specifier is a C++11 extension
[-Wc++11-extensions]
Col y = Col::red;
^
p157a.cpp:41:5: warning: use of enumeration in a nested name specifier is a C++11 extension
[-Wc++11-extensions]
d = direction::right; // OK
^
p157a.cpp:43:6: warning: scoped enumerations are a C++11 extension [-Wc++11-extensions]
enum class altitude { high='h', low='l' };
^
p157a.cpp:47:5: warning: use of enumeration in a nested name specifier is a C++11 extension
[-Wc++11-extensions]
a = altitude::low; // OK
^
5 warnings and 3 errors generated.
$ clang++ p157a.cpp -std=c++2a -Wall
x.f(i)=2
C++N4741(83)10.2 Enumeration declarations [dcl.enum]p157.cpp
$ g++-8 p157a.cpp -std=c++03 -Wall
p157a.cpp:12:10: warning: scoped enums only available with -std=c++11 or -std=gnu++11
enum E : int {};
^~~
p157a.cpp:31:1: warning: scoped enums only available with -std=c++11 or -std=gnu++11
enum class Col { red, yellow, green };
^~~~
p157a.cpp:33:9: error: 'Col' is not a class or namespace
Col y = Col::red;
^~~
p157a.cpp: In function 'void N::g()':
p157a.cpp:41:5: error: 'direction' is not a class or namespace
d = direction::right; // OK
^~~~~~~~~
p157a.cpp: At global scope:
p157a.cpp:43:1: warning: scoped enums only available with -std=c++11 or -std=gnu++11
enum class altitude { high='h', low='l' };
^~~~
p157a.cpp: In function 'void N::h()':
p157a.cpp:47:5: error: 'altitude' is not a class or namespace
a = altitude::low; // OK
^~~~~~~~
$ g++-8 p157a.cpp -std=c++2a -Wall
p157a.cpp: In function 'void N::g()':
p157a.cpp:39:11: warning: variable 'd' set but not used [-Wunused-but-set-variable]
direction d; // OK
^
p157a.cpp: In function 'void N::h()':
p157a.cpp:45:10: warning: variable 'a' set but not used [-Wunused-but-set-variable]
altitude a; // OK
^
p157a.cpp: In function 'void g(X*)':
p157a.cpp:59:5: warning: variable 'i' set but not used [-Wunused-but-set-variable]
int i;
^
x.f(i)=2
C++N4741(83)10.2 Enumeration declarations [dcl.enum]p157.cpp
#検討事項(agenda)
役に立つまたは意味のあるその他の出力
#参考資料(reference)
docker gnu(gcc/g++) and llvm(clang/clang++)
https://qiita.com/drafts/059874ea39c4de64c0f7
[C][C++]の国際規格案の例題をコンパイルするときの課題7つ。
https://qiita.com/kaizen_nagoya/items/5f4b155030259497c4de
C++N4606 Working Draft 2016, ISO/IEC 14882, C++ standardのコード断片をコンパイルするためにしていること
https://qiita.com/kaizen_nagoya/items/a8d7ee2f2e29e76c19c1
コンパイル用shell script C版(clangとgcc)とC++版(clang++とg++)
https://qiita.com/kaizen_nagoya/items/74220c0577a512c2d7da
Clang/Clang++(LLVM) gcc/g++(GNU) コンパイラ警告等比較
https://qiita.com/kaizen_nagoya/items/9a82b958cc3aeef0403f
C++2003とC++2017でコンパイルエラーになるならない事例集
https://qiita.com/kaizen_nagoya/items/a13ea3823441c430edff
Qiitaに投稿するCのStyle例(暫定)
https://qiita.com/kaizen_nagoya/items/946df1528a6a1ef2bc0d
cpprefjpのdecltypeをコンパイル試験
https://qiita.com/kaizen_nagoya/items/090909af702f0d5d8a67
MISRA C++ 5-0-16
https://qiita.com/kaizen_nagoya/items/7df2d4e05db724752a74
C++ Templates Part1 BASICS Chapter 3. Class Templates 3.2 Use of Class Template Stack stack1test.cpp
https://qiita.com/kaizen_nagoya/items/cd5fc49106fad5a4e9ed
ISO/IEC TS 17961:2013 C Secure Coding Rules(1) All list(to be confirmed)
https://qiita.com/kaizen_nagoya/items/54e056195c4f11b850a1
C言語(C++)に対する誤解、曲解、無理解、爽快。
https://qiita.com/kaizen_nagoya/items/3f3992c9722c1cee2e3a
C Puzzle Bookの有り難み5つ、C言語規格及びCコンパイラの特性を認識
https://qiita.com/kaizen_nagoya/items/d89a48c1536a02ecdec9
'wchar.h' file not found で困った clang++ macOS
https://qiita.com/kaizen_nagoya/items/de15cd46d657517fac11
Open POSIX Test Suiteの使い方を調べはじめました
https://qiita.com/kaizen_nagoya/items/644d5e407f5faf96e6dc
MISRA-C 2012 Referenceに掲載している文献の入手可能性を確認
https://qiita.com/kaizen_nagoya/items/96dc8b125e462d5575bb
どうやって MISRA Example Suiteをコンパイルするか
https://qiita.com/kaizen_nagoya/items/fbdbff5ff696e2ca7f00
MISRA C まとめ #include
https://qiita.com/kaizen_nagoya/items/f1a79a7cbd281607c7c9
「C++完全理解ガイド」の同意できること上位10
https://qiita.com/kaizen_nagoya/items/aa5744e0c4a8618c7671
#文書履歴(document history)
ver. 0.10 初稿 20180522
ver. 0.11 誤記訂正 20180523