mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-10 10:52:31 -05:00
util: Move error message formatting of NonFatalCheckError to cpp
This allows to strip down the header file
This commit is contained in:
parent
547a963628
commit
2222ec71fd
3 changed files with 22 additions and 16 deletions
|
@ -59,6 +59,7 @@ if [ "${RUN_TIDY}" = "true" ]; then
|
||||||
" src/threadinterrupt.cpp"\
|
" src/threadinterrupt.cpp"\
|
||||||
" src/util/bip32.cpp"\
|
" src/util/bip32.cpp"\
|
||||||
" src/util/bytevectorhash.cpp"\
|
" src/util/bytevectorhash.cpp"\
|
||||||
|
" src/util/check.cpp"\
|
||||||
" src/util/error.cpp"\
|
" src/util/error.cpp"\
|
||||||
" src/util/getuniquepath.cpp"\
|
" src/util/getuniquepath.cpp"\
|
||||||
" src/util/hasher.cpp"\
|
" src/util/hasher.cpp"\
|
||||||
|
|
|
@ -4,8 +4,23 @@
|
||||||
|
|
||||||
#include <util/check.h>
|
#include <util/check.h>
|
||||||
|
|
||||||
|
#if defined(HAVE_CONFIG_H)
|
||||||
|
#include <config/bitcoin-config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <tinyformat.h>
|
#include <tinyformat.h>
|
||||||
|
|
||||||
|
#include <cstdio>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
|
||||||
|
NonFatalCheckError::NonFatalCheckError(const char* msg, const char* file, int line, const char* func)
|
||||||
|
: std::runtime_error{
|
||||||
|
strprintf("Internal bug detected: \"%s\"\n%s:%d (%s)\nPlease report this issue here: %s\n", msg, file, line, func, PACKAGE_BUGREPORT)}
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
void assertion_fail(const char* file, int line, const char* func, const char* assertion)
|
void assertion_fail(const char* file, int line, const char* func, const char* assertion)
|
||||||
{
|
{
|
||||||
auto str = strprintf("%s:%s %s: Assertion `%s' failed.\n", file, line, func, assertion);
|
auto str = strprintf("%s:%s %s: Assertion `%s' failed.\n", file, line, func, assertion);
|
||||||
|
|
|
@ -5,31 +5,23 @@
|
||||||
#ifndef BITCOIN_UTIL_CHECK_H
|
#ifndef BITCOIN_UTIL_CHECK_H
|
||||||
#define BITCOIN_UTIL_CHECK_H
|
#define BITCOIN_UTIL_CHECK_H
|
||||||
|
|
||||||
#if defined(HAVE_CONFIG_H)
|
|
||||||
#include <config/bitcoin-config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <attributes.h>
|
#include <attributes.h>
|
||||||
#include <tinyformat.h>
|
|
||||||
|
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
class NonFatalCheckError : public std::runtime_error
|
class NonFatalCheckError : public std::runtime_error
|
||||||
{
|
{
|
||||||
using std::runtime_error::runtime_error;
|
public:
|
||||||
|
NonFatalCheckError(const char* msg, const char* file, int line, const char* func);
|
||||||
};
|
};
|
||||||
|
|
||||||
#define format_internal_error(msg, file, line, func, report) \
|
|
||||||
strprintf("Internal bug detected: \"%s\"\n%s:%d (%s)\nPlease report this issue here: %s\n", \
|
|
||||||
msg, file, line, func, report)
|
|
||||||
|
|
||||||
/** Helper for CHECK_NONFATAL() */
|
/** Helper for CHECK_NONFATAL() */
|
||||||
template <typename T>
|
template <typename T>
|
||||||
T&& inline_check_non_fatal(LIFETIMEBOUND T&& val, const char* file, int line, const char* func, const char* assertion)
|
T&& inline_check_non_fatal(LIFETIMEBOUND T&& val, const char* file, int line, const char* func, const char* assertion)
|
||||||
{
|
{
|
||||||
if (!(val)) {
|
if (!val) {
|
||||||
throw NonFatalCheckError(
|
throw NonFatalCheckError{assertion, file, line, func};
|
||||||
format_internal_error(assertion, file, line, func, PACKAGE_BUGREPORT));
|
|
||||||
}
|
}
|
||||||
return std::forward<T>(val);
|
return std::forward<T>(val);
|
||||||
}
|
}
|
||||||
|
@ -88,11 +80,9 @@ T&& inline_assertion_check(LIFETIMEBOUND T&& val, [[maybe_unused]] const char* f
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* NONFATAL_UNREACHABLE() is a macro that is used to mark unreachable code. It throws a NonFatalCheckError.
|
* NONFATAL_UNREACHABLE() is a macro that is used to mark unreachable code. It throws a NonFatalCheckError.
|
||||||
* This is used to mark code that is not yet implemented or is not yet reachable.
|
|
||||||
*/
|
*/
|
||||||
#define NONFATAL_UNREACHABLE() \
|
#define NONFATAL_UNREACHABLE() \
|
||||||
throw NonFatalCheckError( \
|
throw NonFatalCheckError( \
|
||||||
format_internal_error("Unreachable code reached (non-fatal)", \
|
"Unreachable code reached (non-fatal)", __FILE__, __LINE__, __func__)
|
||||||
__FILE__, __LINE__, __func__, PACKAGE_BUGREPORT))
|
|
||||||
|
|
||||||
#endif // BITCOIN_UTIL_CHECK_H
|
#endif // BITCOIN_UTIL_CHECK_H
|
||||||
|
|
Loading…
Add table
Reference in a new issue