Initial 1.4.2 support.
git-svn-id: http://mc-server.googlecode.com/svn/trunk@1019 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
parent
08a20492ef
commit
9012e834d7
@ -2066,6 +2066,14 @@
|
|||||||
RelativePath="..\source\Protocol\Protocol132.h"
|
RelativePath="..\source\Protocol\Protocol132.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\source\Protocol\Protocol142.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\source\Protocol\Protocol142.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\source\Protocol\ProtocolRecognizer.cpp"
|
RelativePath="..\source\Protocol\ProtocolRecognizer.cpp"
|
||||||
>
|
>
|
||||||
|
112
source/Protocol/Protocol142.cpp
Normal file
112
source/Protocol/Protocol142.cpp
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
|
||||||
|
// Protocol142.cpp
|
||||||
|
|
||||||
|
// Implements the cProtocol142 class representing the release 1.4.2 protocol (#47)
|
||||||
|
|
||||||
|
#include "Globals.h"
|
||||||
|
#include "Protocol142.h"
|
||||||
|
#include "../Root.h"
|
||||||
|
#include "../Server.h"
|
||||||
|
#include "../ClientHandle.h"
|
||||||
|
#include "../../CryptoPP/randpool.h"
|
||||||
|
#include "../Item.h"
|
||||||
|
#include "ChunkDataSerializer.h"
|
||||||
|
#include "../Player.h"
|
||||||
|
#include "../Mobs/Monster.h"
|
||||||
|
#include "../UI/Window.h"
|
||||||
|
#include "../Pickup.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define HANDLE_PACKET_READ(Proc, Type, Var) \
|
||||||
|
Type Var; \
|
||||||
|
{ \
|
||||||
|
if (!m_ReceivedData.Proc(Var)) \
|
||||||
|
{ \
|
||||||
|
return PARSE_INCOMPLETE; \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typedef unsigned char Byte;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
PACKET_UPDATE_TIME = 0x04,
|
||||||
|
PACKET_SOUND_PARTICLE_EFFECT = 0x3d
|
||||||
|
} ;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// cProtocol142:
|
||||||
|
|
||||||
|
cProtocol142::cProtocol142(cClientHandle * a_Client) :
|
||||||
|
super(a_Client)
|
||||||
|
{
|
||||||
|
LOGD("Created cProtocol142 at %p", this);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
cProtocol142::~cProtocol142()
|
||||||
|
{
|
||||||
|
if (!m_DataToSend.empty())
|
||||||
|
{
|
||||||
|
LOGD("There are %d unsent bytes while deleting cProtocol142", m_DataToSend.size());
|
||||||
|
}
|
||||||
|
LOGD("Deleted cProtocol142 at %p", this);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int cProtocol142::ParseLogin(void)
|
||||||
|
{
|
||||||
|
// This packet seems to be back in 1.4.2, no documentation yet.
|
||||||
|
return PARSE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cProtocol142::SendSoundParticleEffect(int a_EffectID, int a_SrcX, int a_SrcY, int a_SrcZ, int a_Data)
|
||||||
|
{
|
||||||
|
cCSLock Lock(m_CSPacket);
|
||||||
|
WriteByte(PACKET_SOUND_PARTICLE_EFFECT);
|
||||||
|
WriteInt (a_EffectID);
|
||||||
|
WriteInt (a_SrcX / 8);
|
||||||
|
WriteByte(a_SrcY / 8);
|
||||||
|
WriteInt (a_SrcZ / 8);
|
||||||
|
WriteInt (a_Data);
|
||||||
|
WriteBool(0);
|
||||||
|
Flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cProtocol142::SendTimeUpdate(Int64 a_WorldTime)
|
||||||
|
{
|
||||||
|
cCSLock Lock(m_CSPacket);
|
||||||
|
WriteByte (PACKET_UPDATE_TIME);
|
||||||
|
WriteInt64(1);
|
||||||
|
WriteInt64(a_WorldTime);
|
||||||
|
Flush();
|
||||||
|
}
|
39
source/Protocol/Protocol142.h
Normal file
39
source/Protocol/Protocol142.h
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
|
||||||
|
// Protocol142.h
|
||||||
|
|
||||||
|
// Interfaces to the cProtocol142 class representing the release 1.4.2 protocol (#47)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "Protocol132.h"
|
||||||
|
#include "../../CryptoPP/modes.h"
|
||||||
|
#include "../../CryptoPP/aes.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class cProtocol142 :
|
||||||
|
public cProtocol132
|
||||||
|
{
|
||||||
|
typedef cProtocol132 super;
|
||||||
|
public:
|
||||||
|
|
||||||
|
cProtocol142(cClientHandle * a_Client);
|
||||||
|
virtual ~cProtocol142();
|
||||||
|
|
||||||
|
// Sending commands (alphabetically sorted):
|
||||||
|
virtual void SendSoundParticleEffect(int a_EffectID, int a_SrcX, int a_SrcY, int a_SrcZ, int a_Data) override;
|
||||||
|
virtual void SendTimeUpdate (Int64 a_WorldTime) override;
|
||||||
|
|
||||||
|
// Specific packet parsers:
|
||||||
|
virtual int ParseLogin (void) override;
|
||||||
|
} ;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -9,6 +9,7 @@
|
|||||||
#include "ProtocolRecognizer.h"
|
#include "ProtocolRecognizer.h"
|
||||||
#include "Protocol125.h"
|
#include "Protocol125.h"
|
||||||
#include "Protocol132.h"
|
#include "Protocol132.h"
|
||||||
|
#include "Protocol142.h"
|
||||||
#include "../ClientHandle.h"
|
#include "../ClientHandle.h"
|
||||||
#include "../Root.h"
|
#include "../Root.h"
|
||||||
#include "../World.h"
|
#include "../World.h"
|
||||||
@ -567,6 +568,11 @@ bool cProtocolRecognizer::TryRecognizeProtocol(void)
|
|||||||
m_Protocol = new cProtocol132(m_Client);
|
m_Protocol = new cProtocol132(m_Client);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
if (ch == PROTO_VERSION_1_4_2)
|
||||||
|
{
|
||||||
|
m_Protocol = new cProtocol142(m_Client);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
m_Protocol = new cProtocol125(m_Client);
|
m_Protocol = new cProtocol125(m_Client);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -18,8 +18,8 @@
|
|||||||
|
|
||||||
|
|
||||||
// Adjust these if a new protocol is added or an old one is removed:
|
// Adjust these if a new protocol is added or an old one is removed:
|
||||||
#define MCS_CLIENT_VERSIONS "1.2.4, 1.2.5, 1.3.1, 1.3.2"
|
#define MCS_CLIENT_VERSIONS "1.2.4, 1.2.5, 1.3.1, 1.3.2, 1.4.2"
|
||||||
#define MCS_PROTOCOL_VERSIONS "29, 39"
|
#define MCS_PROTOCOL_VERSIONS "29, 39, 47"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user