 c52f43e72d
			
		
	
	c52f43e72d
	
	
	
		
			
			git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@111767 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is distributed under the University of Illinois Open Source
 | |
| // License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // <memory>
 | |
| 
 | |
| // template <class ForwardIterator, class T>
 | |
| //   void
 | |
| //   uninitialized_fill(ForwardIterator first, ForwardIterator last,
 | |
| //                      const T& x);
 | |
| 
 | |
| #include <memory>
 | |
| #include <cassert>
 | |
| 
 | |
| struct B
 | |
| {
 | |
|     static int count_;
 | |
|     int data_;
 | |
|     explicit B() : data_(1) {}
 | |
|     B(const B& b) {if (++count_ == 3) throw 1; data_ = b.data_;}
 | |
|     ~B() {data_ = 0;}
 | |
| };
 | |
| 
 | |
| int B::count_ = 0;
 | |
| 
 | |
| int main()
 | |
| {
 | |
|     const int N = 5;
 | |
|     char pool[sizeof(B)*N] = {0};
 | |
|     B* bp = (B*)pool;
 | |
|     try
 | |
|     {
 | |
|         std::uninitialized_fill(bp, bp+N, B());
 | |
|         assert(false);
 | |
|     }
 | |
|     catch (...)
 | |
|     {
 | |
|         for (int i = 0; i < N; ++i)
 | |
|             assert(bp[i].data_ == 0);
 | |
|     }
 | |
|     B::count_ = 0;
 | |
|     std::uninitialized_fill(bp, bp+2, B());
 | |
|     for (int i = 0; i < 2; ++i)
 | |
|         assert(bp[i].data_ == 1);
 | |
| }
 |