mirror of
				https://github.com/isledecomp/isle.git
				synced 2025-10-25 01:14:19 +00:00 
			
		
		
		
	implement LegoOmni::FindByEntityIdOrAtomId (#435)
* push changes * Match and add annotations * Fix annotations --------- Co-authored-by: Christian Semmler <mail@csemmler.com>
This commit is contained in:
		| @@ -28,6 +28,19 @@ public: | |||||||
| 	}; // vtable+0x14
 | 	}; // vtable+0x14
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | // VTABLE: LEGO1 0x100d75b8
 | ||||||
|  | // class MxListCursor<LegoWorld *>
 | ||||||
|  | 
 | ||||||
|  | // VTABLE: LEGO1 0x100d7588
 | ||||||
|  | // class MxPtrListCursor<LegoWorld>
 | ||||||
|  | 
 | ||||||
|  | // VTABLE: LEGO1 0x100d75a0
 | ||||||
|  | // SIZE 0x10
 | ||||||
|  | class LegoWorldListCursor : public MxPtrListCursor<LegoWorld> { | ||||||
|  | public: | ||||||
|  | 	LegoWorldListCursor(LegoWorldList* p_list) : MxPtrListCursor<LegoWorld>(p_list){}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| // TEMPLATE: LEGO1 0x100598f0
 | // TEMPLATE: LEGO1 0x100598f0
 | ||||||
| // MxCollection<LegoWorld *>::Compare
 | // MxCollection<LegoWorld *>::Compare
 | ||||||
| 
 | 
 | ||||||
| @@ -52,4 +65,16 @@ public: | |||||||
| // SYNTHETIC: LEGO1 0x10059be0
 | // SYNTHETIC: LEGO1 0x10059be0
 | ||||||
| // MxPtrList<LegoWorld>::`scalar deleting destructor'
 | // MxPtrList<LegoWorld>::`scalar deleting destructor'
 | ||||||
| 
 | 
 | ||||||
|  | // SYNTHETIC: LEGO1 0x1003e870
 | ||||||
|  | // LegoWorldListCursor::`scalar deleting destructor'
 | ||||||
|  | 
 | ||||||
|  | // FUNCTION: LEGO1 0x1003e8e0
 | ||||||
|  | // MxPtrListCursor<LegoWorld>::~MxPtrListCursor<LegoWorld>
 | ||||||
|  | 
 | ||||||
|  | // FUNCTION: LEGO1 0x1003ea10
 | ||||||
|  | // MxListCursor<LegoWorld *>::~MxListCursor<LegoWorld *>
 | ||||||
|  | 
 | ||||||
|  | // FUNCTION: LEGO1 0x1003ea60
 | ||||||
|  | // LegoWorldListCursor::~LegoWorldListCursor
 | ||||||
|  | 
 | ||||||
| #endif // LEGOWORLDLIST_H
 | #endif // LEGOWORLDLIST_H
 | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ | |||||||
| #include "mxtransitionmanager.h" | #include "mxtransitionmanager.h" | ||||||
| 
 | 
 | ||||||
| DECOMP_SIZE_ASSERT(LegoWorldList, 0x18); | DECOMP_SIZE_ASSERT(LegoWorldList, 0x18); | ||||||
|  | DECOMP_SIZE_ASSERT(LegoWorldListCursor, 0x10); | ||||||
| 
 | 
 | ||||||
| // GLOBAL: LEGO1 0x100f451c
 | // GLOBAL: LEGO1 0x100f451c
 | ||||||
| MxAtomId* g_copterScript = NULL; | MxAtomId* g_copterScript = NULL; | ||||||
| @@ -597,10 +598,20 @@ void LegoOmni::RemoveWorld(const MxAtomId&, MxLong) | |||||||
| 	// TODO
 | 	// TODO
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // STUB: LEGO1 0x1005b0c0
 | // FUNCTION: LEGO1 0x1005b0c0
 | ||||||
| LegoEntity* LegoOmni::FindByEntityIdOrAtomId(const MxAtomId& p_atom, MxS32 p_entityid) | LegoEntity* LegoOmni::FindByEntityIdOrAtomId(const MxAtomId& p_atom, MxS32 p_entityid) | ||||||
| { | { | ||||||
| 	// TODO
 | 	if (m_worldList) { | ||||||
|  | 		LegoWorld* world; | ||||||
|  | 		LegoWorldListCursor cursor(m_worldList); | ||||||
|  | 
 | ||||||
|  | 		while (cursor.Next(world)) { | ||||||
|  | 			if ((p_entityid == -1 || world->GetEntityId() == p_entityid) && | ||||||
|  | 				(!p_atom.GetInternal() || world->GetAtom() == p_atom)) | ||||||
|  | 				return world; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	return NULL; | 	return NULL; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -35,6 +35,7 @@ private: | |||||||
| // class MxListCursor<MxDSAction *>
 | // class MxListCursor<MxDSAction *>
 | ||||||
| 
 | 
 | ||||||
| // VTABLE: LEGO1 0x100d7e50
 | // VTABLE: LEGO1 0x100d7e50
 | ||||||
|  | // SIZE 0x10
 | ||||||
| class MxDSActionListCursor : public MxListCursor<MxDSAction*> { | class MxDSActionListCursor : public MxListCursor<MxDSAction*> { | ||||||
| public: | public: | ||||||
| 	MxDSActionListCursor(MxDSActionList* p_list) : MxListCursor<MxDSAction*>(p_list){}; | 	MxDSActionListCursor(MxDSActionList* p_list) : MxListCursor<MxDSAction*>(p_list){}; | ||||||
|   | |||||||
| @@ -45,6 +45,9 @@ public: | |||||||
| 		return SUCCESS; | 		return SUCCESS; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	inline MxS32 GetEntityId() { return m_mxEntityId; } | ||||||
|  | 	inline MxAtomId& GetAtom() { return m_atom; } | ||||||
|  | 
 | ||||||
| protected: | protected: | ||||||
| 	MxS32 m_mxEntityId; // 0x8
 | 	MxS32 m_mxEntityId; // 0x8
 | ||||||
| 	MxAtomId m_atom;    // 0xc
 | 	MxAtomId m_atom;    // 0xc
 | ||||||
|   | |||||||
| @@ -69,6 +69,7 @@ protected: | |||||||
| 	MxListEntry<T>* InsertEntry(T, MxListEntry<T>*, MxListEntry<T>*); | 	MxListEntry<T>* InsertEntry(T, MxListEntry<T>*, MxListEntry<T>*); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | // SIZE 0x18
 | ||||||
| template <class T> | template <class T> | ||||||
| class MxPtrList : public MxList<T*> { | class MxPtrList : public MxList<T*> { | ||||||
| public: | public: | ||||||
| @@ -82,6 +83,7 @@ public: | |||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | // SIZE 0x10
 | ||||||
| template <class T> | template <class T> | ||||||
| class MxListCursor : public MxCore { | class MxListCursor : public MxCore { | ||||||
| public: | public: | ||||||
| @@ -128,6 +130,7 @@ private: | |||||||
| 	MxListEntry<T>* m_match; // 0x0c
 | 	MxListEntry<T>* m_match; // 0x0c
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | // SIZE 0x10
 | ||||||
| template <class T> | template <class T> | ||||||
| class MxPtrListCursor : public MxListCursor<T*> { | class MxPtrListCursor : public MxListCursor<T*> { | ||||||
| public: | public: | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ public: | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // VTABLE: LEGO1 0x100dc510
 | // VTABLE: LEGO1 0x100dc510
 | ||||||
|  | // SIZE 0x10
 | ||||||
| class MxStreamChunkListCursor : public MxListCursor<MxStreamChunk*> { | class MxStreamChunkListCursor : public MxListCursor<MxStreamChunk*> { | ||||||
| public: | public: | ||||||
| 	MxStreamChunkListCursor(MxStreamChunkList* p_list) : MxListCursor<MxStreamChunk*>(p_list){}; | 	MxStreamChunkListCursor(MxStreamChunkList* p_list) : MxListCursor<MxStreamChunk*>(p_list){}; | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ | |||||||
| class MxStringList : public MxList<MxString> {}; | class MxStringList : public MxList<MxString> {}; | ||||||
| 
 | 
 | ||||||
| // VTABLE: LEGO1 0x100dd058
 | // VTABLE: LEGO1 0x100dd058
 | ||||||
|  | // SIZE 0x10
 | ||||||
| class MxStringListCursor : public MxListCursor<MxString> { | class MxStringListCursor : public MxListCursor<MxString> { | ||||||
| public: | public: | ||||||
| 	MxStringListCursor(MxStringList* p_list) : MxListCursor<MxString>(p_list){}; | 	MxStringListCursor(MxStringList* p_list) : MxListCursor<MxString>(p_list){}; | ||||||
|   | |||||||
| @@ -5,6 +5,8 @@ | |||||||
| #include "mxvariabletable.h" | #include "mxvariabletable.h" | ||||||
| 
 | 
 | ||||||
| DECOMP_SIZE_ASSERT(MxDSSelectAction, 0xb0) | DECOMP_SIZE_ASSERT(MxDSSelectAction, 0xb0) | ||||||
|  | DECOMP_SIZE_ASSERT(MxStringList, 0x18) | ||||||
|  | DECOMP_SIZE_ASSERT(MxStringListCursor, 0x10) | ||||||
| DECOMP_SIZE_ASSERT(MxListEntry<MxString>, 0x18) | DECOMP_SIZE_ASSERT(MxListEntry<MxString>, 0x18) | ||||||
| 
 | 
 | ||||||
| // FUNCTION: LEGO1 0x100cb2b0
 | // FUNCTION: LEGO1 0x100cb2b0
 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Misha
					Misha