mirror of
				https://github.com/llvm-mirror/libcxx.git
				synced 2025-10-23 10:07:41 +08:00 
			
		
		
		
	Tolerate Clangs new static_assert messages
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@349189 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -20,6 +20,6 @@ int main() | |||||||
|     { |     { | ||||||
|     typedef std::pair<int, double> P; |     typedef std::pair<int, double> P; | ||||||
|     std::tuple_element<2, P>::type foo; // expected-note {{requested here}} |     std::tuple_element<2, P>::type foo; // expected-note {{requested here}} | ||||||
|         // expected-error@utility:* {{static_assert failed "Index out of bounds in std::tuple_element<std::pair<T1, T2>>"}} |         // expected-error-re@utility:* {{static_assert failed{{( due to requirement '2UL < 2')?}} "Index out of bounds in std::tuple_element<std::pair<T1, T2>>"}} | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -31,6 +31,6 @@ int main() | |||||||
|     { |     { | ||||||
|         typedef std::variant<int, double> T; |         typedef std::variant<int, double> T; | ||||||
|         std::variant_alternative<2, T>::type foo; // expected-note {{requested here}} |         std::variant_alternative<2, T>::type foo; // expected-note {{requested here}} | ||||||
|         // expected-error@variant:* {{static_assert failed "Index out of bounds in std::variant_alternative<>"}} |         // expected-error-re@variant:* {{static_assert failed{{( due to requirement '2UL < sizeof...\(_Types\)')?}} "Index out of bounds in std::variant_alternative<>"}} | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ template <class PopulationIterator, class SampleIterator> void test() { | |||||||
| } | } | ||||||
|  |  | ||||||
| int main() { | int main() { | ||||||
|   // expected-error@algorithm:* {{static_assert failed "SampleIterator must meet the requirements of RandomAccessIterator"}} |   // expected-error-re@algorithm:* {{static_assert failed{{( due to requirement '.*')?}} "SampleIterator must meet the requirements of RandomAccessIterator"}} | ||||||
|   // expected-error@algorithm:* 2 {{does not provide a subscript operator}} |   // expected-error@algorithm:* 2 {{does not provide a subscript operator}} | ||||||
|   // expected-error@algorithm:* {{invalid operands}} |   // expected-error@algorithm:* {{invalid operands}} | ||||||
|   test<input_iterator<int *>, output_iterator<int *> >(); |   test<input_iterator<int *>, output_iterator<int *> >(); | ||||||
|   | |||||||
| @@ -31,6 +31,6 @@ int main() | |||||||
|         typedef std::array<T, 3> C; |         typedef std::array<T, 3> C; | ||||||
|         C c = {1, 2, 3.5}; |         C c = {1, 2, 3.5}; | ||||||
|         std::get<3>(c) = 5.5; // expected-note {{requested here}} |         std::get<3>(c) = 5.5; // expected-note {{requested here}} | ||||||
|         // expected-error@array:* {{static_assert failed "Index out of bounds in std::get<> (std::array)"}} |         // expected-error-re@array:* {{static_assert failed{{( due to requirement '3UL < 3UL')?}} "Index out of bounds in std::get<> (std::array)"}} | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -30,6 +30,6 @@ int main() | |||||||
|         typedef double T; |         typedef double T; | ||||||
|         typedef std::array<T, 3> C; |         typedef std::array<T, 3> C; | ||||||
|         std::tuple_element<3, C> foo; // expected-note {{requested here}} |         std::tuple_element<3, C> foo; // expected-note {{requested here}} | ||||||
|         // expected-error@array:* {{static_assert failed "Index out of bounds in std::tuple_element<> (std::array)"}} |         // expected-error-re@array:* {{static_assert failed{{( due to requirement '3UL < 3UL')?}} "Index out of bounds in std::tuple_element<> (std::array)"}} | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ | |||||||
|  |  | ||||||
| int main () | int main () | ||||||
| { | { | ||||||
|     std::span<int, 2> s; // expected-error@span:* {{static_assert failed "Can't default construct a statically sized span with size > 0"}} |     std::span<int, 2> s; // expected-error-re@span:* {{static_assert failed{{( due to requirement '2L == 0')?}} "Can't default construct a statically sized span with size > 0"}} | ||||||
|  |  | ||||||
| //  TODO: This is what I want: | //  TODO: This is what I want: | ||||||
| // eXpected-error {{no matching constructor for initialization of 'std::span<int, 2>'}} | // eXpected-error {{no matching constructor for initialization of 'std::span<int, 2>'}} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Eric Fiselier
					Eric Fiselier