1*b0d29bc4SBrooks Davis// Copyright 2014 The Kyua Authors. 2*b0d29bc4SBrooks Davis// All rights reserved. 3*b0d29bc4SBrooks Davis// 4*b0d29bc4SBrooks Davis// Redistribution and use in source and binary forms, with or without 5*b0d29bc4SBrooks Davis// modification, are permitted provided that the following conditions are 6*b0d29bc4SBrooks Davis// met: 7*b0d29bc4SBrooks Davis// 8*b0d29bc4SBrooks Davis// * Redistributions of source code must retain the above copyright 9*b0d29bc4SBrooks Davis// notice, this list of conditions and the following disclaimer. 10*b0d29bc4SBrooks Davis// * Redistributions in binary form must reproduce the above copyright 11*b0d29bc4SBrooks Davis// notice, this list of conditions and the following disclaimer in the 12*b0d29bc4SBrooks Davis// documentation and/or other materials provided with the distribution. 13*b0d29bc4SBrooks Davis// * Neither the name of Google Inc. nor the names of its contributors 14*b0d29bc4SBrooks Davis// may be used to endorse or promote products derived from this software 15*b0d29bc4SBrooks Davis// without specific prior written permission. 16*b0d29bc4SBrooks Davis// 17*b0d29bc4SBrooks Davis// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 18*b0d29bc4SBrooks Davis// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 19*b0d29bc4SBrooks Davis// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 20*b0d29bc4SBrooks Davis// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 21*b0d29bc4SBrooks Davis// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 22*b0d29bc4SBrooks Davis// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 23*b0d29bc4SBrooks Davis// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24*b0d29bc4SBrooks Davis// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25*b0d29bc4SBrooks Davis// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26*b0d29bc4SBrooks Davis// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27*b0d29bc4SBrooks Davis// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28*b0d29bc4SBrooks Davis 29*b0d29bc4SBrooks Davis#if !defined(UTILS_FORMAT_CONTAINERS_IPP) 30*b0d29bc4SBrooks Davis#define UTILS_FORMAT_CONTAINERS_IPP 31*b0d29bc4SBrooks Davis 32*b0d29bc4SBrooks Davis#include "utils/format/containers.hpp" 33*b0d29bc4SBrooks Davis 34*b0d29bc4SBrooks Davis#include <ostream> 35*b0d29bc4SBrooks Davis 36*b0d29bc4SBrooks Davis 37*b0d29bc4SBrooks Davis/// Injects the object into a stream. 38*b0d29bc4SBrooks Davis/// 39*b0d29bc4SBrooks Davis/// \param output The stream into which to inject the object. 40*b0d29bc4SBrooks Davis/// \param object The object to format. 41*b0d29bc4SBrooks Davis/// 42*b0d29bc4SBrooks Davis/// \return The output stream. 43*b0d29bc4SBrooks Davistemplate< typename K, typename V > 44*b0d29bc4SBrooks Davisstd::ostream& 45*b0d29bc4SBrooks Davisstd::operator<<(std::ostream& output, const std::map< K, V >& object) 46*b0d29bc4SBrooks Davis{ 47*b0d29bc4SBrooks Davis output << "map("; 48*b0d29bc4SBrooks Davis typename std::map< K, V >::size_type counter = 0; 49*b0d29bc4SBrooks Davis for (typename std::map< K, V >::const_iterator iter = object.begin(); 50*b0d29bc4SBrooks Davis iter != object.end(); ++iter, ++counter) { 51*b0d29bc4SBrooks Davis if (counter != 0) 52*b0d29bc4SBrooks Davis output << ", "; 53*b0d29bc4SBrooks Davis output << (*iter).first << "=" << (*iter).second; 54*b0d29bc4SBrooks Davis } 55*b0d29bc4SBrooks Davis output << ")"; 56*b0d29bc4SBrooks Davis return output; 57*b0d29bc4SBrooks Davis} 58*b0d29bc4SBrooks Davis 59*b0d29bc4SBrooks Davis 60*b0d29bc4SBrooks Davis/// Injects the object into a stream. 61*b0d29bc4SBrooks Davis/// 62*b0d29bc4SBrooks Davis/// \param output The stream into which to inject the object. 63*b0d29bc4SBrooks Davis/// \param object The object to format. 64*b0d29bc4SBrooks Davis/// 65*b0d29bc4SBrooks Davis/// \return The output stream. 66*b0d29bc4SBrooks Davistemplate< typename T1, typename T2 > 67*b0d29bc4SBrooks Davisstd::ostream& 68*b0d29bc4SBrooks Davisstd::operator<<(std::ostream& output, const std::pair< T1, T2 >& object) 69*b0d29bc4SBrooks Davis{ 70*b0d29bc4SBrooks Davis output << "pair(" << object.first << ", " << object.second << ")"; 71*b0d29bc4SBrooks Davis return output; 72*b0d29bc4SBrooks Davis} 73*b0d29bc4SBrooks Davis 74*b0d29bc4SBrooks Davis 75*b0d29bc4SBrooks Davis/// Injects the object into a stream. 76*b0d29bc4SBrooks Davis/// 77*b0d29bc4SBrooks Davis/// \param output The stream into which to inject the object. 78*b0d29bc4SBrooks Davis/// \param object The object to format. 79*b0d29bc4SBrooks Davis/// 80*b0d29bc4SBrooks Davis/// \return The output stream. 81*b0d29bc4SBrooks Davistemplate< typename T > 82*b0d29bc4SBrooks Davisstd::ostream& 83*b0d29bc4SBrooks Davisstd::operator<<(std::ostream& output, const std::shared_ptr< T > object) 84*b0d29bc4SBrooks Davis{ 85*b0d29bc4SBrooks Davis if (object.get() == NULL) { 86*b0d29bc4SBrooks Davis output << "<NULL>"; 87*b0d29bc4SBrooks Davis } else { 88*b0d29bc4SBrooks Davis output << *object; 89*b0d29bc4SBrooks Davis } 90*b0d29bc4SBrooks Davis return output; 91*b0d29bc4SBrooks Davis} 92*b0d29bc4SBrooks Davis 93*b0d29bc4SBrooks Davis 94*b0d29bc4SBrooks Davis/// Injects the object into a stream. 95*b0d29bc4SBrooks Davis/// 96*b0d29bc4SBrooks Davis/// \param output The stream into which to inject the object. 97*b0d29bc4SBrooks Davis/// \param object The object to format. 98*b0d29bc4SBrooks Davis/// 99*b0d29bc4SBrooks Davis/// \return The output stream. 100*b0d29bc4SBrooks Davistemplate< typename T > 101*b0d29bc4SBrooks Davisstd::ostream& 102*b0d29bc4SBrooks Davisstd::operator<<(std::ostream& output, const std::set< T >& object) 103*b0d29bc4SBrooks Davis{ 104*b0d29bc4SBrooks Davis output << "set("; 105*b0d29bc4SBrooks Davis typename std::set< T >::size_type counter = 0; 106*b0d29bc4SBrooks Davis for (typename std::set< T >::const_iterator iter = object.begin(); 107*b0d29bc4SBrooks Davis iter != object.end(); ++iter, ++counter) { 108*b0d29bc4SBrooks Davis if (counter != 0) 109*b0d29bc4SBrooks Davis output << ", "; 110*b0d29bc4SBrooks Davis output << (*iter); 111*b0d29bc4SBrooks Davis } 112*b0d29bc4SBrooks Davis output << ")"; 113*b0d29bc4SBrooks Davis return output; 114*b0d29bc4SBrooks Davis} 115*b0d29bc4SBrooks Davis 116*b0d29bc4SBrooks Davis 117*b0d29bc4SBrooks Davis/// Injects the object into a stream. 118*b0d29bc4SBrooks Davis/// 119*b0d29bc4SBrooks Davis/// \param output The stream into which to inject the object. 120*b0d29bc4SBrooks Davis/// \param object The object to format. 121*b0d29bc4SBrooks Davis/// 122*b0d29bc4SBrooks Davis/// \return The output stream. 123*b0d29bc4SBrooks Davistemplate< typename T > 124*b0d29bc4SBrooks Davisstd::ostream& 125*b0d29bc4SBrooks Davisstd::operator<<(std::ostream& output, const std::vector< T >& object) 126*b0d29bc4SBrooks Davis{ 127*b0d29bc4SBrooks Davis output << "["; 128*b0d29bc4SBrooks Davis for (typename std::vector< T >::size_type i = 0; i < object.size(); ++i) { 129*b0d29bc4SBrooks Davis if (i != 0) 130*b0d29bc4SBrooks Davis output << ", "; 131*b0d29bc4SBrooks Davis output << object[i]; 132*b0d29bc4SBrooks Davis } 133*b0d29bc4SBrooks Davis output << "]"; 134*b0d29bc4SBrooks Davis return output; 135*b0d29bc4SBrooks Davis} 136*b0d29bc4SBrooks Davis 137*b0d29bc4SBrooks Davis 138*b0d29bc4SBrooks Davis#endif // !defined(UTILS_FORMAT_CONTAINERS_IPP) 139