mirror of
https://github.com/coop-deluxe/sm64coopdx.git
synced 2025-01-22 23:52:15 -05:00
Keep console messages around until the final djui_init()
This commit is contained in:
parent
a85c8dbbf8
commit
1e89fcc4d4
4 changed files with 44 additions and 1 deletions
|
@ -747,6 +747,7 @@ static void ParseGfxSymbol(GfxData* aGfxData, DataNode<Gfx>* aNode, Gfx*& aHead,
|
||||||
gfx_symbol_5(gsDPLoadBlock);
|
gfx_symbol_5(gsDPLoadBlock);
|
||||||
gfx_symbol_2(gsDPSetRenderMode, false);
|
gfx_symbol_2(gsDPSetRenderMode, false);
|
||||||
gfx_symbol_2(gsSPGeometryMode, false);
|
gfx_symbol_2(gsSPGeometryMode, false);
|
||||||
|
gfx_symbol_2(gsSPGeometryModeSetFirst, false);
|
||||||
gfx_symbol_6(gsDPSetPrimColor);
|
gfx_symbol_6(gsDPSetPrimColor);
|
||||||
gfx_symbol_4(gsDPSetEnvColor);
|
gfx_symbol_4(gsDPSetEnvColor);
|
||||||
gfx_symbol_4(gsDPSetFogColor);
|
gfx_symbol_4(gsDPSetFogColor);
|
||||||
|
|
|
@ -10,6 +10,42 @@ struct DjuiConsole* gDjuiConsole = NULL;
|
||||||
bool gDjuiConsoleFocus = false;
|
bool gDjuiConsoleFocus = false;
|
||||||
char gDjuiConsoleTmpBuffer[CONSOLE_MAX_TMP_BUFFER] = "";
|
char gDjuiConsoleTmpBuffer[CONSOLE_MAX_TMP_BUFFER] = "";
|
||||||
u32 sDjuiConsoleMessages = 0;
|
u32 sDjuiConsoleMessages = 0;
|
||||||
|
bool sDjuiConsoleQueueMessages = true;
|
||||||
|
|
||||||
|
struct ConsoleQueuedMessage {
|
||||||
|
char* message;
|
||||||
|
struct ConsoleQueuedMessage* next;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ConsoleQueuedMessage* sConsoleQueuedMessages = NULL;
|
||||||
|
|
||||||
|
static void djui_console_message_queue(char* message) {
|
||||||
|
struct ConsoleQueuedMessage* queued = malloc(sizeof(struct ConsoleQueuedMessage));
|
||||||
|
queued->message = strdup(message);
|
||||||
|
queued->next = NULL;
|
||||||
|
if (sConsoleQueuedMessages == NULL) {
|
||||||
|
sConsoleQueuedMessages = queued;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct ConsoleQueuedMessage* entry = sConsoleQueuedMessages;
|
||||||
|
while (entry->next) { entry = entry->next; }
|
||||||
|
entry->next = queued;
|
||||||
|
}
|
||||||
|
|
||||||
|
void djui_console_message_dequeue(void) {
|
||||||
|
if (!gDjuiConsole) { return; }
|
||||||
|
sDjuiConsoleQueueMessages = false;
|
||||||
|
struct ConsoleQueuedMessage* entry = sConsoleQueuedMessages;
|
||||||
|
while (entry) {
|
||||||
|
struct ConsoleQueuedMessage* next = entry->next;
|
||||||
|
djui_console_message_create(entry->message);
|
||||||
|
free(entry->message);
|
||||||
|
free(entry);
|
||||||
|
entry = next;
|
||||||
|
}
|
||||||
|
sConsoleQueuedMessages = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
bool djui_console_render(struct DjuiBase* base) {
|
bool djui_console_render(struct DjuiBase* base) {
|
||||||
djui_base_set_size(base, gDjuiRoot->base.width.value, gDjuiRoot->base.height.value * 0.5f);
|
djui_base_set_size(base, gDjuiRoot->base.width.value, gDjuiRoot->base.height.value * 0.5f);
|
||||||
|
@ -66,8 +102,12 @@ static bool djui_console_on_key_down(UNUSED struct DjuiBase* base, int scancode)
|
||||||
}
|
}
|
||||||
|
|
||||||
void djui_console_message_create(const char* message) {
|
void djui_console_message_create(const char* message) {
|
||||||
if (!gDjuiConsole) { return; }
|
if (sDjuiConsoleQueueMessages || !gDjuiConsole) {
|
||||||
|
djui_console_message_queue(message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
djui_base_compute_tree(&gDjuiConsole->base);
|
djui_base_compute_tree(&gDjuiConsole->base);
|
||||||
|
|
||||||
struct DjuiBase* cfBase = &gDjuiConsole->flow->base;
|
struct DjuiBase* cfBase = &gDjuiConsole->flow->base;
|
||||||
|
|
||||||
f32 maxTextWidth = gDjuiConsole->base.comp.width - gDjuiConsole->base.padding.left.value - gDjuiConsole->base.padding.right.value;
|
f32 maxTextWidth = gDjuiConsole->base.comp.width - gDjuiConsole->base.padding.left.value - gDjuiConsole->base.padding.right.value;
|
||||||
|
|
|
@ -12,6 +12,7 @@ extern struct DjuiConsole* gDjuiConsole;
|
||||||
extern bool gDjuiConsoleFocus;
|
extern bool gDjuiConsoleFocus;
|
||||||
extern char gDjuiConsoleTmpBuffer[];
|
extern char gDjuiConsoleTmpBuffer[];
|
||||||
|
|
||||||
|
void djui_console_message_dequeue(void);
|
||||||
void djui_console_message_create(const char* message);
|
void djui_console_message_create(const char* message);
|
||||||
void djui_console_toggle(void);
|
void djui_console_toggle(void);
|
||||||
struct DjuiConsole* djui_console_create(void);
|
struct DjuiConsole* djui_console_create(void);
|
||||||
|
|
|
@ -349,6 +349,7 @@ int main(int argc, char *argv[]) {
|
||||||
djui_init();
|
djui_init();
|
||||||
djui_unicode_init();
|
djui_unicode_init();
|
||||||
djui_init_late();
|
djui_init_late();
|
||||||
|
djui_console_message_dequeue();
|
||||||
|
|
||||||
// Init network
|
// Init network
|
||||||
if (gCLIOpts.Network == NT_CLIENT) {
|
if (gCLIOpts.Network == NT_CLIENT) {
|
||||||
|
|
Loading…
Reference in a new issue