| 
									
										
										
										
											2006-09-11 22:08:18 +00:00
										 |  |  | .. Copyright David Abrahams 2006. 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)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 23:33:32 +00:00
										 |  |  | Header
 | 
					
						
							|  |  |  | ......
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  |   
 | 
					
						
							|  |  |  |   #include <boost/function_output_iterator.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class UnaryFunction>
 | 
					
						
							|  |  |  |   class function_output_iterator {
 | 
					
						
							|  |  |  |   public:
 | 
					
						
							| 
									
										
										
										
											2004-01-12 19:30:48 +00:00
										 |  |  |     typedef std::output_iterator_tag iterator_category;
 | 
					
						
							|  |  |  |     typedef void                     value_type;
 | 
					
						
							|  |  |  |     typedef void                     difference_type;
 | 
					
						
							|  |  |  |     typedef void                     pointer;
 | 
					
						
							|  |  |  |     typedef void                     reference;
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-21 16:26:04 +00:00
										 |  |  |     explicit function_output_iterator();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     explicit function_output_iterator(const UnaryFunction& f);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 13:51:28 +00:00
										 |  |  |     /* see below */ operator*();
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  |     function_output_iterator& operator++();
 | 
					
						
							|  |  |  |     function_output_iterator& operator++(int);
 | 
					
						
							| 
									
										
										
										
											2004-01-12 19:30:48 +00:00
										 |  |  |   private:
 | 
					
						
							|  |  |  |     UnaryFunction m_f;     // exposition only
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  |   };
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-12 19:30:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | ``function_output_iterator`` requirements
 | 
					
						
							| 
									
										
										
										
											2004-01-12 04:17:26 +00:00
										 |  |  | .........................................
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 13:51:28 +00:00
										 |  |  | ``UnaryFunction`` must be Assignable and Copy Constructible.  
 | 
					
						
							| 
									
										
										
										
											2004-01-12 19:30:48 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``function_output_iterator`` models
 | 
					
						
							|  |  |  | ...................................
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``function_output_iterator`` is a model of the Writable and
 | 
					
						
							|  |  |  | Incrementable Iterator concepts.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``function_output_iterator`` operations
 | 
					
						
							| 
									
										
										
										
											2004-01-12 04:17:26 +00:00
										 |  |  | .......................................
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ``explicit function_output_iterator(const UnaryFunction& f = UnaryFunction());``
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-19 18:52:48 +00:00
										 |  |  | :Effects: Constructs an instance of ``function_output_iterator`` 
 | 
					
						
							|  |  |  |   with ``m_f`` constructed from ``f``.
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 13:51:28 +00:00
										 |  |  | ``operator*();``
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-13 13:51:28 +00:00
										 |  |  | :Returns: An object ``r`` of unspecified type such that ``r = t``
 | 
					
						
							|  |  |  |   is equivalent to ``m_f(t)`` for all ``t``.
 | 
					
						
							| 
									
										
										
										
											2003-08-05 19:42:37 +00:00
										 |  |  |   
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``function_output_iterator& operator++();``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Returns: ``*this``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``function_output_iterator& operator++(int);``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Returns: ``*this``
 |