opennx/mylog.cpp
2025-08-08 20:34:09 +02:00

96 lines
2.6 KiB
C++

// $Id: mylog.cpp 451 2010-01-27 12:24:56Z felfert $
//
// Copyright (C) 2006 The OpenNX Team
// Author: Fritz Elfert
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU Library 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 Library General Public
// License along with this program; if not, write to the
// Free Software Foundation, Inc.,
// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//
// ----------------------------------------------------------------------------
// headers
// ----------------------------------------------------------------------------
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "wx/wxprec.h"
#ifndef WX_PRECOMP
#include "wx/wx.h"
#endif
#include "mylog.h"
#ifdef HAVE_SYSLOG_H
#include <syslog.h>
#endif
// The following functions are replacing the regular
// debug- and trace logging functions of wxWidgets.
// Since those are available in debug builds only, we use
// our own framework here in order enable tracing even in
// releas builds.
void logit(const char *szString, time_t WXUNUSED(t))
{
#ifdef __WXMSW__
OutputDebugStringA(szString);
#else
# ifdef HAVE_SYSLOG_H
static bool initial = true;
if (initial) {
initial = false;
openlog("opennx", LOG_CONS|LOG_PID, LOG_USER);
}
syslog(LOG_DEBUG, "%s", szString);
# else
fprintf(stderr, "%s\n", szString);
fflush(stderr);
# endif
#endif
}
static void myVLogDebug(const wxChar *szFormat, va_list argptr)
{
wxString msg;
msg << wxString::FormatV(szFormat, argptr);
logit(msg.ToUTF8(), time(NULL));
}
void myLogDebug(const wxChar *szFormat, ...)
{
va_list argptr;
va_start(argptr, szFormat);
myVLogDebug(szFormat, argptr);
va_end(argptr);
}
static void myVLogTrace(const wxChar *mask, const wxChar *szFormat, va_list argptr)
{
if ((wxLog::IsAllowedTraceMask(mask)) || (wxLog::IsAllowedTraceMask(wxT("All")))) {
wxString msg;
msg << _T("(") << mask << _T(") ") << wxString::FormatV(szFormat, argptr);
logit(msg.ToUTF8(), time(NULL));
}
}
void myLogTrace(const wxChar *mask, const wxChar *szFormat, ...)
{
va_list argptr;
va_start(argptr, szFormat);
myVLogTrace(mask, szFormat, argptr);
va_end(argptr);
}