mirror of
https://github.com/wiiu-env/Flappy-Bird_GX2.git
synced 2024-11-27 10:04:16 +01:00
Log via WHB
This commit is contained in:
parent
d3097d15de
commit
04d775fbdb
@ -52,22 +52,22 @@ Application::Application()
|
|||||||
}
|
}
|
||||||
|
|
||||||
Application::~Application() {
|
Application::~Application() {
|
||||||
log_printf("Destroy music\n");
|
DEBUG_FUNCTION_LINE("Destroy music");
|
||||||
|
|
||||||
delete bgMusic;
|
delete bgMusic;
|
||||||
|
|
||||||
log_printf("Destroy controller\n");
|
DEBUG_FUNCTION_LINE("Destroy controller");
|
||||||
|
|
||||||
for (int i = 0; i < 5; i++)
|
for (int i = 0; i < 5; i++)
|
||||||
delete controller[i];
|
delete controller[i];
|
||||||
|
|
||||||
log_printf("Destroy async deleter\n");
|
|
||||||
AsyncDeleter::destroyInstance();
|
AsyncDeleter::destroyInstance();
|
||||||
|
DEBUG_FUNCTION_LINE("Destroy async deleter");
|
||||||
|
|
||||||
log_printf("Clear resources\n");
|
DEBUG_FUNCTION_LINE("Clear resources");
|
||||||
Resources::Clear();
|
Resources::Clear();
|
||||||
|
|
||||||
log_printf("Stop sound handler\n");
|
DEBUG_FUNCTION_LINE("Stop sound handler");
|
||||||
SoundHandler::DestroyInstance();
|
SoundHandler::DestroyInstance();
|
||||||
|
|
||||||
ProcUIShutdown();
|
ProcUIShutdown();
|
||||||
@ -139,27 +139,27 @@ bool Application::procUI(void) {
|
|||||||
|
|
||||||
switch (ProcUIProcessMessages(true)) {
|
switch (ProcUIProcessMessages(true)) {
|
||||||
case PROCUI_STATUS_EXITING: {
|
case PROCUI_STATUS_EXITING: {
|
||||||
log_printf("PROCUI_STATUS_EXITING\n");
|
DEBUG_FUNCTION_LINE("PROCUI_STATUS_EXITING");
|
||||||
exitCode = EXIT_SUCCESS;
|
exitCode = EXIT_SUCCESS;
|
||||||
exitApplication = true;
|
exitApplication = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case PROCUI_STATUS_RELEASE_FOREGROUND: {
|
case PROCUI_STATUS_RELEASE_FOREGROUND: {
|
||||||
log_printf("PROCUI_STATUS_RELEASE_FOREGROUND\n");
|
DEBUG_FUNCTION_LINE("PROCUI_STATUS_RELEASE_FOREGROUND");
|
||||||
if (video != NULL) {
|
if (video != NULL) {
|
||||||
// we can turn of the screen but we don't need to and it will display the last image
|
// we can turn of the screen but we don't need to and it will display the last image
|
||||||
video->tvEnable(true);
|
video->tvEnable(true);
|
||||||
video->drcEnable(true);
|
video->drcEnable(true);
|
||||||
|
|
||||||
log_printf("delete fontSystem\n");
|
DEBUG_FUNCTION_LINE("delete fontSystem");
|
||||||
delete fontSystem;
|
delete fontSystem;
|
||||||
fontSystem = NULL;
|
fontSystem = NULL;
|
||||||
|
|
||||||
log_printf("delete video\n");
|
DEBUG_FUNCTION_LINE("delete video");
|
||||||
delete video;
|
delete video;
|
||||||
video = NULL;
|
video = NULL;
|
||||||
|
|
||||||
log_printf("deinitialze memory\n");
|
DEBUG_FUNCTION_LINE("deinitialze memory");
|
||||||
memoryRelease();
|
memoryRelease();
|
||||||
ProcUIDrawDoneRelease();
|
ProcUIDrawDoneRelease();
|
||||||
} else {
|
} else {
|
||||||
@ -170,21 +170,21 @@ bool Application::procUI(void) {
|
|||||||
case PROCUI_STATUS_IN_FOREGROUND: {
|
case PROCUI_STATUS_IN_FOREGROUND: {
|
||||||
if (!quitRequest) {
|
if (!quitRequest) {
|
||||||
if (video == NULL) {
|
if (video == NULL) {
|
||||||
log_printf("PROCUI_STATUS_IN_FOREGROUND\n");
|
DEBUG_FUNCTION_LINE("PROCUI_STATUS_IN_FOREGROUND");
|
||||||
log_printf("initialze memory\n");
|
DEBUG_FUNCTION_LINE("initialze memory");
|
||||||
memoryInitialize();
|
memoryInitialize();
|
||||||
|
|
||||||
log_printf("Initialize video\n");
|
DEBUG_FUNCTION_LINE("Initialize video");
|
||||||
video = new CVideo(GX2_TV_SCAN_MODE_720P, GX2_DRC_RENDER_MODE_SINGLE);
|
video = new CVideo(GX2_TV_SCAN_MODE_720P, GX2_DRC_RENDER_MODE_SINGLE);
|
||||||
log_printf("Video size %i x %i\n", video->getTvWidth(), video->getTvHeight());
|
DEBUG_FUNCTION_LINE("Video size %i x %i", video->getTvWidth(), video->getTvHeight());
|
||||||
|
|
||||||
//! setup default Font
|
//! setup default Font
|
||||||
log_printf("Initialize main font system\n");
|
DEBUG_FUNCTION_LINE("Initialize main font system");
|
||||||
FreeTypeGX *fontSystem = new FreeTypeGX(Resources::GetFile("font.ttf"), Resources::GetFileSize("font.ttf"), true);
|
FreeTypeGX *fontSystem = new FreeTypeGX(Resources::GetFile("font.ttf"), Resources::GetFileSize("font.ttf"), true);
|
||||||
GuiText::setPresetFont(fontSystem);
|
GuiText::setPresetFont(fontSystem);
|
||||||
|
|
||||||
if (mainWindow == NULL) {
|
if (mainWindow == NULL) {
|
||||||
log_printf("Initialize main window\n");
|
DEBUG_FUNCTION_LINE("Initialize main window");
|
||||||
mainWindow = new MainWindow(video->getTvWidth(), video->getTvHeight());
|
mainWindow = new MainWindow(video->getTvWidth(), video->getTvHeight());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,7 +202,7 @@ bool Application::procUI(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Application::executeThread(void) {
|
void Application::executeThread(void) {
|
||||||
log_printf("Entering main loop\n");
|
DEBUG_FUNCTION_LINE("Entering main loop");
|
||||||
|
|
||||||
//! main GX2 loop (60 Hz cycle with max priority on core 1)
|
//! main GX2 loop (60 Hz cycle with max priority on core 1)
|
||||||
while (!exitApplication) {
|
while (!exitApplication) {
|
||||||
@ -252,18 +252,18 @@ void Application::executeThread(void) {
|
|||||||
fadeOut();
|
fadeOut();
|
||||||
}
|
}
|
||||||
|
|
||||||
log_printf("delete mainWindow\n");
|
DEBUG_FUNCTION_LINE("delete mainWindow");
|
||||||
delete mainWindow;
|
delete mainWindow;
|
||||||
mainWindow = NULL;
|
mainWindow = NULL;
|
||||||
|
|
||||||
log_printf("delete fontSystem\n");
|
DEBUG_FUNCTION_LINE("delete fontSystem");
|
||||||
delete fontSystem;
|
delete fontSystem;
|
||||||
fontSystem = NULL;
|
fontSystem = NULL;
|
||||||
|
|
||||||
log_printf("delete video\n");
|
DEBUG_FUNCTION_LINE("delete video");
|
||||||
delete video;
|
delete video;
|
||||||
video = NULL;
|
video = NULL;
|
||||||
|
|
||||||
log_printf("deinitialze memory\n");
|
DEBUG_FUNCTION_LINE("deinitialze memory");
|
||||||
memoryRelease();
|
memoryRelease();
|
||||||
}
|
}
|
||||||
|
13
src/main.cpp
13
src/main.cpp
@ -4,26 +4,21 @@
|
|||||||
#include "system/memory.h"
|
#include "system/memory.h"
|
||||||
#include "utils/logger.h"
|
#include "utils/logger.h"
|
||||||
#include "utils/utils.h"
|
#include "utils/utils.h"
|
||||||
|
#include <whb/log_udp.h>
|
||||||
|
|
||||||
/* Entry point */
|
/* Entry point */
|
||||||
extern "C" int Menu_Main(void) {
|
extern "C" int Menu_Main(void) {
|
||||||
//!*******************************************************************
|
WHBLogUdpInit();
|
||||||
//! Initialize function pointers *
|
|
||||||
//!*******************************************************************
|
|
||||||
socket_lib_init();
|
|
||||||
//! do OS (for acquire) and sockets first so we got logging
|
|
||||||
log_init();
|
|
||||||
|
|
||||||
log_print("Initialize memory management\n");
|
DEBUG_FUNCTION_LINE("Initialize memory management");
|
||||||
memoryInitialize();
|
memoryInitialize();
|
||||||
|
|
||||||
//!*******************************************************************
|
//!*******************************************************************
|
||||||
//! Initialize heap memory *
|
//! Initialize heap memory *
|
||||||
//!*******************************************************************
|
//!*******************************************************************
|
||||||
|
|
||||||
log_printf("Start main application\n");
|
DEBUG_FUNCTION_LINE("Start main application");
|
||||||
Application::instance()->exec();
|
Application::instance()->exec();
|
||||||
|
|
||||||
Application::destroyInstance();
|
Application::destroyInstance();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1,82 +0,0 @@
|
|||||||
#include <stdarg.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <utils/logger.h>
|
|
||||||
#include <nsysnet/socket.h>
|
|
||||||
#include <coreinit/debug.h>
|
|
||||||
|
|
||||||
#include <coreinit/systeminfo.h>
|
|
||||||
#include <coreinit/thread.h>
|
|
||||||
|
|
||||||
static int log_socket __attribute__((section(".data"))) = -1;
|
|
||||||
static struct sockaddr_in connect_addr __attribute__((section(".data")));
|
|
||||||
static volatile int log_lock __attribute__((section(".data"))) = 0;
|
|
||||||
|
|
||||||
void log_init_() {
|
|
||||||
int broadcastEnable = 1;
|
|
||||||
log_socket = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
|
||||||
if (log_socket < 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
setsockopt(log_socket, SOL_SOCKET, SO_BROADCAST, &broadcastEnable, sizeof(broadcastEnable));
|
|
||||||
|
|
||||||
memset(&connect_addr, 0, sizeof(struct sockaddr_in));
|
|
||||||
connect_addr.sin_family = AF_INET;
|
|
||||||
connect_addr.sin_port = 4405;
|
|
||||||
connect_addr.sin_addr.s_addr = htonl(INADDR_BROADCAST);
|
|
||||||
}
|
|
||||||
|
|
||||||
void log_print_(const char *str) {
|
|
||||||
// socket is always 0 initially as it is in the BSS
|
|
||||||
if (log_socket < 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (log_lock)
|
|
||||||
OSSleepTicks(OSMicrosecondsToTicks(1000));
|
|
||||||
log_lock = 1;
|
|
||||||
|
|
||||||
int len = strlen(str);
|
|
||||||
int ret;
|
|
||||||
while (len > 0) {
|
|
||||||
int block = len < 1400 ? len : 1400; // take max 1400 bytes per UDP packet
|
|
||||||
ret = sendto(log_socket, str, block, 0, (struct sockaddr *) &connect_addr, sizeof(struct sockaddr_in));
|
|
||||||
if (ret < 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
len -= ret;
|
|
||||||
str += ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
log_lock = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void OSFatal_printf(const char *format, ...) {
|
|
||||||
char tmp[512];
|
|
||||||
tmp[0] = 0;
|
|
||||||
va_list va;
|
|
||||||
va_start(va, format);
|
|
||||||
if ((vsprintf(tmp, format, va) >= 0)) {
|
|
||||||
OSFatal(tmp);
|
|
||||||
}
|
|
||||||
va_end(va);
|
|
||||||
}
|
|
||||||
|
|
||||||
void log_printf_(const char *format, ...) {
|
|
||||||
if (log_socket < 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
char tmp[512];
|
|
||||||
tmp[0] = 0;
|
|
||||||
|
|
||||||
va_list va;
|
|
||||||
va_start(va, format);
|
|
||||||
if ((vsprintf(tmp, format, va) >= 0)) {
|
|
||||||
log_print_(tmp);
|
|
||||||
}
|
|
||||||
va_end(va);
|
|
||||||
}
|
|
||||||
|
|
@ -1,20 +1,11 @@
|
|||||||
#ifndef __LOGGER_H_
|
#pragma once
|
||||||
#define __LOGGER_H_
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <whb/log.h>
|
||||||
void log_init_();
|
|
||||||
|
|
||||||
//void log_deinit_(void);
|
|
||||||
void log_print_(const char *str);
|
|
||||||
|
|
||||||
void log_printf_(const char *format, ...);
|
|
||||||
|
|
||||||
void OSFatal_printf(const char *format, ...);
|
|
||||||
|
|
||||||
#define __FILENAME_X__ (strrchr(__FILE__, '\\') ? strrchr(__FILE__, '\\') + 1 : __FILE__)
|
#define __FILENAME_X__ (strrchr(__FILE__, '\\') ? strrchr(__FILE__, '\\') + 1 : __FILE__)
|
||||||
#define __FILENAME__ (strrchr(__FILE__, '/') ? strrchr(__FILE__, '/') + 1 : __FILENAME_X__)
|
#define __FILENAME__ (strrchr(__FILE__, '/') ? strrchr(__FILE__, '/') + 1 : __FILENAME_X__)
|
||||||
@ -23,19 +14,14 @@ void OSFatal_printf(const char *format, ...);
|
|||||||
OSFatal_printf("[%s]%s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
OSFatal_printf("[%s]%s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
|
||||||
#define log_init() log_init_()
|
|
||||||
//#define log_deinit() log_deinit_()
|
|
||||||
#define log_print(str) log_print_(str)
|
|
||||||
#define log_printf(FMT, ARGS...) log_printf_(FMT, ## ARGS);
|
|
||||||
|
|
||||||
#define DEBUG_FUNCTION_LINE(FMT, ARGS...)do { \
|
#define DEBUG_FUNCTION_LINE(FMT, ARGS...)do { \
|
||||||
log_printf("[%23s]%30s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
WHBLogPrintf("[%23s]%30s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
||||||
} while (0)
|
} while (0);
|
||||||
|
|
||||||
|
#define DEBUG_FUNCTION_LINE_WRITE(FMT, ARGS...)do { \
|
||||||
|
WHBLogWritef("[%23s]%30s@L%04d: " FMT "",__FILENAME__,__FUNCTION__, __LINE__, ## ARGS); \
|
||||||
|
} while (0);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
|
||||||
|
Loading…
Reference in New Issue
Block a user