| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | [/ | 
					
						
							|  |  |  |   Copyright 2000 Beman Dawes & John Maddock. | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  |   Copyright (c) 2021, Alan Freitas | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Distributed under the Boost Software License, Version 1.0. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   See accompanying file LICENSE_1_0.txt | 
					
						
							|  |  |  |   or copy at http://boost.org/LICENSE_1_0.txt | 
					
						
							|  |  |  | ] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | [section Compressed Pair] | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:52:17 -03:00
										 |  |  | [section Introduction] | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-28 15:24:39 -03:00
										 |  |  | All of the contents of [@../../../../boost/compressed_pair.hpp `<boost/compressed_pair.hpp>`] are defined inside | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | `namespace boost`. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | The class __compressed_pair__ is very similar to __std_pair__. However, if either of | 
					
						
							|  |  |  | the template arguments are empty classes, then the | 
					
						
							|  |  |  | [@https://en.cppreference.com/w/cpp/language/ebo ['empty base-class optimisation]] | 
					
						
							|  |  |  | is applied to compress the size of the pair. | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:52:17 -03:00
										 |  |  | [endsect] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [section Synopsis] | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | ```cpp | 
					
						
							|  |  |  | template <class T1, class T2> | 
					
						
							|  |  |  | class __compressed_pair__ | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     typedef T1                                                 first_type; | 
					
						
							|  |  |  |     typedef T2                                                 second_type; | 
					
						
							|  |  |  |     typedef typename __call_traits__<first_type>::param_type       first_param_type; | 
					
						
							|  |  |  |     typedef typename __call_traits__<second_type>::param_type      second_param_type; | 
					
						
							|  |  |  |     typedef typename __call_traits__<first_type>::reference        first_reference; | 
					
						
							|  |  |  |     typedef typename __call_traits__<second_type>::reference       second_reference; | 
					
						
							|  |  |  |     typedef typename __call_traits__<first_type>::const_reference  first_const_reference; | 
					
						
							|  |  |  |     typedef typename __call_traits__<second_type>::const_reference second_const_reference; | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  |              compressed_pair() : base() {} | 
					
						
							|  |  |  |              compressed_pair(first_param_type x, second_param_type y); | 
					
						
							|  |  |  |     explicit compressed_pair(first_param_type x); | 
					
						
							|  |  |  |     explicit compressed_pair(second_param_type y); | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  |     compressed_pair& operator=(const compressed_pair&); | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  |     first_reference       first(); | 
					
						
							|  |  |  |     first_const_reference first() const; | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  |     second_reference       second(); | 
					
						
							|  |  |  |     second_const_reference second() const; | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  |     void swap(compressed_pair& y); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | The two members of the pair can be accessed using the member functions | 
					
						
							|  |  |  | `first()` and `second()`. Note that not all member functions can be | 
					
						
							|  |  |  | instantiated for all template parameter types. In particular | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | __compressed_pair__ can be instantiated for reference and array types, | 
					
						
							|  |  |  | however in these cases the range of constructors that can be used is | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | limited. If types `T1` and `T2` are the same type, then there is only | 
					
						
							|  |  |  | one version of the single-argument constructor, and this constructor | 
					
						
							|  |  |  | initialises both values in the pair to the passed value. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | Note that if either member is a [@https://en.cppreference.com/w/cpp/named_req/PODType POD] | 
					
						
							|  |  |  | type, then that member is not zero-initialized by the __compressed_pair__ default constructor: | 
					
						
							|  |  |  | it is up to you to supply an initial value for these types if you want them to have | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | a default value. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | Note that __compressed_pair__ can not be instantiated if either of the | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | template arguments is a union type, unless there is compiler support for | 
					
						
							| 
									
										
										
										
											2021-12-28 15:24:39 -03:00
										 |  |  | [@boost:/libs/type_traits/index.html `boost::is_union`], or | 
					
						
							|  |  |  | if [@boost:/libs/type_traits/index.html `boost::is_union`] is | 
					
						
							| 
									
										
										
										
											2021-11-05 21:50:00 -03:00
										 |  |  | specialised for the union type. | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | Finally, a word of caution for Visual C++ 6 users: if either argument is an | 
					
						
							|  |  |  | empty type, then assigning to that member will produce memory corruption, | 
					
						
							|  |  |  | unless the empty type has a "do nothing" assignment operator defined. This | 
					
						
							|  |  |  | is due to a bug in the way VC6 generates implicit assignment operators. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-05 21:52:17 -03:00
										 |  |  | [endsect] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [/===============] | 
					
						
							| 
									
										
										
										
											2021-11-16 17:15:50 +03:00
										 |  |  | [xinclude tmp/compressed_pair_reference.xml] | 
					
						
							| 
									
										
										
										
											2021-11-05 21:52:17 -03:00
										 |  |  | [/===============] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [section Acknowledgments] | 
					
						
							| 
									
										
										
										
											2014-06-11 19:25:29 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | Based on contributions by Steve Cleary, Beman Dawes, Howard Hinnant and | 
					
						
							|  |  |  | John Maddock. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Maintained by [@mailto:john@johnmaddock.co.uk John Maddock]. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [endsect] | 
					
						
							| 
									
										
										
										
											2021-11-05 21:52:17 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | [endsect] |