Hi Everyone,
I am continuing with updating the Lit tests for C++11 compatibility.
There are 5 tests.
test/Modules/Inputs/merge-using-decls/a.h
test/Modules/Inputs/merge-using-decls/b.h
test/Modules/merge-using-decls.cpp
This test verifies the interaction between Modules and Using declarations. Part of this test, template struct “E” checks for mismatch between using declarations in a.h and Access declarations in b.h. Since C++11 has deprecated Access declarations, module “B” will fail to build. Therefore, I have restricted this part of the test to only use C++98.
test/SemaCXX/PR9572.cpp
This test verifies 2 types of diagnostics. Type 1: Warning for unsupported C++11 feature when compiling at C++98. Guard the following Warning under C++98. C++98: warning: in-class initialization of non-static data member is a C++11 extension [-Wc++11-extensions] Type 2: Errors when derived class inherit a private virtual destructor in the base class. Class Base has a private virtual destructor. Struct Foo inherits Base. Foo does not explicitly declare a destructor. Struct Bar inherits Foo. Bar explicitly declares a destructor. Struct Baz contains an instance of Foo as its member. Because C++11 introduced ‘delete’, this results in the following changes in diagnostics. C++98 issues 1 Error on Base’s private destructor. C++11 issues 4 Errors at all points of the inheritance chain where the destructor is implicitly deleted. C++98: error: base class 'Base' has private destructor note: implicitly declared private here note: implicit destructor for 'Foo' first required here C++11: error: deleted function '~Foo' cannot override a non-deleted function note: overridden virtual function is here C++11: error: non-deleted function '~Bar' cannot override a deleted function note: overridden virtual function is here C++11: error: attempt to use a deleted function note: destructor of 'Foo' is implicitly deleted because base class 'Base' has an inaccessible destructor C++11: error: attempt to use a deleted function note: destructor of 'Foo' is implicitly deleted because base class 'Base' has an inaccessible destructor
test/SemaCXX/default-assignment-operator.cpp
C++11 introduced ‘delete’. Change in diagnostics regarding implicitly deleted copy assignment operator. This test change contains 3 parts: Test1, Test5, ProtectedCheck. Test1 Class Base has a member “int &ref” that is never initialized. Class X is derived from Base. Neither Base nor X explicitly declare their copy assignment operator. In C++98, Clang issues one error for each implicit class copy assignment operator definition failure (“Base” and “X”). In C++11, Clang issues one error for each assignment statement of the class instance. (“x = cx;” and “x = cx;”) And since there are 2 copy assignments of x, there are 2 sets of identical diagnostics in C++11. C++98: error: cannot define the implicit copy assignment operator for 'Base', because non-static reference member 'ref' cannot use copy assignment operator note: declared here note: implicit copy assignment operator for 'Base' first required here error: cannot define the implicit copy assignment operator for 'X', because non-static const member 'cint' cannot use copy assignment operator note: declared here note: implicit copy assignment operator for 'X' first required here C++11: error: object of type 'X' cannot be assigned because its copy assignment operator is implicitly deleted note: copy assignment operator of 'X' is implicitly deleted because base class 'Base' has a deleted copy assignment operator note: copy assignment operator of 'Base' is implicitly deleted because field 'ref' is of reference type 'int &' error: object of type 'X' cannot be assigned because its copy assignment operator is implicitly deleted note: copy assignment operator of 'X' is implicitly deleted because base class 'Base' has a deleted copy assignment operator note: copy assignment operator of 'Base' is implicitly deleted because field 'ref' is of reference type 'int &' Test5 Class E1 has a constant integer member ‘a’. E1 has a default constructor “E1() : a(0) {}”. Two instances of E1 are created, e1 and e2. e2 is assigned to e1. Change in diagnostics messages. C++98: error: cannot define the implicit copy assignment operator for 'E1', because non-static const member 'a' cannot use copy assignment operator note: declared here note: implicit copy assignment operator for 'E1' first required here C++11: error: object of type 'E1' cannot be assigned because its copy assignment operator is implicitly deleted note: copy assignment operator of 'E1' is implicitly deleted because field 'a' is of const-qualified type 'const int' ProtectedCheck Class X has a protected copy assignment operator. Struct Z contains an instance of X. An instance of Z, z, is copy assigned to itself (z = z). C++98 and C++11 issues different diagnostics. C++98: error: 'operator=' is a protected member of 'ProtectedCheck::X' note: declared protected here note: implicit copy assignment operator for 'ProtectedCheck::Z' first required here C++11: error: object of type 'ProtectedCheck::Z' cannot be assigned because its copy assignment operator is implicitly deleted note: copy assignment operator of 'Z' is implicitly deleted because field 'x' has an inaccessible copy assignment operator
test/SemaCXX/default-constructor-initializers.cpp
C++11 introduced ‘delete’. As a result, implicitly deleted default constructor diagnostics changed. http://en.cppreference.com/w/cpp/language/default_constructor Part 1 X1 has no implicitly default constructor. X2 inherits X1. X3 inherits X2. X3 is instantiated. C++98: error: implicit default constructor for 'X3' must explicitly initialize the base class 'X2' which does not have a default constructor note: 'X2' declared here note: implicit default constructor for 'X3' first required here C++11: error: call to implicitly-deleted default constructor of 'X3' note: default constructor of 'X3' is implicitly deleted because base class 'X2' has no default constructor Part 2. X4 contains an instance of X2 and a reference of X2. C++98 issues 2 Errors, one for each member of the class. C++11 issues 1 Error, for the instantiation of the class. C++98: error: implicit default constructor for 'X4' must explicitly initialize the member 'x2' which does not have a default constructor note: member is declared here note: 'X2' declared here C++98: error: implicit default constructor for 'X4' must explicitly initialize the reference member 'rx2' note: declared here note: implicit default constructor for 'X4' first required here C++11: error: call to implicitly-deleted default constructor of 'X4' note: default constructor of 'X4' is implicitly deleted because field 'x2' has no default constructor Part 3. Z1 has 3 members: integer reference z, constant integer c1 and volatile integer v1. None of which are explicitly initialized. Therefore, Z1 has no implicitly default constructor. C++98 issues 2 Errors. One for the integer reference member. One for the constant integer member. C++11 issues 1 Error for the instantiation of the class. C++98: error: implicit default constructor for 'Z1' must explicitly initialize the reference member 'z' note: declared here error: implicit default constructor for 'Z1' must explicitly initialize the const member 'c1' note: declared here note: implicit default constructor for 'Z1' first required here C++11: error: call to implicitly-deleted default constructor of 'Z1' note: default constructor of 'Z1' is implicitly deleted because field 'z' of reference type 'int &' would not be initialized
test/SemaCXX/warn-thread-safety-parsing.cpp
In C++11, does not issue Errors for thread safety attributes applied to static members. http://clang.llvm.org/docs/ThreadSafetyAnalysis.html This may be a side effect of C++11’s relaxation on in-class member initializers. http://www.stroustrup.com/C++11FAQ.html#member-init Restrict the following diagnostics to C++98. (2 instances each) C++98: error: invalid use of non-static data member 'mu' C++98: error: invalid use of member 'mu' in static member function
I don't see a reason to #ifdef this portion, which should work either way, and likewise for the other change to this file. (The changes to the other header and to the cpp file look fine and appropriate, though.)