2018-02-03 18:22:01 -08:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
|
|
|
// Copyright (C) 2016-2018 Jason Volk <jason@zemos.net>
|
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
2016-07-25 19:06:31 -07:00
|
|
|
|
2018-01-10 21:32:32 -08:00
|
|
|
[[noreturn]] static void
|
|
|
|
ircd_terminate_handler()
|
|
|
|
noexcept
|
|
|
|
{
|
|
|
|
std::abort();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ircd::aborting()
|
|
|
|
noexcept
|
|
|
|
{
|
|
|
|
std::set_terminate(&ircd_terminate_handler);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ircd::throw_system_error(const int &code)
|
|
|
|
{
|
|
|
|
throw std::system_error(code, std::system_category());
|
|
|
|
}
|
|
|
|
|
|
|
|
std::exception_ptr
|
|
|
|
ircd::make_system_error(const int &code)
|
|
|
|
{
|
|
|
|
return std::make_exception_ptr(std::system_error(code, std::system_category()));
|
|
|
|
}
|
|
|
|
|
2016-08-14 19:03:25 -07:00
|
|
|
ssize_t
|
2017-03-17 17:37:40 -07:00
|
|
|
ircd::exception::generate(const char *const &fmt,
|
|
|
|
const va_rtti &ap)
|
2016-07-25 19:06:31 -07:00
|
|
|
noexcept
|
|
|
|
{
|
2017-03-17 17:37:40 -07:00
|
|
|
return fmt::vsnprintf(buf, sizeof(buf), fmt, ap);
|
2016-08-14 19:03:25 -07:00
|
|
|
}
|
2016-07-25 19:06:31 -07:00
|
|
|
|
2016-08-14 19:03:25 -07:00
|
|
|
ssize_t
|
2017-03-17 17:37:40 -07:00
|
|
|
ircd::exception::generate(const char *const &name,
|
|
|
|
const char *const &fmt,
|
|
|
|
const va_rtti &ap)
|
2016-08-14 19:03:25 -07:00
|
|
|
noexcept
|
|
|
|
{
|
2016-07-25 19:06:31 -07:00
|
|
|
size_t size(0);
|
|
|
|
const bool empty(!fmt || !fmt[0] || fmt[0] == ' ');
|
2016-11-29 07:23:38 -08:00
|
|
|
size = strlcat(buf, name, sizeof(buf));
|
|
|
|
size = strlcat(buf, empty? "." : ": ", sizeof(buf));
|
2016-07-25 19:06:31 -07:00
|
|
|
if(size < sizeof(buf))
|
2017-03-17 17:37:40 -07:00
|
|
|
size += fmt::vsnprintf(buf + size, sizeof(buf) - size, fmt, ap);
|
2016-07-25 19:06:31 -07:00
|
|
|
|
2016-08-14 19:03:25 -07:00
|
|
|
return size;
|
2016-07-25 19:06:31 -07:00
|
|
|
}
|
2017-11-25 17:20:42 -07:00
|
|
|
|
2018-01-08 13:26:29 -08:00
|
|
|
void
|
|
|
|
ircd::assertion()
|
2018-01-26 21:49:41 -08:00
|
|
|
noexcept(RB_DEBUG_LEVEL)
|
2018-01-08 13:26:29 -08:00
|
|
|
{
|
|
|
|
if(std::uncaught_exceptions())
|
|
|
|
{
|
|
|
|
assertion(std::current_exception());
|
|
|
|
} else {
|
|
|
|
log::critical("IRCd Assertion without active exception.");
|
|
|
|
assert(0);
|
|
|
|
throw assertive{};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ircd::assertion(std::exception_ptr eptr)
|
2018-01-26 21:49:41 -08:00
|
|
|
noexcept(RB_DEBUG_LEVEL) try
|
2018-01-08 13:26:29 -08:00
|
|
|
{
|
|
|
|
std::rethrow_exception(eptr);
|
|
|
|
}
|
|
|
|
catch(const std::exception &e)
|
|
|
|
{
|
|
|
|
assertion(e);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ircd::assertion(const std::exception &e)
|
2018-01-26 21:49:41 -08:00
|
|
|
noexcept(RB_DEBUG_LEVEL)
|
2018-01-08 13:26:29 -08:00
|
|
|
{
|
|
|
|
#ifdef RB_DEBUG
|
|
|
|
terminate(e);
|
|
|
|
#else
|
2018-01-23 20:58:33 -08:00
|
|
|
log::critical("IRCd Assertion %s", e.what());
|
2018-01-08 13:26:29 -08:00
|
|
|
throw e;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2017-11-25 17:20:42 -07:00
|
|
|
void
|
|
|
|
ircd::terminate()
|
|
|
|
noexcept
|
|
|
|
{
|
|
|
|
terminate(std::current_exception());
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ircd::terminate(std::exception_ptr eptr)
|
|
|
|
noexcept
|
|
|
|
{
|
|
|
|
if(eptr) try
|
|
|
|
{
|
|
|
|
std::rethrow_exception(eptr);
|
|
|
|
}
|
|
|
|
catch(const std::exception &e)
|
|
|
|
{
|
|
|
|
terminate(e);
|
|
|
|
}
|
|
|
|
|
|
|
|
log::critical("IRCd Terminate without exception");
|
|
|
|
std::terminate();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ircd::terminate(const std::exception &e)
|
|
|
|
noexcept
|
|
|
|
{
|
|
|
|
log::critical("IRCd Terminated: %s", e.what());
|
2018-01-08 13:26:29 -08:00
|
|
|
throw e;
|
2017-11-25 17:20:42 -07:00
|
|
|
}
|