관리-도구
편집 파일: caller_context.hpp
// (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