Update submodules
This commit is contained in:
parent
07f3f7ec30
commit
330626ab22
@ -10,8 +10,6 @@
|
|||||||
#include "mbedTLS++/CryptoKey.h"
|
#include "mbedTLS++/CryptoKey.h"
|
||||||
#include "../../src/Logger.h"
|
#include "../../src/Logger.h"
|
||||||
|
|
||||||
#include "fmt/printf.h"
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <direct.h> // For _mkdir()
|
#include <direct.h> // For _mkdir()
|
||||||
#endif
|
#endif
|
||||||
@ -284,12 +282,12 @@ void cConnection::Run(void)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cConnection::vLog(const char * a_Format, fmt::printf_args a_Args)
|
void cConnection::vLog(const char * a_Format, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
// Log to file:
|
// Log to file:
|
||||||
cCSLock Lock(m_CSLog);
|
cCSLock Lock(m_CSLog);
|
||||||
fmt::fprintf(m_LogFile, "[%5.3f] ", GetRelativeTime());
|
fmt::fprintf(m_LogFile, "[%5.3f] ", GetRelativeTime());
|
||||||
fmt::vfprintf(m_LogFile, a_Format, a_Args);
|
fmt::vfprintf(m_LogFile, a_Format, a_ArgList);
|
||||||
fmt::fprintf(m_LogFile, "\n");
|
fmt::fprintf(m_LogFile, "\n");
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
fflush(m_LogFile);
|
fflush(m_LogFile);
|
||||||
@ -303,7 +301,7 @@ void cConnection::vLog(const char * a_Format, fmt::printf_args a_Args)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cConnection::vDataLog(const void * a_Data, size_t a_Size, const char * a_Format, fmt::printf_args a_Args)
|
void cConnection::vDataLog(const void * a_Data, size_t a_Size, const char * a_Format, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
AString Hex;
|
AString Hex;
|
||||||
CreateHexDump(Hex, a_Data, a_Size, 16);
|
CreateHexDump(Hex, a_Data, a_Size, 16);
|
||||||
@ -311,13 +309,11 @@ void cConnection::vDataLog(const void * a_Data, size_t a_Size, const char * a_Fo
|
|||||||
// Log to file:
|
// Log to file:
|
||||||
cCSLock Lock(m_CSLog);
|
cCSLock Lock(m_CSLog);
|
||||||
fmt::fprintf(m_LogFile, "[%5.3f] ", GetRelativeTime());
|
fmt::fprintf(m_LogFile, "[%5.3f] ", GetRelativeTime());
|
||||||
fmt::vfprintf(m_LogFile, a_Format, a_Args);
|
fmt::vfprintf(m_LogFile, a_Format, a_ArgList);
|
||||||
fmt::fprintf(m_LogFile, "\n%s\n", Hex);
|
fmt::fprintf(m_LogFile, "\n%s\n", Hex);
|
||||||
|
|
||||||
/*
|
|
||||||
// Log to screen:
|
// Log to screen:
|
||||||
std::cout << FullMsg;
|
// std::cout << FullMsg;
|
||||||
//*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ public:
|
|||||||
|
|
||||||
void Run(void);
|
void Run(void);
|
||||||
|
|
||||||
void vLog(const char * a_Format, fmt::printf_args);
|
void vLog(const char * a_Format, fmt::printf_args a_ArgList);
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
void Log(const char * a_Format, const Args & ... a_Args)
|
void Log(const char * a_Format, const Args & ... a_Args)
|
||||||
@ -67,7 +67,7 @@ public:
|
|||||||
vLog(a_Format, fmt::make_printf_args(a_Args...));
|
vLog(a_Format, fmt::make_printf_args(a_Args...));
|
||||||
}
|
}
|
||||||
|
|
||||||
void vDataLog(const void * a_Data, size_t a_Size, const char * a_Format, fmt::printf_args);
|
void vDataLog(const void * a_Data, size_t a_Size, const char * a_Format, fmt::printf_args a_ArgList);
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
void DataLog(const void * a_Data, size_t a_Size, const char * a_Format, const Args & ... a_Args)
|
void DataLog(const void * a_Data, size_t a_Size, const char * a_Format, const Args & ... a_Args)
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit 12cee38782897cfe60a1611615c200c45cd99eaf
|
Subproject commit 07472612522e4da6b96f589ccd1d20607c28c2b8
|
@ -53,9 +53,9 @@ public:
|
|||||||
static int tolua_do_error(lua_State * L, const char * a_pMsg, tolua_Error * a_pToLuaError);
|
static int tolua_do_error(lua_State * L, const char * a_pMsg, tolua_Error * a_pToLuaError);
|
||||||
static int vlua_do_error(lua_State * L, const char * a_pFormat, fmt::printf_args a_ArgList);
|
static int vlua_do_error(lua_State * L, const char * a_pFormat, fmt::printf_args a_ArgList);
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
static int lua_do_error(lua_State * L, const char * a_Format, const Args & ... args)
|
static int lua_do_error(lua_State * L, const char * a_Format, const Args & ... a_Args)
|
||||||
{
|
{
|
||||||
return vlua_do_error(L, a_Format, fmt::make_printf_args(args...));
|
return vlua_do_error(L, a_Format, fmt::make_printf_args(a_Args...));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -13,9 +13,9 @@
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// cCommandOutputCallback:
|
// cCommandOutputCallback:
|
||||||
|
|
||||||
void cCommandOutputCallback::vOut(const char * a_Fmt, fmt::printf_args args)
|
void cCommandOutputCallback::vOut(const char * a_Fmt, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
AString Output = ::vPrintf(a_Fmt, args);
|
AString Output = ::vPrintf(a_Fmt, a_ArgList);
|
||||||
Output.append("\n");
|
Output.append("\n");
|
||||||
Out(Output);
|
Out(Output);
|
||||||
}
|
}
|
||||||
|
@ -21,9 +21,9 @@ public:
|
|||||||
|
|
||||||
/** Syntax sugar function, calls Out() with Printf()-ed parameters; appends a newline" */
|
/** Syntax sugar function, calls Out() with Printf()-ed parameters; appends a newline" */
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
void Out(const char * a_Fmt, const Args & ... a_Args)
|
void Out(const char * a_Format, const Args & ... a_Args)
|
||||||
{
|
{
|
||||||
vOut(a_Fmt, fmt::make_printf_args(a_Args...));
|
vOut(a_Format, fmt::make_printf_args(a_Args...));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Called when the command wants to output anything; may be called multiple times */
|
/** Called when the command wants to output anything; may be called multiple times */
|
||||||
|
@ -84,9 +84,7 @@ void cLogger::LogLine(std::string_view a_Line, eLogLevel a_LogLevel)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cLogger::LogPrintf(
|
void cLogger::LogPrintf(std::string_view a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList)
|
||||||
std::string_view a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
fmt::memory_buffer Buffer;
|
fmt::memory_buffer Buffer;
|
||||||
WriteLogOpener(Buffer);
|
WriteLogOpener(Buffer);
|
||||||
@ -100,9 +98,7 @@ void cLogger::LogPrintf(
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cLogger::LogFormat(
|
void cLogger::LogFormat(std::string_view a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList)
|
||||||
std::string_view a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
fmt::memory_buffer Buffer;
|
fmt::memory_buffer Buffer;
|
||||||
WriteLogOpener(Buffer);
|
WriteLogOpener(Buffer);
|
||||||
@ -152,9 +148,7 @@ void cLogger::DetachListener(cListener * a_Listener)
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// Global functions
|
// Global functions
|
||||||
|
|
||||||
void Logger::LogFormat(
|
void Logger::LogFormat(std::string_view a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList)
|
||||||
std::string_view a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
cLogger::GetInstance().LogFormat(a_Format, a_LogLevel, a_ArgList);
|
cLogger::GetInstance().LogFormat(a_Format, a_LogLevel, a_ArgList);
|
||||||
}
|
}
|
||||||
@ -163,9 +157,7 @@ void Logger::LogFormat(
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Logger::LogPrintf(
|
void Logger::LogPrintf(std::string_view a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList)
|
||||||
std::string_view a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList
|
|
||||||
)
|
|
||||||
{
|
{
|
||||||
cLogger::GetInstance().LogPrintf(a_Format, a_LogLevel, a_ArgList);
|
cLogger::GetInstance().LogPrintf(a_Format, a_LogLevel, a_ArgList);
|
||||||
}
|
}
|
||||||
@ -178,7 +170,3 @@ void Logger::LogSimple(std::string_view a_Message, eLogLevel a_LogLevel)
|
|||||||
{
|
{
|
||||||
cLogger::GetInstance().LogSimple(a_Message, a_LogLevel);
|
cLogger::GetInstance().LogSimple(a_Message, a_LogLevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
14
src/Logger.h
14
src/Logger.h
@ -50,14 +50,10 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
/** Log a message formatted with a printf style formatting string. */
|
/** Log a message formatted with a printf style formatting string. */
|
||||||
void LogPrintf(
|
void LogPrintf(std::string_view a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList);
|
||||||
std::string_view a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList
|
|
||||||
);
|
|
||||||
|
|
||||||
/** Log a message formatted with a python style formatting string. */
|
/** Log a message formatted with a python style formatting string. */
|
||||||
void LogFormat(
|
void LogFormat(std::string_view a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList);
|
||||||
std::string_view a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList
|
|
||||||
);
|
|
||||||
|
|
||||||
/** Logs the simple text message at the specified log level. */
|
/** Logs the simple text message at the specified log level. */
|
||||||
void LogSimple(std::string_view a_Message, eLogLevel a_LogLevel = eLogLevel::Regular);
|
void LogSimple(std::string_view a_Message, eLogLevel a_LogLevel = eLogLevel::Regular);
|
||||||
@ -65,8 +61,10 @@ public:
|
|||||||
cAttachment AttachListener(std::unique_ptr<cListener> a_Listener);
|
cAttachment AttachListener(std::unique_ptr<cListener> a_Listener);
|
||||||
|
|
||||||
static cLogger & GetInstance(void);
|
static cLogger & GetInstance(void);
|
||||||
|
|
||||||
// Must be called before calling GetInstance in a multithreaded context
|
// Must be called before calling GetInstance in a multithreaded context
|
||||||
static void InitiateMultithreading();
|
static void InitiateMultithreading();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
cCriticalSection m_CriticalSection;
|
cCriticalSection m_CriticalSection;
|
||||||
@ -74,8 +72,4 @@ private:
|
|||||||
|
|
||||||
void DetachListener(cListener * a_Listener);
|
void DetachListener(cListener * a_Listener);
|
||||||
void LogLine(std::string_view a_Line, eLogLevel a_LogLevel);
|
void LogLine(std::string_view a_Line, eLogLevel a_LogLevel);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -695,10 +695,10 @@ AString cFile::GetExecutableExt(void)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
int cFile::vPrintf(const char * a_Fmt, fmt::printf_args a_ArgList)
|
int cFile::vPrintf(const char * a_Format, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
fmt::memory_buffer Buffer;
|
fmt::memory_buffer Buffer;
|
||||||
fmt::vprintf(Buffer, fmt::to_string_view(a_Fmt), a_ArgList);
|
fmt::vprintf(Buffer, fmt::to_string_view(a_Format), a_ArgList);
|
||||||
return Write(Buffer.data(), Buffer.size());
|
return Write(Buffer.data(), Buffer.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -710,7 +710,3 @@ void cFile::Flush(void)
|
|||||||
{
|
{
|
||||||
fflush(m_File);
|
fflush(m_File);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -168,11 +168,11 @@ public:
|
|||||||
/** Returns the list of all items in the specified folder (files, folders, nix pipes, whatever's there). */
|
/** Returns the list of all items in the specified folder (files, folders, nix pipes, whatever's there). */
|
||||||
static AStringVector GetFolderContents(const AString & a_Folder); // Exported in ManualBindings.cpp
|
static AStringVector GetFolderContents(const AString & a_Folder); // Exported in ManualBindings.cpp
|
||||||
|
|
||||||
int vPrintf(const char * a_Fmt, fmt::printf_args);
|
int vPrintf(const char * a_Format, fmt::printf_args a_ArgList);
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
int Printf(const char * a_Fmt, const Args & ... a_Args)
|
int Printf(const char * a_Format, const Args & ... a_Args)
|
||||||
{
|
{
|
||||||
return vPrintf(a_Fmt, fmt::make_printf_args(a_Args...));
|
return vPrintf(a_Format, fmt::make_printf_args(a_Args...));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Flushes all the bufferef output into the file (only when writing) */
|
/** Flushes all the bufferef output into the file (only when writing) */
|
||||||
|
@ -52,34 +52,34 @@ static unsigned char HexToDec(char a_HexChar)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
AString & vPrintf(AString & str, const char * format, fmt::printf_args args)
|
AString & vPrintf(AString & a_String, const char * a_Format, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
ASSERT(format != nullptr);
|
ASSERT(a_Format != nullptr);
|
||||||
fmt::memory_buffer Buffer;
|
fmt::memory_buffer Buffer; // Save a string allocation compared to vsprintf
|
||||||
fmt::vprintf(Buffer, fmt::to_string_view(format), args);
|
fmt::vprintf(Buffer, fmt::to_string_view(a_Format), a_ArgList);
|
||||||
str.assign(Buffer.data(), Buffer.size());
|
a_String.assign(Buffer.data(), Buffer.size());
|
||||||
return str;
|
return a_String;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
AString vPrintf(const char * format, fmt::printf_args args)
|
AString vPrintf(const char * a_Format, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
ASSERT(format != nullptr);
|
ASSERT(a_Format != nullptr);
|
||||||
return fmt::vsprintf(format, args);
|
return fmt::vsprintf(a_Format, a_ArgList);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
AString & vAppendPrintf(AString & a_String, const char * format, fmt::printf_args args)
|
AString & vAppendPrintf(AString & a_String, const char * a_Format, fmt::printf_args a_ArgList)
|
||||||
{
|
{
|
||||||
ASSERT(format != nullptr);
|
ASSERT(a_Format != nullptr);
|
||||||
fmt::memory_buffer Buffer;
|
fmt::memory_buffer Buffer;
|
||||||
fmt::vprintf(Buffer, fmt::to_string_view(format), args);
|
fmt::vprintf(Buffer, fmt::to_string_view(a_Format), a_ArgList);
|
||||||
a_String.append(Buffer.data(), Buffer.size());
|
a_String.append(Buffer.data(), Buffer.size());
|
||||||
return a_String;
|
return a_String;
|
||||||
}
|
}
|
||||||
|
@ -23,25 +23,25 @@ typedef std::map<AString, AString> AStringMap;
|
|||||||
|
|
||||||
/** Output the formatted text into the string.
|
/** Output the formatted text into the string.
|
||||||
Returns a_Dst. */
|
Returns a_Dst. */
|
||||||
extern AString & vPrintf(AString & a_Dst, const char * format, fmt::printf_args args);
|
extern AString & vPrintf(AString & a_Dst, const char * a_Format, fmt::printf_args a_ArgList);
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
AString & Printf(AString & a_Dst, const char * a_Format, const Args & ... args)
|
AString & Printf(AString & a_Dst, const char * a_Format, const Args & ... a_Args)
|
||||||
{
|
{
|
||||||
return vPrintf(a_Dst, a_Format, fmt::make_printf_args(args...));
|
return vPrintf(a_Dst, a_Format, fmt::make_printf_args(a_Args...));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Output the formatted text into string
|
/** Output the formatted text into string
|
||||||
Returns the formatted string by value. */
|
Returns the formatted string by value. */
|
||||||
extern AString vPrintf(const char * format, fmt::printf_args args);
|
extern AString vPrintf(const char * a_Format, fmt::printf_args a_ArgList);
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
AString Printf(const char * a_Format, const Args & ... args)
|
AString Printf(const char * a_Format, const Args & ... a_Args)
|
||||||
{
|
{
|
||||||
return vPrintf(a_Format, fmt::make_printf_args(args...));
|
return vPrintf(a_Format, fmt::make_printf_args(a_Args...));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add the formated string to the existing data in the string.
|
/** Add the formated string to the existing data in the string.
|
||||||
Returns a_Dst. */
|
Returns a_Dst. */
|
||||||
extern AString & vAppendPrintf(AString & a_Dst, const char * a_Format, fmt::printf_args args);
|
extern AString & vAppendPrintf(AString & a_Dst, const char * a_Format, fmt::printf_args a_ArgList);
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
extern AString & AppendPrintf(AString & a_Dst, const char * a_Format, const Args & ... a_Args)
|
extern AString & AppendPrintf(AString & a_Dst, const char * a_Format, const Args & ... a_Args)
|
||||||
{
|
{
|
||||||
|
@ -400,26 +400,25 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
namespace fmt
|
|
||||||
{
|
|
||||||
|
|
||||||
|
/** Allows formatting a Vector<T> using the same format specifiers as for T
|
||||||
|
e.g. `fmt::format("{0:0.2f}", Vector3f{0.0231f, 1.2146f, 1.0f}) == "{0.02, 1.21, 1.00}"` */
|
||||||
template <typename What>
|
template <typename What>
|
||||||
class formatter<Vector3<What>>:
|
class fmt::formatter<Vector3<What>> : public fmt::formatter<What>
|
||||||
public fmt::formatter<What>
|
|
||||||
{
|
{
|
||||||
using Super = fmt::formatter<What>;
|
using Super = fmt::formatter<What>;
|
||||||
|
|
||||||
template <typename FormatContext, size_t Len>
|
template <typename FormatContext, size_t Len>
|
||||||
void Write(FormatContext & a_Ctx, const char (& a_Str)[Len])
|
void Write(FormatContext & a_Ctx, const char (& a_Str)[Len])
|
||||||
{
|
{
|
||||||
auto Itr = std::copy_n(&a_Str[0], Len - 1, a_Ctx.out());
|
const auto Itr = std::copy_n(&a_Str[0], Len - 1, a_Ctx.out());
|
||||||
a_Ctx.advance_to(Itr);
|
a_Ctx.advance_to(Itr);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename FormatContext>
|
template <typename FormatContext>
|
||||||
void Write(FormatContext & a_Ctx, const What & a_Arg)
|
void Write(FormatContext & a_Ctx, const What & a_Arg)
|
||||||
{
|
{
|
||||||
auto Itr = Super::format(a_Arg, a_Ctx);
|
const auto Itr = Super::format(a_Arg, a_Ctx);
|
||||||
a_Ctx.advance_to(Itr);
|
a_Ctx.advance_to(Itr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -440,8 +439,6 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user