forked from boostorg/assert
Enable BOOST_CURRENT_LOCATION at top level and in default arguments
This commit is contained in:
@ -9,10 +9,12 @@
|
|||||||
|
|
||||||
#include <boost/current_function.hpp>
|
#include <boost/current_function.hpp>
|
||||||
#include <boost/config.hpp>
|
#include <boost/config.hpp>
|
||||||
|
#include <boost/config/workaround.hpp>
|
||||||
#include <boost/cstdint.hpp>
|
#include <boost/cstdint.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
#if defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L
|
#if defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L
|
||||||
# include <source_location>
|
# include <source_location>
|
||||||
@ -75,7 +77,9 @@ public:
|
|||||||
|
|
||||||
std::string to_string() const
|
std::string to_string() const
|
||||||
{
|
{
|
||||||
if( line() == 0 )
|
unsigned long ln = line();
|
||||||
|
|
||||||
|
if( ln == 0 )
|
||||||
{
|
{
|
||||||
return "(unknown source location)";
|
return "(unknown source location)";
|
||||||
}
|
}
|
||||||
@ -84,18 +88,25 @@ public:
|
|||||||
|
|
||||||
char buffer[ 16 ];
|
char buffer[ 16 ];
|
||||||
|
|
||||||
std::sprintf( buffer, ":%lu", static_cast<unsigned long>( line() ) );
|
std::sprintf( buffer, ":%lu", ln );
|
||||||
r += buffer;
|
r += buffer;
|
||||||
|
|
||||||
if( column() )
|
unsigned long co = column();
|
||||||
|
|
||||||
|
if( co )
|
||||||
{
|
{
|
||||||
std::sprintf( buffer, ":%lu", static_cast<unsigned long>( column() ) );
|
std::sprintf( buffer, ":%lu", co );
|
||||||
r += buffer;
|
r += buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
r += " in function '";
|
char const* fn = function_name();
|
||||||
r += function_name();
|
|
||||||
r += '\'';
|
if( *fn != 0 )
|
||||||
|
{
|
||||||
|
r += " in function '";
|
||||||
|
r += fn;
|
||||||
|
r += '\'';
|
||||||
|
}
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
@ -112,25 +123,42 @@ template<class E, class T> std::basic_ostream<E, T> & operator<<( std::basic_ost
|
|||||||
return os;
|
return os;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace detail
|
||||||
|
{
|
||||||
|
|
||||||
|
inline char const* srcloc_strip_top_level( char const* fn )
|
||||||
|
{
|
||||||
|
return std::strcmp( fn, "top level" ) == 0? "": fn;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#if defined( BOOST_DISABLE_CURRENT_LOCATION )
|
#if defined( BOOST_DISABLE_CURRENT_LOCATION )
|
||||||
|
|
||||||
# define BOOST_CURRENT_LOCATION ::boost::source_location()
|
# define BOOST_CURRENT_LOCATION ::boost::source_location()
|
||||||
|
|
||||||
#elif defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L
|
#elif defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L && !BOOST_WORKAROUND(BOOST_MSVC, < 1931)
|
||||||
|
|
||||||
# define BOOST_CURRENT_LOCATION ::boost::source_location(std::source_location::current())
|
# define BOOST_CURRENT_LOCATION ::boost::source_location(::std::source_location::current())
|
||||||
|
|
||||||
#elif defined(__clang_analyzer__)
|
#elif defined(BOOST_DISABLE_CURRENT_FUNCTION) || defined(__clang_analyzer__) // https://bugs.llvm.org/show_bug.cgi?id=28480
|
||||||
|
|
||||||
// Cast to char const* to placate clang-tidy
|
# define BOOST_CURRENT_LOCATION ::boost::source_location(__FILE__, __LINE__, "")
|
||||||
// https://bugs.llvm.org/show_bug.cgi?id=28480
|
|
||||||
# define BOOST_CURRENT_LOCATION ::boost::source_location(__FILE__, __LINE__, static_cast<char const*>(BOOST_CURRENT_FUNCTION))
|
#elif defined(__GNUC__)
|
||||||
|
|
||||||
|
# define BOOST_CURRENT_LOCATION ::boost::source_location(__FILE__, __LINE__, ::boost::detail::srcloc_strip_top_level(__PRETTY_FUNCTION__))
|
||||||
|
|
||||||
|
# if defined(__clang__)
|
||||||
|
//# pragma clang diagnostic ignored "-W"
|
||||||
|
# endif
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
# define BOOST_CURRENT_LOCATION ::boost::source_location(__FILE__, __LINE__, BOOST_CURRENT_FUNCTION)
|
// __func__ macros aren't allowed outside functions, but BOOST_CURRENT_LOCATION is
|
||||||
|
# define BOOST_CURRENT_LOCATION ::boost::source_location(__FILE__, __LINE__, "")
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -40,3 +40,4 @@ run current_function_test2.cpp ;
|
|||||||
run source_location_test.cpp ;
|
run source_location_test.cpp ;
|
||||||
run source_location_test2.cpp ;
|
run source_location_test2.cpp ;
|
||||||
run source_location_test3.cpp ;
|
run source_location_test3.cpp ;
|
||||||
|
run source_location_test4.cpp ;
|
||||||
|
@ -17,17 +17,28 @@ int main()
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
boost::source_location loc( __FILE__, __LINE__, "main" );
|
||||||
|
|
||||||
BOOST_TEST_CSTR_EQ( loc.file_name(), __FILE__ );
|
BOOST_TEST_CSTR_EQ( loc.file_name(), __FILE__ );
|
||||||
BOOST_TEST_EQ( loc.line(), 20 );
|
BOOST_TEST_EQ( loc.line(), 20 );
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.function_name(), "main" );
|
||||||
#if !( defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L )
|
|
||||||
|
|
||||||
BOOST_TEST_CSTR_EQ( loc.function_name(), BOOST_CURRENT_FUNCTION );
|
|
||||||
BOOST_TEST_EQ( loc.column(), 0 );
|
BOOST_TEST_EQ( loc.column(), 0 );
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
{
|
||||||
|
boost::source_location loc( "file", 1, "main", 2 );
|
||||||
|
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.file_name(), "file" );
|
||||||
|
BOOST_TEST_EQ( loc.line(), 1 );
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.function_name(), "main" );
|
||||||
|
BOOST_TEST_EQ( loc.column(), 2 );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
||||||
|
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.file_name(), __FILE__ );
|
||||||
|
BOOST_TEST_EQ( loc.line(), 38 );
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L
|
#if defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L
|
||||||
|
@ -23,34 +23,66 @@ int main()
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
boost::source_location loc( __FILE__, __LINE__, BOOST_CURRENT_FUNCTION );
|
boost::source_location loc( "file", 5, "" );
|
||||||
BOOST_TEST_EQ( loc.to_string(), std::string( __FILE__ ) + ":26 in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
BOOST_TEST_EQ( loc.to_string(), std::string( "file:5" ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
boost::source_location loc( __FILE__, __LINE__, BOOST_CURRENT_FUNCTION );
|
boost::source_location loc( "file", 5, "" );
|
||||||
|
|
||||||
std::ostringstream os;
|
std::ostringstream os;
|
||||||
os << loc;
|
os << loc;
|
||||||
|
|
||||||
BOOST_TEST_EQ( os.str(), std::string( __FILE__ ) + ":31 in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
BOOST_TEST_EQ( os.str(), std::string( "file:5" ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc( "file", 7, "main" );
|
||||||
|
BOOST_TEST_EQ( loc.to_string(), std::string( "file:7 in function 'main'" ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc( "file", 7, "main" );
|
||||||
|
|
||||||
|
std::ostringstream os;
|
||||||
|
os << loc;
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( os.str(), std::string( "file:7 in function 'main'" ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc( "file", 11, "main", 13 );
|
||||||
|
BOOST_TEST_EQ( loc.to_string(), std::string( "file:11:13 in function 'main'" ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc( "file", 11, "main", 13 );
|
||||||
|
|
||||||
|
std::ostringstream os;
|
||||||
|
os << loc;
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( os.str(), std::string( "file:11:13 in function 'main'" ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc( "file", 17, "", 19 );
|
||||||
|
BOOST_TEST_EQ( loc.to_string(), std::string( "file:17:19" ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc( "file", 17, "", 19 );
|
||||||
|
|
||||||
|
std::ostringstream os;
|
||||||
|
os << loc;
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( os.str(), std::string( "file:17:19" ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
boost::source_location loc = BOOST_CURRENT_LOCATION;
|
||||||
|
|
||||||
std::string prefix = std::string( __FILE__ ) + ":40";
|
std::string prefix = std::string( __FILE__ ) + ":82";
|
||||||
|
|
||||||
#if !( defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L )
|
|
||||||
|
|
||||||
BOOST_TEST_EQ( loc.to_string(), prefix + " in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
// column and function vary when coming from std::source_location::current()
|
|
||||||
BOOST_TEST_EQ( loc.to_string().substr( 0, prefix.size() ), prefix );
|
BOOST_TEST_EQ( loc.to_string().substr( 0, prefix.size() ), prefix );
|
||||||
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -59,18 +91,8 @@ int main()
|
|||||||
std::ostringstream os;
|
std::ostringstream os;
|
||||||
os << loc;
|
os << loc;
|
||||||
|
|
||||||
std::string prefix = std::string( __FILE__ ) + ":57";
|
std::string prefix = std::string( __FILE__ ) + ":89";
|
||||||
|
|
||||||
#if !( defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L )
|
|
||||||
|
|
||||||
BOOST_TEST_EQ( os.str(), prefix + " in function '" + BOOST_CURRENT_FUNCTION + "'" );
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
// column and function vary when coming from std::source_location::current()
|
|
||||||
BOOST_TEST_EQ( os.str().substr( 0, prefix.size() ), prefix );
|
BOOST_TEST_EQ( os.str().substr( 0, prefix.size() ), prefix );
|
||||||
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return boost::report_errors();
|
return boost::report_errors();
|
||||||
|
42
test/source_location_test4.cpp
Normal file
42
test/source_location_test4.cpp
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
// Copyright 2022 Peter Dimov
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// http://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/assert/source_location.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
boost::source_location s_loc = BOOST_CURRENT_LOCATION;
|
||||||
|
|
||||||
|
boost::source_location f( boost::source_location const& loc = BOOST_CURRENT_LOCATION )
|
||||||
|
{
|
||||||
|
return loc;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
BOOST_TEST_CSTR_EQ( s_loc.file_name(), __FILE__ );
|
||||||
|
BOOST_TEST_EQ( s_loc.line(), 8 );
|
||||||
|
BOOST_TEST_CSTR_EQ( s_loc.function_name(), "" );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
boost::source_location loc = f();
|
||||||
|
|
||||||
|
#if defined(__cpp_lib_source_location) && __cpp_lib_source_location >= 201907L && !BOOST_WORKAROUND(BOOST_MSVC, < 1931)
|
||||||
|
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.file_name(), std::source_location::current().file_name() );
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.function_name(), std::source_location::current().function_name() );
|
||||||
|
BOOST_TEST_EQ( loc.line(), 24 );
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.file_name(), __FILE__ );
|
||||||
|
BOOST_TEST_EQ( loc.line(), 10 );
|
||||||
|
BOOST_TEST_CSTR_EQ( loc.function_name(), "" );
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
Reference in New Issue
Block a user