c846ee0d1b
The former was deprecated in C++14. The Standard says they are the same: The contents of the header<cstdarg>are the same as the C standard library header<stdarg.h>, with the following changes: The restrictions that ISO C places on the second parameter to the va_start macro in header<stdarg.h> are different in this International Standard. The parameter parmN is the rightmost parameter in the variable parameter list of the function definition (the one just before the...).219If the parameter parmN is a pack expansion (17.5.3) or an entity resulting from a lambda capture (8.1.5), the program is ill-formed, no diagnostic required. If the parameter parmN is of a reference type, or of a type that is not compatible with the type that results when passing an argument for which there is no parameter, the behavior is undefined. Also changed va_list to the std:: namespace version, which is the same. Signed-off-by: Rosen Penev <rosenp@gmail.com>
183 lines
3.9 KiB
C++
183 lines
3.9 KiB
C++
/*
|
|
* Copyright 2003-2020 The Music Player Daemon Project
|
|
* http://www.musicpd.org
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
|
|
#include "LogV.hxx"
|
|
#include "util/Domain.hxx"
|
|
#include "util/Exception.hxx"
|
|
|
|
#include <cerrno>
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
static constexpr Domain exception_domain("exception");
|
|
|
|
void
|
|
LogFormatV(LogLevel level, const Domain &domain,
|
|
const char *fmt, std::va_list ap) noexcept
|
|
{
|
|
char msg[1024];
|
|
vsnprintf(msg, sizeof(msg), fmt, ap);
|
|
Log(level, domain, msg);
|
|
}
|
|
|
|
void
|
|
LogFormat(LogLevel level, const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
LogFormatV(level, domain, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
FormatDebug(const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
LogFormatV(LogLevel::DEBUG, domain, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
FormatInfo(const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
LogFormatV(LogLevel::INFO, domain, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
FormatDefault(const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
LogFormatV(LogLevel::DEFAULT, domain, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
FormatWarning(const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
LogFormatV(LogLevel::WARNING, domain, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
FormatError(const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
LogFormatV(LogLevel::ERROR, domain, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
Log(LogLevel level, const std::exception &e) noexcept
|
|
{
|
|
Log(level, exception_domain, GetFullMessage(e).c_str());
|
|
}
|
|
|
|
void
|
|
Log(LogLevel level, const std::exception &e, const char *msg) noexcept
|
|
{
|
|
LogFormat(level, exception_domain, "%s: %s", msg, GetFullMessage(e).c_str());
|
|
}
|
|
|
|
void
|
|
LogFormat(LogLevel level, const std::exception &e, const char *fmt, ...) noexcept
|
|
{
|
|
char msg[1024];
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
vsnprintf(msg, sizeof(msg), fmt, ap);
|
|
va_end(ap);
|
|
|
|
Log(level, e, msg);
|
|
}
|
|
|
|
void
|
|
Log(LogLevel level, const std::exception_ptr &ep) noexcept
|
|
{
|
|
Log(level, exception_domain, GetFullMessage(ep).c_str());
|
|
}
|
|
|
|
void
|
|
Log(LogLevel level, const std::exception_ptr &ep, const char *msg) noexcept
|
|
{
|
|
LogFormat(level, exception_domain, "%s: %s", msg,
|
|
GetFullMessage(ep).c_str());
|
|
}
|
|
|
|
void
|
|
LogFormat(LogLevel level, const std::exception_ptr &ep, const char *fmt, ...) noexcept
|
|
{
|
|
char msg[1024];
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
vsnprintf(msg, sizeof(msg), fmt, ap);
|
|
va_end(ap);
|
|
|
|
Log(level, ep, msg);
|
|
}
|
|
|
|
void
|
|
LogErrno(const Domain &domain, int e, const char *msg) noexcept
|
|
{
|
|
LogFormat(LogLevel::ERROR, domain, "%s: %s", msg, strerror(e));
|
|
}
|
|
|
|
void
|
|
LogErrno(const Domain &domain, const char *msg) noexcept
|
|
{
|
|
LogErrno(domain, errno, msg);
|
|
}
|
|
|
|
static void
|
|
FormatErrnoV(const Domain &domain, int e, const char *fmt, std::va_list ap) noexcept
|
|
{
|
|
char msg[1024];
|
|
vsnprintf(msg, sizeof(msg), fmt, ap);
|
|
|
|
LogErrno(domain, e, msg);
|
|
}
|
|
|
|
void
|
|
FormatErrno(const Domain &domain, int e, const char *fmt, ...) noexcept
|
|
{
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
FormatErrnoV(domain, e, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void
|
|
FormatErrno(const Domain &domain, const char *fmt, ...) noexcept
|
|
{
|
|
const int e = errno;
|
|
|
|
std::va_list ap;
|
|
va_start(ap, fmt);
|
|
FormatErrnoV(domain, e, fmt, ap);
|
|
va_end(ap);
|
|
}
|