|
Packit |
18d29c |
// This file is automatically generated from src/glog/stl_logging.h.in
|
|
Packit |
18d29c |
// using src/windows/preprocess.sh.
|
|
Packit |
18d29c |
// DO NOT EDIT!
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
// Copyright (c) 2003, Google Inc.
|
|
Packit |
18d29c |
// All rights reserved.
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// Redistribution and use in source and binary forms, with or without
|
|
Packit |
18d29c |
// modification, are permitted provided that the following conditions are
|
|
Packit |
18d29c |
// met:
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// * Redistributions of source code must retain the above copyright
|
|
Packit |
18d29c |
// notice, this list of conditions and the following disclaimer.
|
|
Packit |
18d29c |
// * Redistributions in binary form must reproduce the above
|
|
Packit |
18d29c |
// copyright notice, this list of conditions and the following disclaimer
|
|
Packit |
18d29c |
// in the documentation and/or other materials provided with the
|
|
Packit |
18d29c |
// distribution.
|
|
Packit |
18d29c |
// * Neither the name of Google Inc. nor the names of its
|
|
Packit |
18d29c |
// contributors may be used to endorse or promote products derived from
|
|
Packit |
18d29c |
// this software without specific prior written permission.
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
Packit |
18d29c |
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
Packit |
18d29c |
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
Packit |
18d29c |
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
Packit |
18d29c |
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
Packit |
18d29c |
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
Packit |
18d29c |
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
Packit |
18d29c |
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
Packit |
18d29c |
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
Packit |
18d29c |
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
Packit |
18d29c |
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// Stream output operators for STL containers; to be used for logging *only*.
|
|
Packit |
18d29c |
// Inclusion of this file lets you do:
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// list<string> x;
|
|
Packit |
18d29c |
// LOG(INFO) << "data: " << x;
|
|
Packit |
18d29c |
// vector<int> v1, v2;
|
|
Packit |
18d29c |
// CHECK_EQ(v1, v2);
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// If you want to use this header file with hash_compare maps or slist, you
|
|
Packit |
18d29c |
// need to define macros before including this file:
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// - GLOG_STL_LOGGING_FOR_UNORDERED - <unordered_map> and <unordered_set>
|
|
Packit |
18d29c |
// - GLOG_STL_LOGGING_FOR_TR1_UNORDERED - <tr1/unordered_(map|set)>
|
|
Packit |
18d29c |
// - GLOG_STL_LOGGING_FOR_EXT_HASH - <ext/hash_(map|set)>
|
|
Packit |
18d29c |
// - GLOG_STL_LOGGING_FOR_EXT_SLIST - <ext/slist>
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#ifndef UTIL_GTL_STL_LOGGING_INL_H_
|
|
Packit |
18d29c |
#define UTIL_GTL_STL_LOGGING_INL_H_
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#if !1
|
|
Packit |
18d29c |
# error We do not support stl_logging for this compiler
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#include <deque>
|
|
Packit |
18d29c |
#include <list>
|
|
Packit |
18d29c |
#include <map>
|
|
Packit |
18d29c |
#include <ostream>
|
|
Packit |
18d29c |
#include <set>
|
|
Packit |
18d29c |
#include <utility>
|
|
Packit |
18d29c |
#include <vector>
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_UNORDERED
|
|
Packit |
18d29c |
# include <unordered_map>
|
|
Packit |
18d29c |
# include <unordered_set>
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_TR1_UNORDERED
|
|
Packit |
18d29c |
# include <tr1/unordered_map>
|
|
Packit |
18d29c |
# include <tr1/unordered_set>
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_EXT_HASH
|
|
Packit |
18d29c |
# include <ext/hash_set>
|
|
Packit |
18d29c |
# include <ext/hash_map>
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_EXT_SLIST
|
|
Packit |
18d29c |
# include <ext/slist>
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
// Forward declare these two, and define them after all the container streams
|
|
Packit |
18d29c |
// operators so that we can recurse from pair -> container -> container -> pair
|
|
Packit |
18d29c |
// properly.
|
|
Packit |
18d29c |
template<class First, class Second>
|
|
Packit |
18d29c |
std::ostream& operator<<(std::ostream& out, const std::pair<First, Second>& p);
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
namespace google {
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
template<class Iter>
|
|
Packit |
18d29c |
void PrintSequence(std::ostream& out, Iter begin, Iter end);
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#define OUTPUT_TWO_ARG_CONTAINER(Sequence) \
|
|
Packit |
18d29c |
template<class T1, class T2> \
|
|
Packit |
18d29c |
inline std::ostream& operator<<(std::ostream& out, \
|
|
Packit |
18d29c |
const Sequence<T1, T2>& seq) { \
|
|
Packit |
18d29c |
google::PrintSequence(out, seq.begin(), seq.end()); \
|
|
Packit |
18d29c |
return out; \
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
OUTPUT_TWO_ARG_CONTAINER(std::vector)
|
|
Packit |
18d29c |
OUTPUT_TWO_ARG_CONTAINER(std::deque)
|
|
Packit |
18d29c |
OUTPUT_TWO_ARG_CONTAINER(std::list)
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_EXT_SLIST
|
|
Packit |
18d29c |
OUTPUT_TWO_ARG_CONTAINER(__gnu_cxx::slist)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#undef OUTPUT_TWO_ARG_CONTAINER
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#define OUTPUT_THREE_ARG_CONTAINER(Sequence) \
|
|
Packit |
18d29c |
template<class T1, class T2, class T3> \
|
|
Packit |
18d29c |
inline std::ostream& operator<<(std::ostream& out, \
|
|
Packit |
18d29c |
const Sequence<T1, T2, T3>& seq) { \
|
|
Packit |
18d29c |
google::PrintSequence(out, seq.begin(), seq.end()); \
|
|
Packit |
18d29c |
return out; \
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
OUTPUT_THREE_ARG_CONTAINER(std::set)
|
|
Packit |
18d29c |
OUTPUT_THREE_ARG_CONTAINER(std::multiset)
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#undef OUTPUT_THREE_ARG_CONTAINER
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#define OUTPUT_FOUR_ARG_CONTAINER(Sequence) \
|
|
Packit |
18d29c |
template<class T1, class T2, class T3, class T4> \
|
|
Packit |
18d29c |
inline std::ostream& operator<<(std::ostream& out, \
|
|
Packit |
18d29c |
const Sequence<T1, T2, T3, T4>& seq) { \
|
|
Packit |
18d29c |
google::PrintSequence(out, seq.begin(), seq.end()); \
|
|
Packit |
18d29c |
return out; \
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(std::map)
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(std::multimap)
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_UNORDERED
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(std::unordered_set)
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(std::unordered_multiset)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_TR1_UNORDERED
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(std::tr1::unordered_set)
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(std::tr1::unordered_multiset)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_EXT_HASH
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(__gnu_cxx::hash_set)
|
|
Packit |
18d29c |
OUTPUT_FOUR_ARG_CONTAINER(__gnu_cxx::hash_multiset)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#undef OUTPUT_FOUR_ARG_CONTAINER
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#define OUTPUT_FIVE_ARG_CONTAINER(Sequence) \
|
|
Packit |
18d29c |
template<class T1, class T2, class T3, class T4, class T5> \
|
|
Packit |
18d29c |
inline std::ostream& operator<<(std::ostream& out, \
|
|
Packit |
18d29c |
const Sequence<T1, T2, T3, T4, T5>& seq) { \
|
|
Packit |
18d29c |
google::PrintSequence(out, seq.begin(), seq.end()); \
|
|
Packit |
18d29c |
return out; \
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_UNORDERED
|
|
Packit |
18d29c |
OUTPUT_FIVE_ARG_CONTAINER(std::unordered_map)
|
|
Packit |
18d29c |
OUTPUT_FIVE_ARG_CONTAINER(std::unordered_multimap)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_TR1_UNORDERED
|
|
Packit |
18d29c |
OUTPUT_FIVE_ARG_CONTAINER(std::tr1::unordered_map)
|
|
Packit |
18d29c |
OUTPUT_FIVE_ARG_CONTAINER(std::tr1::unordered_multimap)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
#ifdef GLOG_STL_LOGGING_FOR_EXT_HASH
|
|
Packit |
18d29c |
OUTPUT_FIVE_ARG_CONTAINER(__gnu_cxx::hash_map)
|
|
Packit |
18d29c |
OUTPUT_FIVE_ARG_CONTAINER(__gnu_cxx::hash_multimap)
|
|
Packit |
18d29c |
#endif
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#undef OUTPUT_FIVE_ARG_CONTAINER
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
template<class First, class Second>
|
|
Packit |
18d29c |
inline std::ostream& operator<<(std::ostream& out,
|
|
Packit |
18d29c |
const std::pair<First, Second>& p) {
|
|
Packit |
18d29c |
out << '(' << p.first << ", " << p.second << ')';
|
|
Packit |
18d29c |
return out;
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
namespace google {
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
template<class Iter>
|
|
Packit |
18d29c |
inline void PrintSequence(std::ostream& out, Iter begin, Iter end) {
|
|
Packit |
18d29c |
// Output at most 100 elements -- appropriate if used for logging.
|
|
Packit |
18d29c |
for (int i = 0; begin != end && i < 100; ++i, ++begin) {
|
|
Packit |
18d29c |
if (i > 0) out << ' ';
|
|
Packit |
18d29c |
out << *begin;
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
if (begin != end) {
|
|
Packit |
18d29c |
out << " ...";
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
}
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
// Note that this is technically undefined behavior! We are adding things into
|
|
Packit |
18d29c |
// the std namespace for a reason though -- we are providing new operations on
|
|
Packit |
18d29c |
// types which are themselves defined with this namespace. Without this, these
|
|
Packit |
18d29c |
// operator overloads cannot be found via ADL. If these definitions are not
|
|
Packit |
18d29c |
// found via ADL, they must be #included before they're used, which requires
|
|
Packit |
18d29c |
// this header to be included before apparently independent other headers.
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// For example, base/logging.h defines various template functions to implement
|
|
Packit |
18d29c |
// CHECK_EQ(x, y) and stream x and y into the log in the event the check fails.
|
|
Packit |
18d29c |
// It does so via the function template MakeCheckOpValueString:
|
|
Packit |
18d29c |
// template<class T>
|
|
Packit |
18d29c |
// void MakeCheckOpValueString(strstream* ss, const T& v) {
|
|
Packit |
18d29c |
// (*ss) << v;
|
|
Packit |
18d29c |
// }
|
|
Packit |
18d29c |
// Because 'glog/logging.h' is included before 'glog/stl_logging.h',
|
|
Packit |
18d29c |
// subsequent CHECK_EQ(v1, v2) for vector<...> typed variable v1 and v2 can only
|
|
Packit |
18d29c |
// find these operator definitions via ADL.
|
|
Packit |
18d29c |
//
|
|
Packit |
18d29c |
// Even this solution has problems -- it may pull unintended operators into the
|
|
Packit |
18d29c |
// namespace as well, allowing them to also be found via ADL, and creating code
|
|
Packit |
18d29c |
// that only works with a particular order of includes. Long term, we need to
|
|
Packit |
18d29c |
// move all of the *definitions* into namespace std, bet we need to ensure no
|
|
Packit |
18d29c |
// one references them first. This lets us take that step. We cannot define them
|
|
Packit |
18d29c |
// in both because that would create ambiguous overloads when both are found.
|
|
Packit |
18d29c |
namespace std { using ::operator<<; }
|
|
Packit |
18d29c |
|
|
Packit |
18d29c |
#endif // UTIL_GTL_STL_LOGGING_INL_H_
|