| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | /* 
 | 
					
						
							|  |  |  |    Copyright (c) Marshall Clow 2012. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Distributed under the Boost Software License, Version 1.0. (See accompanying | 
					
						
							|  |  |  |    file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
 | 
					
						
							|  |  |  |     | 
					
						
							|  |  |  |    Alternate interfaces (aka "wrappers") for algorithms. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | #ifndef BOOST_ALGORITHM_WRAPPERS_HPP
 | 
					
						
							|  |  |  | #define BOOST_ALGORITHM_WRAPPERS_HPP
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace boost { namespace algorithm { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// \fn find_ptr ( Container &c, Key k )
 | 
					
						
							|  |  |  | /// \return a pointer to the value matching the key in the container, 
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | /// or NULL if the key does not exist in the container.
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | ///
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | /// \note: This is a wrapper around Container::find, with a useful interface.
 | 
					
						
							|  |  |  | /// Suggested by Olaf van der Spek 
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | /// 
 | 
					
						
							|  |  |  | /// \param c    The container to be searched
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | /// \param k    The key value to search with
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | template <class Container, class Key> | 
					
						
							|  |  |  | typename Container::value_type::second_type*  | 
					
						
							|  |  |  | find_ptr ( Container &c, Key k ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  |     typename Container::iterator iter = c.find ( k ); | 
					
						
							|  |  |  |     return iter == c.end() ? NULL : &iter->second; | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// \fn find_ptr ( const Container &c, Key k )
 | 
					
						
							|  |  |  | /// \return a pointer to the value matching the key in the container, 
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | /// or NULL if the key does not exist in the container.
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | ///
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | /// \note: This is a wrapper around Container::find, with a useful interface.
 | 
					
						
							|  |  |  | /// Suggested by Olaf van der Spek 
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | /// 
 | 
					
						
							|  |  |  | /// \param c    The container to be searched
 | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  | /// \param k    The key value to search with
 | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | template <class Container, class Key> | 
					
						
							|  |  |  | const typename Container::value_type::second_type*  | 
					
						
							|  |  |  | find_ptr ( const Container &c, Key k ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-07-19 00:28:16 +00:00
										 |  |  |     typename Container::const_iterator iter = c.find ( k ); | 
					
						
							|  |  |  |     return iter == c.end() ? NULL : &iter->second; | 
					
						
							| 
									
										
										
										
											2012-07-09 17:31:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |