2016-02-12 19:42:20 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Edward d'Auvergne
|
|
|
|
*
|
|
|
|
* This file is part of the program FlightGear.
|
|
|
|
*
|
|
|
|
* 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, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2019-07-31 10:35:23 +02:00
|
|
|
#include <iomanip>
|
|
|
|
|
2016-02-12 19:42:20 +01:00
|
|
|
#include "logging.hxx"
|
|
|
|
|
2020-09-08 11:37:13 +01:00
|
|
|
#include <simgear/debug/logstream.hxx>
|
2018-06-07 22:29:23 +02:00
|
|
|
#include <simgear/debug/OsgIoCapture.hxx>
|
|
|
|
|
2016-02-12 19:42:20 +01:00
|
|
|
|
|
|
|
// The global stream capture data structure.
|
|
|
|
static capturedIO *_iostreams = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
// capturedIO constructor.
|
2019-07-31 10:35:23 +02:00
|
|
|
capturedIO::capturedIO(sgDebugClass c, sgDebugPriority p)
|
2016-02-12 19:42:20 +01:00
|
|
|
{
|
2019-07-31 10:35:23 +02:00
|
|
|
callback_interleaved = new StreamLogCallback(sg_interleaved, c, p, false);
|
|
|
|
callback_bulk_only = new StreamLogCallback(sg_bulk_only, c, SG_BULK, true);
|
|
|
|
callback_debug_only = new StreamLogCallback(sg_debug_only, c, SG_DEBUG, true);
|
|
|
|
callback_info_only = new StreamLogCallback(sg_info_only, c, SG_INFO, true);
|
|
|
|
callback_warn_only = new StreamLogCallback(sg_warn_only, c, SG_WARN, true);
|
|
|
|
callback_alert_only = new StreamLogCallback(sg_alert_only, c, SG_ALERT, true);
|
|
|
|
|
|
|
|
// Store the class as a string.
|
|
|
|
if (c == SG_ALL)
|
|
|
|
log_class = "SG_ALL";
|
|
|
|
else {
|
|
|
|
std::stringstream stream;
|
|
|
|
stream << "0x" << std::right << std::setfill('0') << std::setw(8) << std::hex << c;
|
|
|
|
log_class = stream.str();
|
|
|
|
}
|
|
|
|
|
2019-07-30 13:19:23 +02:00
|
|
|
// Store the priority as a string.
|
|
|
|
if (p == SG_BULK)
|
|
|
|
log_priority = "SG_BULK";
|
|
|
|
else if (p == SG_DEBUG)
|
|
|
|
log_priority = "SG_DEBUG";
|
|
|
|
else if (p == SG_INFO)
|
|
|
|
log_priority = "SG_INFO";
|
|
|
|
else if (p == SG_WARN)
|
|
|
|
log_priority = "SG_WARN";
|
|
|
|
else if (p == SG_ALERT)
|
|
|
|
log_priority = "SG_ALERT";
|
|
|
|
else if (p == SG_POPUP)
|
|
|
|
log_priority = "SG_POPUP";
|
|
|
|
else if (p == SG_DEV_WARN)
|
|
|
|
log_priority = "SG_DEV_WARN";
|
|
|
|
else if (p == SG_DEV_ALERT)
|
|
|
|
log_priority = "SG_DEV_ALERT";
|
2016-02-12 19:42:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// capturedIO destructor.
|
|
|
|
capturedIO::~capturedIO()
|
|
|
|
{
|
|
|
|
// Destroy the callback objects.
|
2019-07-30 13:19:23 +02:00
|
|
|
delete callback_interleaved;
|
2016-02-12 19:42:20 +01:00
|
|
|
delete callback_bulk_only;
|
|
|
|
delete callback_debug_only;
|
|
|
|
delete callback_info_only;
|
|
|
|
delete callback_warn_only;
|
|
|
|
delete callback_alert_only;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Return the global stream capture data structure, creating it if needed.
|
2019-07-31 10:35:23 +02:00
|
|
|
capturedIO & getIOstreams(sgDebugClass c, sgDebugPriority p)
|
2016-02-12 19:42:20 +01:00
|
|
|
{
|
|
|
|
// Initialise the global stream capture data structure, if needed.
|
|
|
|
if (!_iostreams)
|
2019-07-31 10:35:23 +02:00
|
|
|
_iostreams = new capturedIO(c, p);
|
2016-02-12 19:42:20 +01:00
|
|
|
|
|
|
|
// Return a pointer to the global object.
|
|
|
|
return *_iostreams;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Set up to capture all the simgear logging priorities as separate streams.
|
2019-07-31 10:35:23 +02:00
|
|
|
void setupLogging(sgDebugClass c, sgDebugPriority p, bool split)
|
2016-02-12 19:42:20 +01:00
|
|
|
{
|
|
|
|
// Get the single logstream instance.
|
|
|
|
logstream &log = sglog();
|
|
|
|
|
|
|
|
// Set up the logstream testing mode.
|
|
|
|
log.setTestingMode(true);
|
|
|
|
|
2018-06-07 22:29:23 +02:00
|
|
|
// OSG IO capture.
|
|
|
|
osg::setNotifyHandler(new NotifyLogger);
|
|
|
|
|
2016-02-12 19:42:20 +01:00
|
|
|
// IO capture.
|
2019-07-31 10:35:23 +02:00
|
|
|
capturedIO &obj = getIOstreams(c, p);
|
2019-07-30 14:54:45 +02:00
|
|
|
if (!split)
|
|
|
|
log.addCallback(obj.callback_interleaved);
|
|
|
|
else {
|
|
|
|
if (p <= SG_BULK)
|
|
|
|
log.addCallback(obj.callback_bulk_only);
|
|
|
|
if (p <= SG_DEBUG)
|
|
|
|
log.addCallback(obj.callback_debug_only);
|
|
|
|
if (p <= SG_INFO)
|
|
|
|
log.addCallback(obj.callback_info_only);
|
|
|
|
if (p <= SG_WARN)
|
|
|
|
log.addCallback(obj.callback_warn_only);
|
|
|
|
if (p <= SG_ALERT)
|
|
|
|
log.addCallback(obj.callback_alert_only);
|
|
|
|
}
|
2016-02-12 19:42:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Deactivate all the simgear logging priority IO captures.
|
|
|
|
void stopLogging()
|
|
|
|
{
|
|
|
|
// Get the single logstream instance.
|
|
|
|
logstream &log = sglog();
|
|
|
|
|
|
|
|
// IO decapture.
|
|
|
|
capturedIO &obj = getIOstreams();
|
2019-07-30 13:19:23 +02:00
|
|
|
log.removeCallback(obj.callback_interleaved);
|
2016-02-12 19:42:20 +01:00
|
|
|
log.removeCallback(obj.callback_bulk_only);
|
|
|
|
log.removeCallback(obj.callback_debug_only);
|
|
|
|
log.removeCallback(obj.callback_info_only);
|
|
|
|
log.removeCallback(obj.callback_warn_only);
|
|
|
|
log.removeCallback(obj.callback_alert_only);
|
|
|
|
|
|
|
|
// Clean up the IO stream object.
|
|
|
|
delete _iostreams;
|
|
|
|
_iostreams = NULL;
|
|
|
|
|
|
|
|
// Stop the simgear logstream.
|
|
|
|
simgear::shutdownLogging();
|
|
|
|
}
|