whb: Modification of logging functions

* WHBLogPrint and WHBLogPrint have been renamed to WHBLogWrite and
WHBLogWrite respectively.
* WHBLogPrint and WHBLogPrintf have been re-implemented to automatically
add a new line to the end of the string, and then send the string to
WHBLogWrite.
This commit is contained in:
CreeperMario 2017-08-20 16:57:43 +09:30
parent 84d1957066
commit 45f3cd71ab
3 changed files with 55 additions and 2 deletions

View File

@ -16,9 +16,15 @@ typedef void (*LogHandlerFn)(const char *msg);
BOOL
WHBAddLogHandler(LogHandlerFn fn);
BOOL
WHBLogWrite(const char *str);
BOOL
WHBLogPrint(const char *str);
BOOL
WHBLogWritef(const char *fmt, ...);
BOOL
WHBLogPrintf(const char *fmt, ...);

View File

@ -26,7 +26,7 @@ WHBAddLogHandler(LogHandlerFn fn)
}
BOOL
WHBLogPrint(const char *str)
WHBLogWrite(const char *str)
{
int i;
@ -39,6 +39,44 @@ WHBLogPrint(const char *str)
return TRUE;
}
BOOL
WHBLogPrint(const char *str)
{
char *buf = MEMAllocFromDefaultHeapEx(PRINTF_BUFFER_LENGTH, 4);
BOOL result;
if(!buf) {
return FALSE;
}
snprintf(buf, PRINTF_BUFFER_LENGTH, "%s\n", str);
result = WHBLogWrite(buf);
MEMFreeToDefaultHeap(buf);
return result;
}
BOOL
WHBLogWritef(const char *fmt, ...)
{
char *buf = MEMAllocFromDefaultHeapEx(PRINTF_BUFFER_LENGTH, 4);
va_list va;
BOOL result;
if (!buf) {
return FALSE;
}
va_start(va, fmt);
vsnprintf(buf, PRINTF_BUFFER_LENGTH, fmt, va);
result = WHBLogWrite(buf);
MEMFreeToDefaultHeap(buf);
va_end(va);
return result;
}
BOOL
WHBLogPrintf(const char *fmt, ...)
{

View File

@ -1,10 +1,19 @@
#include <coreinit/debug.h>
#include <whb/log.h>
#include <string.h>
static void
cafeLogHandler(const char * msg)
{
int length = strlen(msg);
if(msg[length-1] != '\n') {
OSReport("%s\n", msg);
}
else {
OSReport(msg);
}
}
BOOL