mirror of
https://github.com/hrydgard/ppsspp.git
synced 2025-03-02 19:16:56 +00:00
We don't really support different listeners per log type, so let's get rid of that fiction.
This commit is contained in:
parent
38fd8c62ec
commit
1ccca2ef33
@ -16,12 +16,14 @@
|
||||
// http://code.google.com/p/dolphin-emu/
|
||||
|
||||
#include <algorithm>
|
||||
|
||||
#include "base/logging.h"
|
||||
#include "util/text/utf8.h"
|
||||
#include "LogManager.h"
|
||||
#include "ConsoleListener.h"
|
||||
#include "Timer.h"
|
||||
#include "FileUtil.h"
|
||||
#include "StringUtils.h"
|
||||
#include "../Core/Config.h"
|
||||
|
||||
// Don't need to savestate this.
|
||||
@ -112,26 +114,27 @@ LogManager::LogManager() {
|
||||
|
||||
for (int i = 0; i < LogTypes::NUMBER_OF_LOGS; ++i) {
|
||||
log_[i]->SetEnable(true);
|
||||
#if !defined(MOBILE_DEVICE) || defined(_DEBUG)
|
||||
log_[i]->AddListener(fileLog_);
|
||||
log_[i]->AddListener(consoleLog_);
|
||||
#if defined(_MSC_VER) && defined(USING_WIN_UI)
|
||||
if (IsDebuggerPresent() && debuggerLog_ != NULL && LOG_MSC_OUTPUTDEBUG)
|
||||
log_[i]->AddListener(debuggerLog_);
|
||||
#endif
|
||||
log_[i]->AddListener(ringLog_);
|
||||
#endif
|
||||
}
|
||||
|
||||
#if !defined(MOBILE_DEVICE) || defined(_DEBUG)
|
||||
AddListener(fileLog_);
|
||||
AddListener(consoleLog_);
|
||||
#if defined(_MSC_VER) && defined(USING_WIN_UI)
|
||||
if (IsDebuggerPresent() && debuggerLog_ != NULL && LOG_MSC_OUTPUTDEBUG)
|
||||
AddListener(debuggerLog_);
|
||||
#endif
|
||||
AddListener(ringLog_);
|
||||
#endif
|
||||
}
|
||||
|
||||
LogManager::~LogManager() {
|
||||
for (int i = 0; i < LogTypes::NUMBER_OF_LOGS; ++i) {
|
||||
#if !defined(MOBILE_DEVICE) || defined(_DEBUG)
|
||||
if (fileLog_ != NULL)
|
||||
logManager_->RemoveListener((LogTypes::LOG_TYPE)i, fileLog_);
|
||||
logManager_->RemoveListener((LogTypes::LOG_TYPE)i, consoleLog_);
|
||||
RemoveListener(fileLog_);
|
||||
RemoveListener(consoleLog_);
|
||||
#if defined(_MSC_VER) && defined(USING_WIN_UI)
|
||||
logManager_->RemoveListener((LogTypes::LOG_TYPE)i, debuggerLog_);
|
||||
RemoveListener(debuggerLog_);
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
@ -149,15 +152,13 @@ LogManager::~LogManager() {
|
||||
|
||||
void LogManager::ChangeFileLog(const char *filename) {
|
||||
if (fileLog_ != NULL) {
|
||||
for (int i = 0; i < LogTypes::NUMBER_OF_LOGS; ++i)
|
||||
logManager_->RemoveListener((LogTypes::LOG_TYPE)i, fileLog_);
|
||||
RemoveListener(fileLog_);
|
||||
delete fileLog_;
|
||||
}
|
||||
|
||||
if (filename != NULL) {
|
||||
fileLog_ = new FileLogListener(filename);
|
||||
for (int i = 0; i < LogTypes::NUMBER_OF_LOGS; ++i)
|
||||
log_[i]->AddListener(fileLog_);
|
||||
AddListener(fileLog_);
|
||||
}
|
||||
}
|
||||
|
||||
@ -181,7 +182,7 @@ void LogManager::LoadConfig(IniFile::Section *section, bool debugDefaults) {
|
||||
|
||||
void LogManager::Log(LogTypes::LOG_LEVELS level, LogTypes::LOG_TYPE type, const char *file, int line, const char *format, va_list args) {
|
||||
LogChannel *log = log_[type];
|
||||
if (level > log->GetLevel() || !log->IsEnabled() || !log->HasListeners())
|
||||
if (level > log->GetLevel() || !log->IsEnabled())
|
||||
return;
|
||||
|
||||
std::lock_guard<std::mutex> lk(log_lock_);
|
||||
@ -231,12 +232,13 @@ void LogManager::Log(LogTypes::LOG_LEVELS level, LogTypes::LOG_TYPE type, const
|
||||
msgPos[neededBytes] = '\n';
|
||||
msgPos[neededBytes + 1] = '\0';
|
||||
}
|
||||
log->Trigger(level, msg);
|
||||
|
||||
Trigger(level, msg);
|
||||
}
|
||||
|
||||
bool LogManager::IsEnabled(LogTypes::LOG_LEVELS level, LogTypes::LOG_TYPE type) {
|
||||
LogChannel *log = log_[type];
|
||||
if (level > log->GetLevel() || !log->IsEnabled() || !log->HasListeners())
|
||||
if (level > log->GetLevel() || !log->IsEnabled())
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
@ -251,8 +253,8 @@ void LogManager::Shutdown() {
|
||||
}
|
||||
|
||||
LogChannel::LogChannel(const char* shortName)
|
||||
: enable_(false), m_hasListeners(false) {
|
||||
strncpy(m_shortName, shortName, 32);
|
||||
: enable_(false) {
|
||||
truncate_cpy(m_shortName, shortName);
|
||||
#if defined(_DEBUG)
|
||||
level_ = LogTypes::LDEBUG;
|
||||
#else
|
||||
@ -261,19 +263,19 @@ LogChannel::LogChannel(const char* shortName)
|
||||
}
|
||||
|
||||
// LogContainer
|
||||
void LogChannel::AddListener(LogListener *listener) {
|
||||
void LogManager::AddListener(LogListener *listener) {
|
||||
std::lock_guard<std::mutex> lk(m_listeners_lock);
|
||||
m_listeners.insert(listener);
|
||||
m_hasListeners = true;
|
||||
}
|
||||
|
||||
void LogChannel::RemoveListener(LogListener *listener) {
|
||||
void LogManager::RemoveListener(LogListener *listener) {
|
||||
std::lock_guard<std::mutex> lk(m_listeners_lock);
|
||||
m_listeners.erase(listener);
|
||||
m_hasListeners = !m_listeners.empty();
|
||||
}
|
||||
|
||||
void LogChannel::Trigger(LogTypes::LOG_LEVELS level, const char *msg) {
|
||||
void LogManager::Trigger(LogTypes::LOG_LEVELS level, const char *msg) {
|
||||
std::lock_guard<std::mutex> lk(m_listeners_lock);
|
||||
|
||||
std::set<LogListener*>::const_iterator i;
|
||||
|
@ -91,18 +91,12 @@ public:
|
||||
|
||||
const char* GetShortName() const { return m_shortName; }
|
||||
|
||||
void AddListener(LogListener* listener);
|
||||
void RemoveListener(LogListener* listener);
|
||||
|
||||
void Trigger(LogTypes::LOG_LEVELS, const char *msg);
|
||||
|
||||
bool IsEnabled() const { return enable_; }
|
||||
void SetEnable(bool enable) { enable_ = enable; }
|
||||
|
||||
LogTypes::LOG_LEVELS GetLevel() const { return (LogTypes::LOG_LEVELS)level_; }
|
||||
|
||||
void SetLevel(LogTypes::LOG_LEVELS level) { level_ = level; }
|
||||
bool HasListeners() const { return m_hasListeners; }
|
||||
|
||||
// Although not elegant, easy to set with a PopupMultiChoice...
|
||||
int level_;
|
||||
@ -110,27 +104,14 @@ public:
|
||||
|
||||
private:
|
||||
char m_shortName[32];
|
||||
std::mutex m_listeners_lock;
|
||||
std::set<LogListener*> m_listeners;
|
||||
bool m_hasListeners;
|
||||
};
|
||||
|
||||
class ConsoleListener;
|
||||
|
||||
class LogManager : NonCopyable {
|
||||
private:
|
||||
LogChannel* log_[LogTypes::NUMBER_OF_LOGS];
|
||||
FileLogListener *fileLog_;
|
||||
ConsoleListener *consoleLog_;
|
||||
DebuggerLogListener *debuggerLog_;
|
||||
RingbufferLogListener *ringLog_;
|
||||
static LogManager *logManager_; // Singleton. Ugh.
|
||||
std::mutex log_lock_;
|
||||
|
||||
LogManager();
|
||||
~LogManager();
|
||||
|
||||
public:
|
||||
void AddListener(LogListener* listener);
|
||||
void RemoveListener(LogListener* listener);
|
||||
|
||||
static u32 GetMaxLevel() { return MAX_LOGLEVEL; }
|
||||
static int GetNumChannels() { return LogTypes::NUMBER_OF_LOGS; }
|
||||
@ -161,14 +142,6 @@ public:
|
||||
return log_[type]->GetLevel();
|
||||
}
|
||||
|
||||
void AddListener(LogTypes::LOG_TYPE type, LogListener *listener) {
|
||||
log_[type]->AddListener(listener);
|
||||
}
|
||||
|
||||
void RemoveListener(LogTypes::LOG_TYPE type, LogListener *listener) {
|
||||
log_[type]->RemoveListener(listener);
|
||||
}
|
||||
|
||||
ConsoleListener *GetConsoleListener() const {
|
||||
return consoleLog_;
|
||||
}
|
||||
@ -196,4 +169,22 @@ public:
|
||||
|
||||
void SaveConfig(IniFile::Section *section);
|
||||
void LoadConfig(IniFile::Section *section, bool debugDefaults);
|
||||
|
||||
private:
|
||||
void Trigger(LogTypes::LOG_LEVELS, const char *msg);
|
||||
|
||||
LogChannel* log_[LogTypes::NUMBER_OF_LOGS];
|
||||
FileLogListener *fileLog_;
|
||||
ConsoleListener *consoleLog_;
|
||||
DebuggerLogListener *debuggerLog_;
|
||||
RingbufferLogListener *ringLog_;
|
||||
static LogManager *logManager_; // Singleton. Ugh.
|
||||
std::mutex log_lock_;
|
||||
|
||||
std::mutex m_listeners_lock;
|
||||
std::set<LogListener*> m_listeners;
|
||||
bool m_hasListeners;
|
||||
|
||||
LogManager();
|
||||
~LogManager();
|
||||
};
|
||||
|
@ -301,8 +301,8 @@ int main(int argc, const char* argv[])
|
||||
LogTypes::LOG_TYPE type = (LogTypes::LOG_TYPE)i;
|
||||
logman->SetEnable(type, fullLog);
|
||||
logman->SetLogLevel(type, LogTypes::LDEBUG);
|
||||
logman->AddListener(type, printfLogger);
|
||||
}
|
||||
logman->AddListener(printfLogger);
|
||||
|
||||
CoreParameter coreParameter;
|
||||
coreParameter.cpuCore = cpuCore;
|
||||
|
Loading…
x
Reference in New Issue
Block a user