2024-04-13 02:31:49 -04:00
|
|
|
|
#include "GasaGameInstance.h"
|
|
|
|
|
|
2024-04-23 01:10:02 -04:00
|
|
|
|
#include "Engine/NetDriver.h"
|
|
|
|
|
#include "Engine/World.h"
|
|
|
|
|
using namespace Gasa;
|
|
|
|
|
|
|
|
|
|
#pragma region GameFramework
|
|
|
|
|
// TODO(Ed): Make a NetLog
|
|
|
|
|
|
2024-04-23 18:54:17 -04:00
|
|
|
|
UGasaGameInstance::UGasaGameInstance()
|
|
|
|
|
{
|
|
|
|
|
GameFrameworkState = EGameFrameworkState::Uninitialized;
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-23 01:10:02 -04:00
|
|
|
|
void UGasaGameInstance::NotifyGameFrameworkClassReady(EGameFrameworkClassFlag ClassReady)
|
|
|
|
|
{
|
|
|
|
|
switch (ClassReady)
|
|
|
|
|
{
|
|
|
|
|
case EGameFrameworkClassFlag::GameMode:
|
|
|
|
|
GameFrameworkClassesState |= (uint32)EGameFrameworkClassFlag::GameMode;
|
2024-04-23 18:54:17 -04:00
|
|
|
|
NetLog("Game Framework class ready: Game State", ELogV::Log, LogGasaNet );
|
2024-04-23 01:10:02 -04:00
|
|
|
|
break;
|
|
|
|
|
case EGameFrameworkClassFlag::GameState:
|
|
|
|
|
GameFrameworkClassesState |= (uint32)EGameFrameworkClassFlag::GameState;
|
2024-04-23 18:54:17 -04:00
|
|
|
|
NetLog("Game Framework class ready: Game State", ELogV::Log, LogGasaNet );
|
2024-04-23 01:10:02 -04:00
|
|
|
|
break;
|
|
|
|
|
case EGameFrameworkClassFlag::PlayerController:
|
|
|
|
|
GameFrameworkClassesState |= (uint32)EGameFrameworkClassFlag::PlayerController;
|
2024-04-23 18:54:17 -04:00
|
|
|
|
NetLog("Game Framework class ready: Player Controller", ELogV::Log, LogGasaNet);
|
2024-04-23 01:10:02 -04:00
|
|
|
|
break;
|
|
|
|
|
case EGameFrameworkClassFlag::PlayerState:
|
|
|
|
|
GameFrameworkClassesState |= (uint32)EGameFrameworkClassFlag::PlayerState;
|
2024-04-23 18:54:17 -04:00
|
|
|
|
NetLog("Game Framework class ready: Player State", ELogV::Log, LogGasaNet);
|
2024-04-23 01:10:02 -04:00
|
|
|
|
break;
|
|
|
|
|
case EGameFrameworkClassFlag::Levels:
|
|
|
|
|
GameFrameworkClassesState |= (uint32)EGameFrameworkClassFlag::Levels;
|
2024-04-23 18:54:17 -04:00
|
|
|
|
NetLog("Game Framework class ready: Levels", ELogV::Log, LogGasaNet);
|
2024-04-23 01:10:02 -04:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
ProcessGameFrameworkState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void UGasaGameInstance::ProcessGameFrameworkState()
|
|
|
|
|
{
|
|
|
|
|
switch (GameFrameworkState)
|
|
|
|
|
{
|
|
|
|
|
case EGameFrameworkState::Uninitialized:
|
|
|
|
|
{
|
|
|
|
|
uint32 InitializedFlags =
|
|
|
|
|
(uint32)EGameFrameworkClassFlag::GameState |
|
|
|
|
|
(uint32)EGameFrameworkClassFlag::PlayerController |
|
|
|
|
|
(uint32)EGameFrameworkClassFlag::PlayerState |
|
|
|
|
|
(uint32)EGameFrameworkClassFlag::Levels
|
|
|
|
|
;
|
|
|
|
|
|
|
|
|
|
if (GetWorld()->NetDriver == nullptr || GetWorld()->NetDriver->IsServer())
|
|
|
|
|
{
|
|
|
|
|
InitializedFlags |= (uint32)EGameFrameworkClassFlag::GameMode;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FString MsgGM = "GameMode : " + FString::FromInt( Bitfield_IsSet( GameFrameworkClassesState, scast(uint32, EGameFrameworkClassFlag::GameMode )) );
|
|
|
|
|
FString MsgGS = "GameState : " + FString::FromInt( Bitfield_IsSet( GameFrameworkClassesState, scast(uint32, EGameFrameworkClassFlag::GameState )) );
|
|
|
|
|
FString MsgPC = "PlayerController: " + FString::FromInt( Bitfield_IsSet( GameFrameworkClassesState, scast(uint32, EGameFrameworkClassFlag::PlayerController ) ));
|
|
|
|
|
FString MsgPS = "PlayerState : " + FString::FromInt( Bitfield_IsSet( GameFrameworkClassesState, scast(uint32, EGameFrameworkClassFlag::PlayerState ) ));
|
|
|
|
|
FString MsgL = "Levels : " + FString::FromInt( Bitfield_IsSet( GameFrameworkClassesState, scast(uint32, EGameFrameworkClassFlag::Levels ) ));
|
|
|
|
|
|
|
|
|
|
NetLog(MsgGM, ELogV::Log, LogGasaNet);
|
|
|
|
|
NetLog(MsgGS, ELogV::Log, LogGasaNet);
|
|
|
|
|
NetLog(MsgPC, ELogV::Log, LogGasaNet);
|
|
|
|
|
NetLog(MsgPS, ELogV::Log, LogGasaNet);
|
|
|
|
|
NetLog(MsgL, ELogV::Log, LogGasaNet);
|
|
|
|
|
|
|
|
|
|
if (GameFrameworkClassesState == InitializedFlags)
|
|
|
|
|
{
|
|
|
|
|
GameFrameworkState = EGameFrameworkState::Initialized;
|
2024-04-23 18:54:17 -04:00
|
|
|
|
NetLog("Game Framework initialized");
|
2024-04-23 01:10:02 -04:00
|
|
|
|
|
|
|
|
|
Event_OnGameFrameworkInitialized.Broadcast();
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#pragma endregion GameFramework
|
|
|
|
|
|
|
|
|
|
#pragma region GameInstance
|
2024-04-13 02:31:49 -04:00
|
|
|
|
void UGasaGameInstance::Init()
|
|
|
|
|
{
|
|
|
|
|
Super::Init();
|
|
|
|
|
|
|
|
|
|
DevOptionsCache.CachedDevOptions();
|
|
|
|
|
}
|
2024-04-23 18:54:17 -04:00
|
|
|
|
#pragma endregion GameInstance
|