20 #ifndef GEOS_COMMON_LOGGER_HPP
21 #define GEOS_COMMON_LOGGER_HPP
24 #include "LvArray/src/Macros.hpp"
30 #if defined(GEOS_USE_MPI)
38 #define GEOS_LOG( ... ) LVARRAY_LOG( __VA_ARGS__ )
44 #define GEOS_LOG_VAR( ... ) LVARRAY_LOG_VAR( __VA_ARGS__ )
52 #if defined(GEOS_DEVICE_COMPILE)
53 #define GEOS_LOG_IF( EXP, msg )
55 #define GEOS_LOG_IF( EXP, msg ) \
59 std::cout<< msg << std::endl; \
70 #define GEOS_LOG_RANK_0_IF( EXP, msg ) \
72 if( ::geos::logger::internal::g_rank == 0 && EXP ) \
74 std::ostringstream oss; \
76 std::cout << oss.str() << std::endl; \
85 #define GEOS_LOG_RANK_0_IF_NLR( EXP, msg ) \
87 if( ::geos::logger::internal::g_rank == 0 && EXP ) \
89 std::ostringstream oss; \
91 std::cout << oss.str(); \
99 #define GEOS_LOG_RANK_0( msg ) GEOS_LOG_RANK_0_IF( true, msg )
106 #if defined(GEOS_DEVICE_COMPILE)
107 #define GEOS_LOG_RANK_IF( EXP, msg )
109 #define GEOS_LOG_RANK_IF( EXP, msg ) \
113 std::ostringstream oss; \
114 oss << "Rank " << ::geos::logger::internal::g_rankString << ": " << msg; \
115 *logger::internal::g_rankStream << oss.str() << std::endl; \
124 #define GEOS_LOG_RANK( msg ) GEOS_LOG_RANK_IF( true, msg )
130 #define GEOS_LOG_RANK_VAR( var ) GEOS_LOG_RANK( #var " = " << var )
137 #if !defined(GEOS_DEVICE_COMPILE) && !defined(GEOS_GLOBAL_LOGGER)
138 #define GEOS_GLOBAL_LOGGER ErrorLogger::global()
150 #if !defined(GEOS_DEVICE_COMPILE)
151 #define GEOS_ERROR_IF_CAUSE( COND, CAUSE_MESSAGE, ... ) \
156 std::ostringstream __msgoss; \
157 __msgoss << GEOS_DETAIL_FIRST_ARG( __VA_ARGS__ ); \
158 std::ostringstream __causemsgsoss; \
159 __causemsgsoss << CAUSE_MESSAGE; \
160 GEOS_GLOBAL_LOGGER.initCurrentExceptionMessage( MsgType::Error, __msgoss.str(), \
161 ::geos::logger::internal::g_rank ) \
162 .setCodeLocation( __FILE__, __LINE__ ) \
163 .setCause( __causemsgsoss.str() ) \
164 .addCallStackInfo( LvArray::system::stackTrace( true ) ) \
165 .addContextInfo( GEOS_DETAIL_REST_ARGS( __VA_ARGS__ )); \
166 GEOS_GLOBAL_LOGGER.flushCurrentExceptionMessage(); \
167 LvArray::system::callErrorHandler(); \
171 #define GEOS_ERROR_IF_CAUSE( COND, CAUSE_MESSAGE, ... ) \
176 constexpr char const * formatString = "***** ERROR\n" \
177 "***** LOCATION" LOCATION "\n" \
178 "***** BLOCK: [%u, %u, %u]\n" \
179 "***** THREAD: [%u, %u, %u]\n" \
180 "***** " STRINGIZE( CAUSE_MESSAGE ) "\n" \
181 "***** " STRINGIZE( GEOS_DETAIL_FIRST_ARG( __VA_ARGS__ ) ) "\n\n"; \
182 printf( formatString, blockIdx.x, blockIdx.y, blockIdx.z, threadIdx.x, threadIdx.y, threadIdx.z ); \
195 #define GEOS_ERROR_IF( COND, ... ) \
196 GEOS_ERROR_IF_CAUSE( COND, "Error cause: " STRINGIZE( COND ), __VA_ARGS__ )
204 #define GEOS_ERROR( ... ) GEOS_ERROR_IF_CAUSE( true, "", __VA_ARGS__ )
215 #if !defined(GEOS_DEVICE_COMPILE)
216 #define GEOS_THROW_IF_CAUSE( COND, CAUSE_MESSAGE, MSG, ... ) \
221 std::ostringstream __msgoss; \
223 std::ostringstream __causemsgsoss; \
224 __causemsgsoss << CAUSE_MESSAGE; \
225 DiagnosticMsg exceptionMsg = GEOS_GLOBAL_LOGGER.initCurrentExceptionMessage( MsgType::Exception, __msgoss.str(), \
226 ::geos::logger::internal::g_rank ) \
227 .setCodeLocation( __FILE__, __LINE__ ) \
228 .setCause( __causemsgsoss.str() ) \
229 .addCallStackInfo( LvArray::system::stackTrace( true ) ) \
230 .addContextInfo( GEOS_DETAIL_REST_ARGS( __VA_ARGS__ )) \
231 .getDiagnosticMsg(); \
232 auto ex = GEOS_DETAIL_FIRST_ARG( __VA_ARGS__ )(); \
233 ex.prepareWhat( exceptionMsg ); \
238 #define GEOS_THROW_IF_CAUSE( COND, CAUSE_MESSAGE, MSG, ... ) \
243 static char const formatString[] = "***** ERROR\n" \
244 "***** LOCATION" LOCATION "\n" \
245 "***** BLOCK: [%u, %u, %u]\n" \
246 "***** THREAD: [%u, %u, %u]\n" \
247 "***** " STRINGIZE( CAUSE_MESSAGE ) "\n" \
248 "***** " STRINGIZE( GEOS_DETAIL_FIRST_ARG( __VA_ARGS__ ) ) "\n\n"; \
249 printf( formatString, blockIdx.x, blockIdx.y, blockIdx.z, threadIdx.x, threadIdx.y, threadIdx.z ); \
263 #define GEOS_THROW_IF( COND, MSG, ... ) \
264 GEOS_THROW_IF_CAUSE( COND, "Error cause: " STRINGIZE( COND ), MSG, __VA_ARGS__ )
273 #define GEOS_THROW( MSG, ... ) GEOS_THROW_IF_CAUSE( true, "", MSG, __VA_ARGS__ )
283 #if !defined(GEOS_DEVICE_COMPILE)
284 #define GEOS_WARNING_IF_CAUSE( COND, CAUSE_MESSAGE, ... ) \
289 std::ostringstream __msgoss; \
290 __msgoss << GEOS_DETAIL_FIRST_ARG( __VA_ARGS__ ); \
291 std::ostringstream __causemsgsoss; \
292 __causemsgsoss << CAUSE_MESSAGE; \
293 DiagnosticMsg __warningMsg; \
294 GEOS_GLOBAL_LOGGER.flushErrorMsg( DiagnosticMsgBuilder::init( __warningMsg, \
295 MsgType::Warning, __msgoss.str(), \
296 ::geos::logger::internal::g_rank ) \
297 .setCodeLocation( __FILE__, __LINE__ ) \
298 .setCause( __causemsgsoss.str() ) \
299 .addCallStackInfo( LvArray::system::stackTrace( true ) ) \
300 .addContextInfo( GEOS_DETAIL_REST_ARGS( __VA_ARGS__ )) \
301 .getDiagnosticMsg() ); \
305 #define GEOS_WARNING_IF_CAUSE( COND, CAUSE_MESSAGE, ... ) \
310 static char const formatString[] = "***** WARNING\n" \
311 "***** LOCATION" LOCATION "\n" \
312 "***** BLOCK: [%u, %u, %u]\n" \
313 "***** THREAD: [%u, %u, %u]\n" \
314 "***** " STRINGIZE( CAUSE_MESSAGE ) "\n" \
315 "***** " STRINGIZE( GEOS_DETAIL_FIRST_ARG( __VA_ARGS__ ) ) "\n\n"; \
316 printf( formatString, blockIdx.x, blockIdx.y, blockIdx.z, threadIdx.x, threadIdx.y, threadIdx.z ); \
329 #define GEOS_WARNING_IF( COND, ... ) \
330 GEOS_WARNING_IF_CAUSE( COND, "Warning cause: " STRINGIZE( COND ), __VA_ARGS__ )
338 #define GEOS_WARNING( ... ) GEOS_WARNING_IF_CAUSE( true, "", __VA_ARGS__ )
345 #define GEOS_INFO_IF( EXP, msg ) LVARRAY_INFO_IF( EXP, msg )
351 #define GEOS_INFO( msg ) LVARRAY_INFO( msg )
358 #define GEOS_ERROR_LHS_RHS_DECLS( lhs, rhs ) \
359 GEOS_MAYBE_UNUSED auto const lhsResult = (lhs); \
360 GEOS_MAYBE_UNUSED auto const rhsResult = (rhs)
372 #define GEOS_ERROR_IF_OP_MSG( lhs, OP, NOP, rhs, ... ) \
374 GEOS_ERROR_LHS_RHS_DECLS( lhs, rhs ); \
375 GEOS_ERROR_IF_CAUSE( lhsResult OP rhsResult, \
376 "Expected: " #lhs " " #NOP " " #rhs "\n* " #lhs " = " << lhsResult << "\n* " #rhs " = " << rhsResult << "\n", \
389 #define GEOS_ERROR_IF_EQ_MSG( lhs, rhs, ... ) GEOS_ERROR_IF_OP_MSG( lhs, ==, !=, rhs, __VA_ARGS__ )
396 #define GEOS_ERROR_IF_EQ( lhs, rhs ) GEOS_ERROR_IF_EQ_MSG( lhs, rhs, "" )
406 #define GEOS_ERROR_IF_NE_MSG( lhs, rhs, ... ) GEOS_ERROR_IF_OP_MSG( lhs, !=, ==, rhs, __VA_ARGS__ )
413 #define GEOS_ERROR_IF_NE( lhs, rhs ) GEOS_ERROR_IF_NE_MSG( lhs, rhs, "" )
423 #define GEOS_ERROR_IF_GT_MSG( lhs, rhs, ... ) GEOS_ERROR_IF_OP_MSG( lhs, >, <=, rhs, __VA_ARGS__ )
430 #define GEOS_ERROR_IF_GT( lhs, rhs ) GEOS_ERROR_IF_GT_MSG( lhs, rhs, "" )
440 #define GEOS_ERROR_IF_GE_MSG( lhs, rhs, ... ) GEOS_ERROR_IF_OP_MSG( lhs, >=, <, rhs, __VA_ARGS__ )
447 #define GEOS_ERROR_IF_GE( lhs, rhs ) GEOS_ERROR_IF_GE_MSG( lhs, rhs, "" )
457 #define GEOS_ERROR_IF_LT_MSG( lhs, rhs, ... ) GEOS_ERROR_IF_OP_MSG( lhs, <, >=, rhs, __VA_ARGS__ )
464 #define GEOS_ERROR_IF_LT( lhs, rhs ) GEOS_ERROR_IF_LT_MSG( lhs, rhs, "" )
474 #define GEOS_ERROR_IF_LE_MSG( lhs, rhs, ... ) GEOS_ERROR_IF_OP_MSG( lhs, <=, >, rhs, __VA_ARGS__ )
482 #define GEOS_ERROR_IF_LE( lhs, rhs ) GEOS_ERROR_IF_LE_MSG( lhs, rhs, "" )
494 #define GEOS_WARNING_IF_OP_MSG( lhs, OP, NOP, rhs, ... ) \
496 GEOS_ERROR_LHS_RHS_DECLS( lhs, rhs ); \
497 GEOS_WARNING_IF_CAUSE( lhsResult OP rhsResult, \
498 "Expected: " #lhs " " #NOP " " #rhs "\n* " #lhs " = " << lhsResult << "\n* " #rhs " = " << rhsResult << "\n", \
511 #define GEOS_WARNING_IF_EQ_MSG( lhs, rhs, ... ) GEOS_WARNING_IF_OP_MSG( lhs, ==, !=, rhs, __VA_ARGS__ )
518 #define GEOS_WARNING_IF_EQ( lhs, rhs ) GEOS_WARNING_IF_EQ_MSG( lhs, rhs, "" )
528 #define GEOS_WARNING_IF_NE_MSG( lhs, rhs, ... ) GEOS_WARNING_IF_OP_MSG( lhs, !=, ==, rhs, __VA_ARGS__ )
535 #define GEOS_WARNING_IF_NE( lhs, rhs ) GEOS_WARNING_IF_NE_MSG( lhs, rhs, "" )
545 #define GEOS_WARNING_IF_GT_MSG( lhs, rhs, ... ) GEOS_WARNING_IF_OP_MSG( lhs, >, <=, rhs, __VA_ARGS__ )
552 #define GEOS_WARNING_IF_GT( lhs, rhs ) GEOS_WARNING_IF_GT_MSG( lhs, rhs, "" )
562 #define GEOS_WARNING_IF_GE_MSG( lhs, rhs, ... ) GEOS_WARNING_IF_OP_MSG( lhs, >=, <, rhs, __VA_ARGS__ )
569 #define GEOS_WARNING_IF_GE( lhs, rhs ) GEOS_WARNING_IF_GE_MSG( lhs, rhs, "" )
579 #define GEOS_WARNING_IF_LT_MSG( lhs, rhs, ... ) GEOS_WARNING_IF_OP_MSG( lhs, <, >=, rhs, __VA_ARGS__ )
586 #define GEOS_WARNING_IF_LT( lhs, rhs ) GEOS_WARNING_IF_LT_MSG( lhs, rhs, "" )
596 #define GEOS_WARNING_IF_LE_MSG( lhs, rhs, ... ) GEOS_WARNING_IF_OP_MSG( lhs, <=, >, rhs, __VA_ARGS__ )
603 #define GEOS_WARNING_IF_LE( lhs, rhs ) GEOS_WARNING_IF_LE_MSG( lhs, rhs, "" )
616 #define GEOS_THROW_IF_OP_MSG( lhs, OP, NOP, rhs, MSG, ... ) \
618 GEOS_ERROR_LHS_RHS_DECLS( lhs, rhs ); \
619 GEOS_THROW_IF_CAUSE( lhsResult OP rhsResult, \
620 "Expected: " #lhs " " #NOP " " #rhs "\n* " #lhs " = " << lhsResult << "\n* " #rhs " = " << rhsResult << "\n", \
621 MSG, __VA_ARGS__ ); \
635 #define GEOS_THROW_IF_EQ_MSG( lhs, rhs, MSG, ... ) GEOS_THROW_IF_OP_MSG( lhs, ==, !=, rhs, MSG, __VA_ARGS__ )
645 #define GEOS_THROW_IF_EQ( lhs, rhs, ... ) GEOS_THROW_IF_EQ_MSG( lhs, rhs, "", __VA_ARGS__ )
656 #define GEOS_THROW_IF_NE_MSG( lhs, rhs, MSG, ... ) GEOS_THROW_IF_OP_MSG( lhs, !=, ==, rhs, MSG, __VA_ARGS__ )
666 #define GEOS_THROW_IF_NE( lhs, rhs, ... ) GEOS_THROW_IF_NE_MSG( lhs, rhs, "", __VA_ARGS__ )
677 #define GEOS_THROW_IF_GT_MSG( lhs, rhs, MSG, ... ) GEOS_THROW_IF_OP_MSG( lhs, >, <=, rhs, MSG, __VA_ARGS__ )
687 #define GEOS_THROW_IF_GT( lhs, rhs, ... ) GEOS_THROW_IF_GT_MSG( lhs, rhs, "", __VA_ARGS__ )
698 #define GEOS_THROW_IF_GE_MSG( lhs, rhs, MSG, ... ) GEOS_THROW_IF_OP_MSG( lhs, >=, <, rhs, MSG, __VA_ARGS__ )
708 #define GEOS_THROW_IF_GE( lhs, rhs, ... ) GEOS_THROW_IF_GE_MSG( lhs, rhs, "", __VA_ARGS__ )
719 #define GEOS_THROW_IF_LT_MSG( lhs, rhs, MSG, ... ) GEOS_THROW_IF_OP_MSG( lhs, <, >=, rhs, MSG, __VA_ARGS__ )
729 #define GEOS_THROW_IF_LT( lhs, rhs, ... ) GEOS_THROW_IF_LT_MSG( lhs, rhs, "", __VA_ARGS__ )
740 #define GEOS_THROW_IF_LE_MSG( lhs, rhs, MSG, ... ) GEOS_THROW_IF_OP_MSG( lhs, <=, >, rhs, MSG, __VA_ARGS__ )
750 #define GEOS_THROW_IF_LE( lhs, rhs, ... ) GEOS_THROW_IF_LE_MSG( lhs, rhs, "", __VA_ARGS__ )
752 #if !defined(NDEBUG) || defined(GEOS_ASSERT_ENABLED)
757 #define GEOS_ASSERT_ENABLED
771 #define GEOS_ASSERT_MSG( COND, ... ) \
772 GEOS_ERROR_IF_CAUSE( !( COND ), "Expected: " STRINGIZE( COND ), __VA_ARGS__ )
783 #define GEOS_ASSERT_OP_MSG( lhs, OP, rhs, ... ) \
785 GEOS_ERROR_LHS_RHS_DECLS( lhs, rhs ); \
786 GEOS_ERROR_IF_CAUSE( !( lhsResult OP rhsResult ), \
787 "Expected: " #lhs " " #OP " " #rhs "\n* " #lhs " = " << lhsResult << "\n* " #rhs " = " << rhsResult << "\n", \
793 #define GEOS_ASSERT_MSG( ... ) ((void) 0)
794 #define GEOS_ASSERT_OP_MSG( ... ) ((void) 0)
802 #define GEOS_ASSERT( COND ) GEOS_ASSERT_MSG( COND, "" )
812 #define GEOS_ASSERT_EQ_MSG( lhs, rhs, ... ) GEOS_ASSERT_OP_MSG( lhs, ==, rhs, __VA_ARGS__ )
819 #define GEOS_ASSERT_EQ( lhs, rhs ) GEOS_ASSERT_EQ_MSG( lhs, rhs, "" )
829 #define GEOS_ASSERT_NE_MSG( lhs, rhs, ... ) GEOS_ASSERT_OP_MSG( lhs, !=, rhs, __VA_ARGS__ )
836 #define GEOS_ASSERT_NE( lhs, rhs ) GEOS_ASSERT_NE_MSG( lhs, rhs, "" )
846 #define GEOS_ASSERT_GT_MSG( lhs, rhs, ... ) GEOS_ASSERT_OP_MSG( lhs, >, rhs, __VA_ARGS__ )
853 #define GEOS_ASSERT_GT( lhs, rhs ) GEOS_ASSERT_GT_MSG( lhs, rhs, "" )
863 #define GEOS_ASSERT_GE_MSG( lhs, rhs, ... ) GEOS_ASSERT_OP_MSG( lhs, >=, rhs, __VA_ARGS__ )
870 #define GEOS_ASSERT_GE( lhs, rhs ) GEOS_ASSERT_GE_MSG( lhs, rhs, "" )
880 #define GEOS_ASSERT_LT_MSG( lhs, rhs, ... ) GEOS_ASSERT_OP_MSG( lhs, <, rhs, __VA_ARGS__ )
887 #define GEOS_ASSERT_LT( lhs, rhs ) GEOS_ASSERT_LT_MSG( lhs, rhs, "" )
897 #define GEOS_ASSERT_LE_MSG( lhs, rhs, ... ) GEOS_ASSERT_OP_MSG( lhs, <=, rhs, __VA_ARGS__ )
904 #define GEOS_ASSERT_LE( lhs, rhs ) GEOS_ASSERT_LE_MSG( lhs, rhs, "" )
919 extern std::ostream * g_rankStream;
923 #if defined(GEOS_USE_MPI)
929 void InitializeLogger( MPI_Comm comm,
const std::string & rank_output_dir=
"" );
void FinalizeLogger()
Finalize the logger and close the rank streams.
void InitializeLogger(const std::string &rank_output_dir="")
Initialize the logger in a serial build.
std::string string
String type.