libcxx initial import
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@103490 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		
							
								
								
									
										90
									
								
								test/containers/associative/map/map.ops/find.pass.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								test/containers/associative/map/map.ops/find.pass.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | ||||
| //===----------------------------------------------------------------------===// | ||||
| // | ||||
| // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>The LLVM Compiler Infrastructure | ||||
| // | ||||
| // This file is distributed under the University of Illinois Open Source | ||||
| // License. See LICENSE.TXT for details. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| // <map> | ||||
|  | ||||
| // class map | ||||
|  | ||||
| //       iterator find(const key_type& k); | ||||
| // const_iterator find(const key_type& k) const; | ||||
|  | ||||
| #include <map> | ||||
| #include <cassert> | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     typedef std::pair<const int, double> V; | ||||
|     typedef std::map<int, double> M; | ||||
|     { | ||||
|         typedef M::iterator R; | ||||
|         V ar[] = | ||||
|         { | ||||
|             V(5, 5), | ||||
|             V(6, 6), | ||||
|             V(7, 7), | ||||
|             V(8, 8), | ||||
|             V(9, 9), | ||||
|             V(10, 10), | ||||
|             V(11, 11), | ||||
|             V(12, 12) | ||||
|         }; | ||||
|         M m(ar, ar+sizeof(ar)/sizeof(ar[0])); | ||||
|         R r = m.find(5); | ||||
|         assert(r == m.begin()); | ||||
|         r = m.find(6); | ||||
|         assert(r == next(m.begin())); | ||||
|         r = m.find(7); | ||||
|         assert(r == next(m.begin(), 2)); | ||||
|         r = m.find(8); | ||||
|         assert(r == next(m.begin(), 3)); | ||||
|         r = m.find(9); | ||||
|         assert(r == next(m.begin(), 4)); | ||||
|         r = m.find(10); | ||||
|         assert(r == next(m.begin(), 5)); | ||||
|         r = m.find(11); | ||||
|         assert(r == next(m.begin(), 6)); | ||||
|         r = m.find(12); | ||||
|         assert(r == next(m.begin(), 7)); | ||||
|         r = m.find(4); | ||||
|         assert(r == next(m.begin(), 8)); | ||||
|     } | ||||
|     { | ||||
|         typedef M::const_iterator R; | ||||
|         V ar[] = | ||||
|         { | ||||
|             V(5, 5), | ||||
|             V(6, 6), | ||||
|             V(7, 7), | ||||
|             V(8, 8), | ||||
|             V(9, 9), | ||||
|             V(10, 10), | ||||
|             V(11, 11), | ||||
|             V(12, 12) | ||||
|         }; | ||||
|         const M m(ar, ar+sizeof(ar)/sizeof(ar[0])); | ||||
|         R r = m.find(5); | ||||
|         assert(r == m.begin()); | ||||
|         r = m.find(6); | ||||
|         assert(r == next(m.begin())); | ||||
|         r = m.find(7); | ||||
|         assert(r == next(m.begin(), 2)); | ||||
|         r = m.find(8); | ||||
|         assert(r == next(m.begin(), 3)); | ||||
|         r = m.find(9); | ||||
|         assert(r == next(m.begin(), 4)); | ||||
|         r = m.find(10); | ||||
|         assert(r == next(m.begin(), 5)); | ||||
|         r = m.find(11); | ||||
|         assert(r == next(m.begin(), 6)); | ||||
|         r = m.find(12); | ||||
|         assert(r == next(m.begin(), 7)); | ||||
|         r = m.find(4); | ||||
|         assert(r == next(m.begin(), 8)); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Howard Hinnant
					Howard Hinnant