From 94bb4b41c559751896cd7ed602bebdd5b9c0a3d3 Mon Sep 17 00:00:00 2001 From: Rushfan Date: Wed, 9 Oct 2024 20:47:08 -0700 Subject: [PATCH] LOG errors from wwivbasic to log file and caller --- bbs/basic/basic.cpp | 27 ++++++++++++++------------- bbs/basic/wwiv_data.cpp | 1 + 2 files changed, 15 insertions(+), 13 deletions(-) diff --git a/bbs/basic/basic.cpp b/bbs/basic/basic.cpp index e6844c861..afaaa1712 100644 --- a/bbs/basic/basic.cpp +++ b/bbs/basic/basic.cpp @@ -34,6 +34,7 @@ #include "core/strings.h" #include "core/textfile.h" #include "deps/my_basic/core/my_basic.h" +#include "fmt/format.h" #include "sdk/config.h" #include @@ -126,22 +127,22 @@ static void _on_error(struct mb_interpreter_t* s, mb_error_e err, const char* ms return; } + std::string errmsg; if (!func) { - printf("Error:\n Line %d, Col %d\n Code %d, Abort Code %d\n Message: %s.\n", row, col, - err, err == SE_EA_EXTENDED_ABORT ? abort_code - MB_EXTENDED_ABORT : abort_code, msg); - return; - } - - if (err == SE_RN_REACHED_TO_WRONG_FUNCTION) { - printf( + errmsg = fmt::sprintf("Error:\n Line %d, Col %d\n Code %d, Abort Code %d\n Message: %s.\n", row, col, + static_cast(err), err == SE_EA_EXTENDED_ABORT ? abort_code - MB_EXTENDED_ABORT : abort_code, msg); + } else if (err == SE_RN_REACHED_TO_WRONG_FUNCTION) { + errmsg = fmt::sprintf( "Error:\n Line %d, Col %d in Func: %s\n Code %d, Abort Code %d\n Message: %s.\n", - row, col, func, err, abort_code, msg); - return; + row, col, func, static_cast(err), abort_code, msg); + } else { + errmsg = fmt::sprintf( + "Error:\n Line %d, Col %d in File: %s\n Code %d, Abort Code %d\n Message: %s.\n", + row, col, func, static_cast(err), err == SE_EA_EXTENDED_ABORT ? abort_code - MB_EXTENDED_ABORT : abort_code, + msg); } - printf( - "Error:\n Line %d, Col %d in File: %s\n Code %d, Abort Code %d\n Message: %s.\n", - row, col, func, err, err == SE_EA_EXTENDED_ABORT ? abort_code - MB_EXTENDED_ABORT : abort_code, - msg); + bout.pl(StrCat("|#6", errmsg)); + LOG(ERROR) << errmsg; } Basic::Basic(common::Input& i, common::Output& o, const sdk::Config& config, common::Context* ctx) diff --git a/bbs/basic/wwiv_data.cpp b/bbs/basic/wwiv_data.cpp index 1cbb0e38b..0ccc94e68 100644 --- a/bbs/basic/wwiv_data.cpp +++ b/bbs/basic/wwiv_data.cpp @@ -24,6 +24,7 @@ #include "core/log.h" #include "core/strings.h" #include "core/cereal_utils.h" +#include "fmt/format.h" #include #include #include