mirror of
				https://github.com/DarkflameUniverse/DarkflameServer.git
				synced 2025-10-21 23:08:07 +00:00 
			
		
		
		
	Entity: fix bad ldf key serialization
This commit is contained in:
		| @@ -704,7 +704,7 @@ void Entity::Initialize() { | |||||||
| 	const Path* path = Game::zoneManager->GetZone()->GetPath(pathName); | 	const Path* path = Game::zoneManager->GetZone()->GetPath(pathName); | ||||||
|  |  | ||||||
| 	//Check to see if we have an attached path and add the appropiate component to handle it: | 	//Check to see if we have an attached path and add the appropiate component to handle it: | ||||||
| 	if (path){ | 	if (path) { | ||||||
| 		// if we have a moving platform path, then we need a moving platform component | 		// if we have a moving platform path, then we need a moving platform component | ||||||
| 		if (path->pathType == PathType::MovingPlatform) { | 		if (path->pathType == PathType::MovingPlatform) { | ||||||
| 			MovingPlatformComponent* plat = new MovingPlatformComponent(this, pathName); | 			MovingPlatformComponent* plat = new MovingPlatformComponent(this, pathName); | ||||||
| @@ -924,10 +924,20 @@ void Entity::WriteBaseReplicaData(RakNet::BitStream* outBitStream, eReplicaPacke | |||||||
| 			outBitStream->Write1(); //ldf data | 			outBitStream->Write1(); //ldf data | ||||||
|  |  | ||||||
| 			RakNet::BitStream settingStream; | 			RakNet::BitStream settingStream; | ||||||
| 			settingStream.Write<uint32_t>(m_Settings.size()); | 			int32_t numberOfValidKeys = m_Settings.size(); | ||||||
|  |  | ||||||
|  | 			// Writing keys value pairs the client does not expect to receive or interpret will result in undefined behavior, | ||||||
|  | 			// so we need to filter out any keys that are not valid and fix the number of valid keys to be correct. | ||||||
|  | 			// TODO should make this more efficient so that we dont waste loops evaluating the same condition twice | ||||||
|  | 			for (LDFBaseData* data : m_Settings) { | ||||||
|  | 				if (!data || data->GetValueType() == eLDFType::LDF_TYPE_UNKNOWN) { | ||||||
|  | 					numberOfValidKeys--; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 			settingStream.Write<uint32_t>(numberOfValidKeys); | ||||||
|  |  | ||||||
| 			for (LDFBaseData* data : m_Settings) { | 			for (LDFBaseData* data : m_Settings) { | ||||||
| 				if (data) { | 				if (data && data->GetValueType() != eLDFType::LDF_TYPE_UNKNOWN) { | ||||||
| 					data->WriteToPacket(&settingStream); | 					data->WriteToPacket(&settingStream); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| @@ -946,7 +956,6 @@ void Entity::WriteBaseReplicaData(RakNet::BitStream* outBitStream, eReplicaPacke | |||||||
|  |  | ||||||
| 			RakNet::BitStream settingStream; | 			RakNet::BitStream settingStream; | ||||||
| 			settingStream.Write<uint32_t>(ldfData.size()); | 			settingStream.Write<uint32_t>(ldfData.size()); | ||||||
|  |  | ||||||
| 			for (LDFBaseData* data : ldfData) { | 			for (LDFBaseData* data : ldfData) { | ||||||
| 				if (data) { | 				if (data) { | ||||||
| 					data->WriteToPacket(&settingStream); | 					data->WriteToPacket(&settingStream); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 David Markowitz
					David Markowitz