forked from boostorg/assert
Add source_location::to_string
This commit is contained in:
@ -1,16 +1,17 @@
|
|||||||
#ifndef BOOST_ASSERT_SOURCE_LOCATION_HPP_INCLUDED
|
#ifndef BOOST_ASSERT_SOURCE_LOCATION_HPP_INCLUDED
|
||||||
#define BOOST_ASSERT_SOURCE_LOCATION_HPP_INCLUDED
|
#define BOOST_ASSERT_SOURCE_LOCATION_HPP_INCLUDED
|
||||||
|
|
||||||
// http://www.boost.org/libs/assert
|
// http://www.boost.org/libs/assert
|
||||||
//
|
//
|
||||||
// Copyright 2019 Peter Dimov
|
// Copyright 2019, 2021 Peter Dimov
|
||||||
// Distributed under the Boost Software License, Version 1.0.
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
// http://www.boost.org/LICENSE_1_0.txt
|
// http://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
#include <boost/current_function.hpp>
|
#include <boost/current_function.hpp>
|
||||||
#include <boost/config.hpp>
|
#include <boost/config.hpp>
|
||||||
#include <boost/cstdint.hpp>
|
#include <boost/cstdint.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace boost
|
namespace boost
|
||||||
{
|
{
|
||||||
@ -53,28 +54,48 @@ public:
|
|||||||
{
|
{
|
||||||
return column_;
|
return column_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(BOOST_MSVC)
|
||||||
|
# pragma warning( push )
|
||||||
|
# pragma warning( disable: 4996 )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
std::string to_string() const
|
||||||
|
{
|
||||||
|
if( line() == 0 )
|
||||||
|
{
|
||||||
|
return "(unknown source location)";
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string r = file_name();
|
||||||
|
|
||||||
|
char buffer[ 16 ];
|
||||||
|
|
||||||
|
sprintf( buffer, ":%ld", static_cast<long>( line() ) );
|
||||||
|
r += buffer;
|
||||||
|
|
||||||
|
if( column() )
|
||||||
|
{
|
||||||
|
sprintf( buffer, ":%ld", static_cast<long>( column() ) );
|
||||||
|
r += buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
r += " in function '";
|
||||||
|
r += function_name();
|
||||||
|
r += '\'';
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(BOOST_MSVC)
|
||||||
|
# pragma warning( pop )
|
||||||
|
#endif
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
template<class E, class T> std::basic_ostream<E, T> & operator<<( std::basic_ostream<E, T> & os, source_location const & loc )
|
template<class E, class T> std::basic_ostream<E, T> & operator<<( std::basic_ostream<E, T> & os, source_location const & loc )
|
||||||
{
|
{
|
||||||
os.width( 0 );
|
os << loc.to_string();
|
||||||
|
|
||||||
if( loc.line() == 0 )
|
|
||||||
{
|
|
||||||
os << "(unknown source location)";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
os << loc.file_name() << ':' << loc.line();
|
|
||||||
|
|
||||||
if( loc.column() )
|
|
||||||
{
|
|
||||||
os << ':' << loc.column();
|
|
||||||
}
|
|
||||||
|
|
||||||
os << ": in function '" << loc.function_name() << '\'';
|
|
||||||
}
|
|
||||||
|
|
||||||
return os;
|
return os;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,6 +8,11 @@
|
|||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
|
{
|
||||||
|
boost::source_location loc;
|
||||||
|
BOOST_TEST_EQ( loc.to_string(), std::string( "(unknown source location)" ) );
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
boost::source_location loc;
|
boost::source_location loc;
|
||||||
|
|
||||||
@ -17,13 +22,18 @@ int main()
|
|||||||
BOOST_TEST_EQ( os.str(), std::string( "(unknown source location)" ) );
|
BOOST_TEST_EQ( os.str(), std::string( "(unknown source location)" ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
||||||
|
BOOST_TEST_EQ( loc.to_string(), std::string( __FILE__ ) + ":26 in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
||||||
|
|
||||||
std::ostringstream os;
|
std::ostringstream os;
|
||||||
os << loc;
|
os << loc;
|
||||||
|
|
||||||
BOOST_TEST_EQ( os.str(), std::string( __FILE__ ) + ":21: in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
BOOST_TEST_EQ( os.str(), std::string( __FILE__ ) + ":31 in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
||||||
}
|
}
|
||||||
|
|
||||||
return boost::report_errors();
|
return boost::report_errors();
|
||||||
|
Reference in New Issue
Block a user