| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 | // (C) Copyright 2013,2015 Vicente J. Botet Escriba// 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)#ifndef BOOST_THREAD_CALL_CONTEXT_HPP#define BOOST_THREAD_CALL_CONTEXT_HPP#include <boost/thread/detail/config.hpp>#if defined BOOST_THREAD_USES_LOG_THREAD_ID#include <boost/thread/thread.hpp>#endif#include <boost/current_function.hpp>#include <boost/io/ios_state.hpp>#include <iomanip>#include <boost/config/abi_prefix.hpp>namespace boost{  struct caller_context_t  {    const char * filename;    unsigned lineno;    const char * func;    caller_context_t(const char * filename, unsigned lineno, const char * func) :      filename(filename), lineno(lineno), func(func)    {    }  };#define BOOST_CONTEXTOF boost::caller_context_t(__FILE__, __LINE__, BOOST_CURRENT_FUNCTION)  template <typename OStream>  OStream& operator<<(OStream& os, caller_context_t const& ctx)  {#if defined BOOST_THREAD_USES_LOG_THREAD_ID    {      io::ios_flags_saver ifs( os );      os << std::left << std::setw(14) << boost::this_thread::get_id() << " ";    }#endif    {      io::ios_flags_saver ifs(os);      os << std::setw(50) << ctx.filename << "["         << std::setw(4) << std::right << std::dec<< ctx.lineno << "] ";#if defined BOOST_THREAD_USES_LOG_CURRENT_FUNCTION      os << ctx.func << " " ;#endif    }    return os;  }}#include <boost/config/abi_suffix.hpp>#endif // header
 |