#200 Use fprintf failback when fail to use uv_tty.

This commit is contained in:
XMRig 2017-11-18 14:07:04 +03:00
parent 1961dcf824
commit 989c217b3f
2 changed files with 11 additions and 9 deletions

View file

@ -76,6 +76,7 @@ public:
inline int retryPause() const { return m_retryPause; } inline int retryPause() const { return m_retryPause; }
inline int threads() const { return m_threads; } inline int threads() const { return m_threads; }
inline int64_t affinity() const { return m_affinity; } inline int64_t affinity() const { return m_affinity; }
inline void setColors(bool colors) { m_colors = colors; }
inline static void release() { delete m_self; } inline static void release() { delete m_self; }

View file

@ -36,6 +36,7 @@
#include "log/ConsoleLog.h" #include "log/ConsoleLog.h"
#include "log/Log.h" #include "log/Log.h"
#include "Options.h"
ConsoleLog::ConsoleLog(bool colors) : ConsoleLog::ConsoleLog(bool colors) :
@ -43,6 +44,8 @@ ConsoleLog::ConsoleLog(bool colors) :
m_stream(nullptr) m_stream(nullptr)
{ {
if (uv_tty_init(uv_default_loop(), &m_tty, 1, 0) < 0) { if (uv_tty_init(uv_default_loop(), &m_tty, 1, 0) < 0) {
Options::i()->setColors(false);
m_colors = false;
return; return;
} }
@ -65,10 +68,6 @@ ConsoleLog::ConsoleLog(bool colors) :
void ConsoleLog::message(int level, const char* fmt, va_list args) void ConsoleLog::message(int level, const char* fmt, va_list args)
{ {
if (!isWritable()) {
return;
}
time_t now = time(nullptr); time_t now = time(nullptr);
tm stime; tm stime;
@ -121,10 +120,6 @@ void ConsoleLog::message(int level, const char* fmt, va_list args)
void ConsoleLog::text(const char* fmt, va_list args) void ConsoleLog::text(const char* fmt, va_list args)
{ {
if (!isWritable()) {
return;
}
snprintf(m_fmt, sizeof(m_fmt) - 1, "%s%s\n", fmt, m_colors ? Log::kCL_N : ""); snprintf(m_fmt, sizeof(m_fmt) - 1, "%s%s\n", fmt, m_colors ? Log::kCL_N : "");
print(args); print(args);
@ -149,5 +144,11 @@ void ConsoleLog::print(va_list args)
return; return;
} }
if (!isWritable()) {
fprintf(stdout, m_buf);
fflush(stdout);
}
else {
uv_try_write(m_stream, &m_uvBuf, 1); uv_try_write(m_stream, &m_uvBuf, 1);
} }
}