fputs("\n", stream);
}
-void lognotice(char const *fmt, ...) {
+void lognotice(char const *fmt, ...) noexcept {
va_list a;
va_start(a, fmt);
log_("notice", stdout, fmt, a);
va_end(a);
}
-void logerror(char const *fmt, ...) {
+void logerror(char const *fmt, ...) noexcept {
va_list a;
va_start(a, fmt);
log_("error", stderr, fmt, a);
va_end(a);
}
-void fatal(char const *fmt, ...) {
+void fatal(char const *fmt, ...) noexcept {
va_list a;
va_start(a, fmt);
log_("fatal", stderr, fmt, a);
}
#ifdef DEBUG_OUTPUT
-void logdebug(char const *fmt, ...) {
+void logdebug(char const *fmt, ...) noexcept {
va_list a;
va_start(a, fmt);
log_("debug", stdout, fmt, a);
#ifdef __GNUC__
#define ATTR_FORMAT(stringindex, firsttocheck) \
__attribute__((format(printf, stringindex, firsttocheck)))
+#define ATTR_NORETURN __attribute__((noreturn))
#else
#define ATTR_FORMAT(stringindex, firsttocheck)
+#define ATTR_NORETURN
#endif
-void lognotice(char const *fmt, ...) ATTR_FORMAT(1, 2);
-void logerror(char const *fmt, ...) ATTR_FORMAT(1, 2);
-void fatal(char const *fmt, ...) ATTR_FORMAT(1, 2);
+void lognotice(char const *fmt, ...) noexcept ATTR_FORMAT(1, 2);
+void logerror(char const *fmt, ...) noexcept ATTR_FORMAT(1, 2);
+void fatal(char const *fmt, ...) noexcept ATTR_FORMAT(1, 2) ATTR_NORETURN;
#ifdef DEBUG_OUTPUT
-void logdebug(char const *fmt, ...) ATTR_FORMAT(1, 2);
+void logdebug(char const *fmt, ...) noexcept ATTR_FORMAT(1, 2);
#else
-static inline void logdebug(char const *fmt, ...) ATTR_FORMAT(1, 2);
-static inline void logdebug(char const *fmt, ...) {}
+static inline void logdebug(char const *fmt, ...) noexcept ATTR_FORMAT(1, 2);
+static inline void logdebug(char const *fmt, ...) noexcept {}
#endif
// _ _ _ __ _