mirror of
				https://github.com/isledecomp/isle.git
				synced 2025-10-25 09:24:17 +00: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:
		| @@ -15,7 +15,14 @@ LegoOmni::~LegoOmni() | ||||
| // OFFSET: LEGO1 0x1005ad10
 | ||||
| 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
 | ||||
| @@ -30,7 +37,6 @@ LegoSoundManager *SoundManager() | ||||
|   return LegoOmni::GetInstance()->GetSoundManager(); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x10015720
 | ||||
| LegoVideoManager *VideoManager() | ||||
| { | ||||
| @@ -79,6 +85,13 @@ LegoNavController *NavController() | ||||
|   return LegoOmni::GetInstance()->GetNavController(); | ||||
| } | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x10015900
 | ||||
| MxTransitionManager *TransitionManager() | ||||
| { | ||||
|   return LegoOmni::GetInstance()->GetTransitionManager(); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x1005b5f0
 | ||||
| long LegoOmni::Notify(MxParam &p) | ||||
| { | ||||
|   | ||||
| @@ -71,6 +71,7 @@ public: | ||||
|   LegoPlantManager *GetLegoPlantManager() { return m_plantManager; } | ||||
|   LegoGameState *GetGameState() { return m_gameState; } | ||||
|   LegoNavController *GetNavController() { return m_navController; } | ||||
|   MxTransitionManager *GetTransitionManager() { return m_transitionManager; } | ||||
| 
 | ||||
| private: | ||||
|   int m_unk68; | ||||
| @@ -84,7 +85,7 @@ private: | ||||
|   char m_unk94[0x4]; | ||||
|   LegoBuildingManager* m_buildingManager; // 0x98
 | ||||
|   LegoGameState *m_gameState; // 0x9c
 | ||||
|   char m_unka0[0x94]; | ||||
|   MxDSAction m_action; | ||||
|   MxBackgroundAudioManager *m_bkgAudioManager; // 0x134
 | ||||
|   MxTransitionManager *m_transitionManager; // 0x138
 | ||||
|   int m_unk13c; | ||||
| @@ -93,26 +94,19 @@ private: | ||||
| 
 | ||||
| __declspec(dllexport) MxBackgroundAudioManager * BackgroundAudioManager(); | ||||
| __declspec(dllexport) MxDSObject * CreateStreamObject(MxDSFile *,short); | ||||
| __declspec(dllexport) MxEventManager * EventManager(); | ||||
| __declspec(dllexport) LegoGameState * GameState(); | ||||
| __declspec(dllexport) const char * GetNoCD_SourceName(); | ||||
| __declspec(dllexport) LegoInputManager * InputManager(); | ||||
| __declspec(dllexport) LegoOmni * Lego(); | ||||
| __declspec(dllexport) MxSoundManager * MSoundManager(); | ||||
| __declspec(dllexport) void MakeSourceName(char *, const char *); | ||||
| __declspec(dllexport) MxMusicManager * MusicManager(); | ||||
| __declspec(dllexport) MxNotificationManager * NotificationManager(); | ||||
| __declspec(dllexport) LegoEntity * PickEntity(long,long); | ||||
| __declspec(dllexport) LegoROI * PickROI(long,long); | ||||
| __declspec(dllexport) void SetOmniUserMessage(void (*)(const char *,int)); | ||||
| __declspec(dllexport) LegoSoundManager * SoundManager(); | ||||
| __declspec(dllexport) long Start(MxDSAction *); | ||||
| __declspec(dllexport) MxStreamer * Streamer(); | ||||
| __declspec(dllexport) MxTickleManager * TickleManager(); | ||||
| __declspec(dllexport) MxTransitionManager * TransitionManager(); | ||||
| __declspec(dllexport) MxVariableTable * VariableTable(); | ||||
| __declspec(dllexport) LegoVideoManager * VideoManager(); | ||||
| 
 | ||||
| __declspec(dllexport) long Start(MxDSAction *a); | ||||
| 
 | ||||
| LegoBuildingManager* BuildingManager(); | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| #include "mxomni.h" | ||||
| 
 | ||||
| // 0x101015b0
 | ||||
| MxOmni* MxOmni::m_instance = NULL; | ||||
| MxOmni *MxOmni::g_instance = NULL; | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x100aef10
 | ||||
| MxOmni::MxOmni() | ||||
| @@ -33,10 +33,26 @@ void MxOmni::Init() | ||||
|   m_unk64 = NULL; | ||||
| } | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x100b0690
 | ||||
| void MxOmni::DestroyInstance() | ||||
| { | ||||
|   if (g_instance != NULL) | ||||
|   { | ||||
|     delete g_instance; | ||||
|     g_instance = NULL; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x100b0680
 | ||||
| MxOmni *MxOmni::GetInstance() | ||||
| { | ||||
|   return m_instance; | ||||
|   return g_instance; | ||||
| } | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x100af0b0
 | ||||
| void MxOmni::SetInstance(MxOmni *instance) | ||||
| { | ||||
|   g_instance = instance; | ||||
| } | ||||
| 
 | ||||
| // OFFSET: LEGO1 0x100af0c0
 | ||||
| @@ -67,8 +83,62 @@ long MxOmni::Notify(MxParam &p) | ||||
|   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
 | ||||
| MxTimer *Timer() | ||||
| { | ||||
|   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 @@ public: | ||||
|   virtual void Init(); // vtable+14
 | ||||
|   virtual MxResult Create(MxOmniCreateParam &p); // vtable+18
 | ||||
|   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; } | ||||
| 
 | ||||
|   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: | ||||
|   static MxOmni* m_instance; | ||||
|   static MxOmni* g_instance; | ||||
| 
 | ||||
|   MxString m_mediaPath; // 0x8
 | ||||
|   HWND *m_windowHandle; // 0x18;
 | ||||
| @@ -60,7 +68,12 @@ protected: | ||||
| 
 | ||||
|   unsigned char m_unk64; // 0x64
 | ||||
| }; | ||||
| 
 | ||||
| __declspec(dllexport) MxTickleManager * TickleManager(); | ||||
| __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
 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 MishaProductions
					MishaProductions