本文整理汇总了C++中Log::SendEvent方法的典型用法代码示例。如果您正苦于以下问题:C++ Log::SendEvent方法的具体用法?C++ Log::SendEvent怎么用?C++ Log::SendEvent使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Log
的用法示例。
在下文中一共展示了Log::SendEvent方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Write
void Log::Write(int msgLevel, const String& message)
{
assert(msgLevel >= LOG_DEBUG && msgLevel < LOG_NONE);
Log* instance = Subsystem<Log>();
if (!instance)
return;
// If not in the main thread, store message for later processing
if (!Thread::IsMainThread())
{
MutexLock lock(instance->logMutex);
instance->threadMessages.Push(StoredLogMessage(message, msgLevel, false));
return;
}
// Do not log if message level excluded or if currently sending a log event
if (instance->level > msgLevel || instance->inWrite)
return;
String formattedMessage = logLevelPrefixes[msgLevel];
formattedMessage += ": " + message;
instance->lastMessage = message;
if (instance->timeStamp)
formattedMessage = "[" + TimeStamp() + "] " + formattedMessage;
if (instance->quiet)
{
// If in quiet mode, still print the error message to the standard error stream
if (msgLevel == LOG_ERROR)
PrintUnicodeLine(formattedMessage, true);
}
else
PrintUnicodeLine(formattedMessage, msgLevel == LOG_ERROR);
if (instance->logFile)
{
instance->logFile->WriteLine(formattedMessage);
instance->logFile->Flush();
}
instance->inWrite = true;
LogMessageEvent& event = instance->logMessageEvent;
event.message = formattedMessage;
event.level = msgLevel;
instance->SendEvent(event);
instance->inWrite = false;
}
示例2: WriteRaw
void Log::WriteRaw(const String& message, bool error)
{
Log* instance = Subsystem<Log>();
if (!instance)
return;
// If not in the main thread, store message for later processing
if (!Thread::IsMainThread())
{
MutexLock lock(instance->logMutex);
instance->threadMessages.Push(StoredLogMessage(message, LOG_RAW, error));
return;
}
// Prevent recursion during log event
if (instance->inWrite)
return;
instance->lastMessage = message;
if (instance->quiet)
{
// If in quiet mode, still print the error message to the standard error stream
if (error)
PrintUnicode(message, true);
}
else
PrintUnicode(message, error);
if (instance->logFile)
{
instance->logFile->Write(message.CString(), message.Length());
instance->logFile->Flush();
}
instance->inWrite = true;
LogMessageEvent& event = instance->logMessageEvent;
event.message = message;
event.level = error ? LOG_ERROR : LOG_INFO;
instance->SendEvent(event);
instance->inWrite = false;
}