 cc2e93cff0
			
		
	
	cc2e93cff0
	
	
	
		
			
			Fixes a small omission in libcxx that prevents libcxx being built when -DLIBCXX_ENABLE_EXCEPTIONS=0 is specified. This patch adds XFAILS to all those tests that are currently failing on the new -fno-exceptions library variant. Follow-up patches will update the tests (progressively) to cope with the new library variant. Change-Id: I4b801bd8d8e4fe7193df9e55f39f1f393a8ba81a git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@252598 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is dual licensed under the MIT and the University of Illinois Open
 | |
| // Source Licenses. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // XFAIL: libcpp-no-exceptions
 | |
| // <regex>
 | |
| 
 | |
| // template <class charT, class traits = regex_traits<charT>> class basic_regex;
 | |
| 
 | |
| // template <class ST, class SA>
 | |
| //    basic_regex(const basic_string<charT, ST, SA>& s);
 | |
| 
 | |
| #include <regex>
 | |
| #include <cassert>
 | |
| 
 | |
| static bool error_badrepeat_thrown(const char *pat) 
 | |
| {
 | |
|     bool result = false;
 | |
|     try {
 | |
|         std::regex re(pat);
 | |
|     } catch (const std::regex_error &ex) {
 | |
|         result = (ex.code() == std::regex_constants::error_badrepeat);
 | |
|     }
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| int main() 
 | |
| {
 | |
|     assert(error_badrepeat_thrown("?a"));
 | |
|     assert(error_badrepeat_thrown("*a"));
 | |
|     assert(error_badrepeat_thrown("+a"));
 | |
|     assert(error_badrepeat_thrown("{a"));
 | |
| 
 | |
|     assert(error_badrepeat_thrown("?(a+)"));
 | |
|     assert(error_badrepeat_thrown("*(a+)"));
 | |
|     assert(error_badrepeat_thrown("+(a+)"));
 | |
|     assert(error_badrepeat_thrown("{(a+)"));
 | |
| }
 |