mirror of
https://github.com/isledecomp/isle-portable.git
synced 2024-11-22 15:37:55 -05:00
lego1: match LegoOmni::GetInstance and deconstructor and add a few methods (#58)
* add GetInstance fix * Implement a few methods * Move get* helpers to their correct locations * rename m_instance * add TransitionManager
This commit is contained in:
parent
6558a78848
commit
88c18c76ed
4 changed files with 107 additions and 17 deletions
|
@ -15,13 +15,20 @@ LegoOmni::~LegoOmni()
|
||||||
// OFFSET: LEGO1 0x1005ad10
|
// OFFSET: LEGO1 0x1005ad10
|
||||||
LegoOmni *LegoOmni::GetInstance()
|
LegoOmni *LegoOmni::GetInstance()
|
||||||
{
|
{
|
||||||
return (LegoOmni *) m_instance;
|
return (LegoOmni *)MxOmni::GetInstance();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x1005ac90
|
||||||
|
void LegoOmni::CreateInstance()
|
||||||
|
{
|
||||||
|
MxOmni::DestroyInstance();
|
||||||
|
MxOmni::SetInstance(new LegoOmni());
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x10015700
|
// OFFSET: LEGO1 0x10015700
|
||||||
LegoOmni *Lego()
|
LegoOmni *Lego()
|
||||||
{
|
{
|
||||||
return (LegoOmni *) MxOmni::GetInstance();
|
return (LegoOmni *)MxOmni::GetInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x10015710
|
// OFFSET: LEGO1 0x10015710
|
||||||
|
@ -30,7 +37,6 @@ LegoSoundManager *SoundManager()
|
||||||
return LegoOmni::GetInstance()->GetSoundManager();
|
return LegoOmni::GetInstance()->GetSoundManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x10015720
|
// OFFSET: LEGO1 0x10015720
|
||||||
LegoVideoManager *VideoManager()
|
LegoVideoManager *VideoManager()
|
||||||
{
|
{
|
||||||
|
@ -79,6 +85,13 @@ LegoNavController *NavController()
|
||||||
return LegoOmni::GetInstance()->GetNavController();
|
return LegoOmni::GetInstance()->GetNavController();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x10015900
|
||||||
|
MxTransitionManager *TransitionManager()
|
||||||
|
{
|
||||||
|
return LegoOmni::GetInstance()->GetTransitionManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x1005b5f0
|
// OFFSET: LEGO1 0x1005b5f0
|
||||||
long LegoOmni::Notify(MxParam &p)
|
long LegoOmni::Notify(MxParam &p)
|
||||||
{
|
{
|
||||||
|
|
|
@ -71,6 +71,7 @@ class LegoOmni : public MxOmni
|
||||||
LegoPlantManager *GetLegoPlantManager() { return m_plantManager; }
|
LegoPlantManager *GetLegoPlantManager() { return m_plantManager; }
|
||||||
LegoGameState *GetGameState() { return m_gameState; }
|
LegoGameState *GetGameState() { return m_gameState; }
|
||||||
LegoNavController *GetNavController() { return m_navController; }
|
LegoNavController *GetNavController() { return m_navController; }
|
||||||
|
MxTransitionManager *GetTransitionManager() { return m_transitionManager; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int m_unk68;
|
int m_unk68;
|
||||||
|
@ -84,7 +85,7 @@ class LegoOmni : public MxOmni
|
||||||
char m_unk94[0x4];
|
char m_unk94[0x4];
|
||||||
LegoBuildingManager* m_buildingManager; // 0x98
|
LegoBuildingManager* m_buildingManager; // 0x98
|
||||||
LegoGameState *m_gameState; // 0x9c
|
LegoGameState *m_gameState; // 0x9c
|
||||||
char m_unka0[0x94];
|
MxDSAction m_action;
|
||||||
MxBackgroundAudioManager *m_bkgAudioManager; // 0x134
|
MxBackgroundAudioManager *m_bkgAudioManager; // 0x134
|
||||||
MxTransitionManager *m_transitionManager; // 0x138
|
MxTransitionManager *m_transitionManager; // 0x138
|
||||||
int m_unk13c;
|
int m_unk13c;
|
||||||
|
@ -93,26 +94,19 @@ class LegoOmni : public MxOmni
|
||||||
|
|
||||||
__declspec(dllexport) MxBackgroundAudioManager * BackgroundAudioManager();
|
__declspec(dllexport) MxBackgroundAudioManager * BackgroundAudioManager();
|
||||||
__declspec(dllexport) MxDSObject * CreateStreamObject(MxDSFile *,short);
|
__declspec(dllexport) MxDSObject * CreateStreamObject(MxDSFile *,short);
|
||||||
__declspec(dllexport) MxEventManager * EventManager();
|
|
||||||
__declspec(dllexport) LegoGameState * GameState();
|
__declspec(dllexport) LegoGameState * GameState();
|
||||||
__declspec(dllexport) const char * GetNoCD_SourceName();
|
__declspec(dllexport) const char * GetNoCD_SourceName();
|
||||||
__declspec(dllexport) LegoInputManager * InputManager();
|
__declspec(dllexport) LegoInputManager * InputManager();
|
||||||
__declspec(dllexport) LegoOmni * Lego();
|
__declspec(dllexport) LegoOmni * Lego();
|
||||||
__declspec(dllexport) MxSoundManager * MSoundManager();
|
|
||||||
__declspec(dllexport) void MakeSourceName(char *, const char *);
|
__declspec(dllexport) void MakeSourceName(char *, const char *);
|
||||||
__declspec(dllexport) MxMusicManager * MusicManager();
|
|
||||||
__declspec(dllexport) MxNotificationManager * NotificationManager();
|
__declspec(dllexport) MxNotificationManager * NotificationManager();
|
||||||
__declspec(dllexport) LegoEntity * PickEntity(long,long);
|
__declspec(dllexport) LegoEntity * PickEntity(long,long);
|
||||||
__declspec(dllexport) LegoROI * PickROI(long,long);
|
__declspec(dllexport) LegoROI * PickROI(long,long);
|
||||||
__declspec(dllexport) void SetOmniUserMessage(void (*)(const char *,int));
|
__declspec(dllexport) void SetOmniUserMessage(void (*)(const char *,int));
|
||||||
__declspec(dllexport) LegoSoundManager * SoundManager();
|
__declspec(dllexport) LegoSoundManager * SoundManager();
|
||||||
__declspec(dllexport) long Start(MxDSAction *);
|
__declspec(dllexport) long Start(MxDSAction *);
|
||||||
__declspec(dllexport) MxStreamer * Streamer();
|
|
||||||
__declspec(dllexport) MxTickleManager * TickleManager();
|
|
||||||
__declspec(dllexport) MxTransitionManager * TransitionManager();
|
__declspec(dllexport) MxTransitionManager * TransitionManager();
|
||||||
__declspec(dllexport) MxVariableTable * VariableTable();
|
|
||||||
__declspec(dllexport) LegoVideoManager * VideoManager();
|
__declspec(dllexport) LegoVideoManager * VideoManager();
|
||||||
|
|
||||||
__declspec(dllexport) long Start(MxDSAction *a);
|
__declspec(dllexport) long Start(MxDSAction *a);
|
||||||
|
|
||||||
LegoBuildingManager* BuildingManager();
|
LegoBuildingManager* BuildingManager();
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#include "mxomni.h"
|
#include "mxomni.h"
|
||||||
|
|
||||||
// 0x101015b0
|
// 0x101015b0
|
||||||
MxOmni* MxOmni::m_instance = NULL;
|
MxOmni *MxOmni::g_instance = NULL;
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100aef10
|
// OFFSET: LEGO1 0x100aef10
|
||||||
MxOmni::MxOmni()
|
MxOmni::MxOmni()
|
||||||
|
@ -33,10 +33,26 @@ void MxOmni::Init()
|
||||||
m_unk64 = NULL;
|
m_unk64 = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100b0690
|
||||||
|
void MxOmni::DestroyInstance()
|
||||||
|
{
|
||||||
|
if (g_instance != NULL)
|
||||||
|
{
|
||||||
|
delete g_instance;
|
||||||
|
g_instance = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100b0680
|
// OFFSET: LEGO1 0x100b0680
|
||||||
MxOmni *MxOmni::GetInstance()
|
MxOmni *MxOmni::GetInstance()
|
||||||
{
|
{
|
||||||
return m_instance;
|
return g_instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100af0b0
|
||||||
|
void MxOmni::SetInstance(MxOmni *instance)
|
||||||
|
{
|
||||||
|
g_instance = instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100af0c0
|
// OFFSET: LEGO1 0x100af0c0
|
||||||
|
@ -67,8 +83,62 @@ long MxOmni::Notify(MxParam &p)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acea0
|
||||||
|
MxObjectFactory *ObjectFactory()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetObjectFactory();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100aceb0
|
||||||
|
MxNotificationManager *NotificationManager()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetNotificationManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acec0
|
||||||
|
MxTickleManager *TickleManager()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetTickleManager();
|
||||||
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100aced0
|
// OFFSET: LEGO1 0x100aced0
|
||||||
MxTimer *Timer()
|
MxTimer *Timer()
|
||||||
{
|
{
|
||||||
return MxOmni::GetInstance()->GetTimer();
|
return MxOmni::GetInstance()->GetTimer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acef0
|
||||||
|
MxStreamer* Streamer()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetStreamer();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acf00
|
||||||
|
MxSoundManager* MSoundManager()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetSoundManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acf10
|
||||||
|
MxVideoManager* MVideoManager()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetVideoManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acf20
|
||||||
|
MxVariableTable* VariableTable()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetVariableTable();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acf30
|
||||||
|
MxMusicManager* MusicManager()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetMusicManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100acf40
|
||||||
|
MxEventManager* EventManager()
|
||||||
|
{
|
||||||
|
return MxOmni::GetInstance()->GetEventManager();
|
||||||
|
}
|
|
@ -35,11 +35,19 @@ class MxOmni : public MxCore
|
||||||
virtual void Init(); // vtable+14
|
virtual void Init(); // vtable+14
|
||||||
virtual MxResult Create(MxOmniCreateParam &p); // vtable+18
|
virtual MxResult Create(MxOmniCreateParam &p); // vtable+18
|
||||||
virtual void Destroy(); // vtable+1c
|
virtual void Destroy(); // vtable+1c
|
||||||
|
static void SetInstance(MxOmni* instance);
|
||||||
|
MxObjectFactory* GetObjectFactory() const { return this->m_objectFactory; }
|
||||||
|
MxNotificationManager* GetNotificationManager() const { return this->m_notificationManager; }
|
||||||
|
MxTickleManager* GetTickleManager() const { return this->m_tickleManager; }
|
||||||
MxTimer* GetTimer() const { return this->m_timer; }
|
MxTimer* GetTimer() const { return this->m_timer; }
|
||||||
|
MxStreamer* GetStreamer() const { return this->m_streamer; }
|
||||||
|
MxSoundManager* GetSoundManager() const { return this->m_soundManager; }
|
||||||
|
MxVideoManager* GetVideoManager() const { return this->m_videoManager; }
|
||||||
|
MxVariableTable* GetVariableTable() const { return this->m_variableTable; }
|
||||||
|
MxMusicManager* GetMusicManager() const { return this->m_musicManager; }
|
||||||
|
MxEventManager* GetEventManager() const { return this->m_eventManager; }
|
||||||
protected:
|
protected:
|
||||||
static MxOmni* m_instance;
|
static MxOmni* g_instance;
|
||||||
|
|
||||||
MxString m_mediaPath; // 0x8
|
MxString m_mediaPath; // 0x8
|
||||||
HWND *m_windowHandle; // 0x18;
|
HWND *m_windowHandle; // 0x18;
|
||||||
|
@ -60,7 +68,12 @@ class MxOmni : public MxCore
|
||||||
|
|
||||||
unsigned char m_unk64; // 0x64
|
unsigned char m_unk64; // 0x64
|
||||||
};
|
};
|
||||||
|
__declspec(dllexport) MxTickleManager * TickleManager();
|
||||||
__declspec(dllexport) MxTimer * Timer();
|
__declspec(dllexport) MxTimer * Timer();
|
||||||
|
__declspec(dllexport) MxStreamer * Streamer();
|
||||||
|
__declspec(dllexport) MxSoundManager * MSoundManager();
|
||||||
|
__declspec(dllexport) MxVariableTable * VariableTable();
|
||||||
|
__declspec(dllexport) MxMusicManager * MusicManager();
|
||||||
|
__declspec(dllexport) MxEventManager * EventManager();
|
||||||
|
|
||||||
#endif // MXOMNI_H
|
#endif // MXOMNI_H
|
||||||
|
|
Loading…
Reference in a new issue