client/UserInterface/PythonNetworkStreamPhaseGam...

4428 lines
116 KiB
C++
Raw Normal View History

#include "StdAfx.h"
#include "PythonNetworkStream.h"
#include "Packet.h"
#include "PythonGuild.h"
#include "PythonCharacterManager.h"
#include "PythonPlayer.h"
#include "PythonBackground.h"
#include "PythonMiniMap.h"
#include "PythonTextTail.h"
#include "PythonItem.h"
#include "PythonChat.h"
#include "PythonShop.h"
#include "PythonExchange.h"
#include "PythonQuest.h"
#include "PythonEventManager.h"
#include "PythonMessenger.h"
#include "PythonApplication.h"
#include "../EterPack/EterPackManager.h"
#include "../gamelib/ItemManager.h"
#include "AbstractApplication.h"
#include "AbstractCharacterManager.h"
#include "InstanceBase.h"
#include "ProcessCRC.h"
BOOL gs_bEmpireLanuageEnable = TRUE;
void CPythonNetworkStream::__RefreshAlignmentWindow()
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshAlignment", Py_BuildValue("()"));
}
void CPythonNetworkStream::__RefreshTargetBoardByVID(DWORD dwVID)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshTargetBoardByVID", Py_BuildValue("(i)", dwVID));
}
void CPythonNetworkStream::__RefreshTargetBoardByName(const char * c_szName)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshTargetBoardByName", Py_BuildValue("(s)", c_szName));
}
void CPythonNetworkStream::__RefreshTargetBoard()
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshTargetBoard", Py_BuildValue("()"));
}
void CPythonNetworkStream::__RefreshGuildWindowGradePage()
{
m_isRefreshGuildWndGradePage=true;
}
void CPythonNetworkStream::__RefreshGuildWindowSkillPage()
{
m_isRefreshGuildWndSkillPage=true;
}
void CPythonNetworkStream::__RefreshGuildWindowMemberPageGradeComboBox()
{
m_isRefreshGuildWndMemberPageGradeComboBox=true;
}
void CPythonNetworkStream::__RefreshGuildWindowMemberPage()
{
m_isRefreshGuildWndMemberPage=true;
}
void CPythonNetworkStream::__RefreshGuildWindowBoardPage()
{
m_isRefreshGuildWndBoardPage=true;
}
void CPythonNetworkStream::__RefreshGuildWindowInfoPage()
{
m_isRefreshGuildWndInfoPage=true;
}
void CPythonNetworkStream::__RefreshMessengerWindow()
{
m_isRefreshMessengerWnd=true;
}
void CPythonNetworkStream::__RefreshSafeboxWindow()
{
m_isRefreshSafeboxWnd=true;
}
void CPythonNetworkStream::__RefreshMallWindow()
{
m_isRefreshMallWnd=true;
}
void CPythonNetworkStream::__RefreshSkillWindow()
{
m_isRefreshSkillWnd=true;
}
void CPythonNetworkStream::__RefreshExchangeWindow()
{
m_isRefreshExchangeWnd=true;
}
void CPythonNetworkStream::__RefreshStatus()
{
m_isRefreshStatus=true;
}
void CPythonNetworkStream::__RefreshCharacterWindow()
{
m_isRefreshCharacterWnd=true;
}
void CPythonNetworkStream::__RefreshInventoryWindow()
{
m_isRefreshInventoryWnd=true;
}
void CPythonNetworkStream::__RefreshEquipmentWindow()
{
m_isRefreshEquipmentWnd=true;
}
void CPythonNetworkStream::__SetGuildID(DWORD id)
{
if (m_dwGuildID != id)
{
m_dwGuildID = id;
IAbstractPlayer& rkPlayer = IAbstractPlayer::GetSingleton();
for (int i = 0; i < PLAYER_PER_ACCOUNT4; ++i)
if (!strncmp(m_akSimplePlayerInfo[i].szName, rkPlayer.GetName(), CHARACTER_NAME_MAX_LEN))
{
m_adwGuildID[i] = id;
std::string guildName;
if (CPythonGuild::Instance().GetGuildName(id, &guildName))
{
m_astrGuildName[i] = guildName;
}
else
{
m_astrGuildName[i] = "";
}
}
}
}
struct PERF_PacketInfo
{
DWORD dwCount;
DWORD dwTime;
PERF_PacketInfo()
{
dwCount=0;
dwTime=0;
}
};
#ifdef __PERFORMANCE_CHECK__
class PERF_PacketTimeAnalyzer
{
public:
~PERF_PacketTimeAnalyzer()
{
FILE* fp=fopen("perf_dispatch_packet_result.txt", "w");
for (std::map<DWORD, PERF_PacketInfo>::iterator i=m_kMap_kPacketInfo.begin(); i!=m_kMap_kPacketInfo.end(); ++i)
{
if (i->second.dwTime>0)
fprintf(fp, "header %d: count %d, time %d, tpc %d\n", i->first, i->second.dwCount, i->second.dwTime, i->second.dwTime/i->second.dwCount);
}
fclose(fp);
}
public:
std::map<DWORD, PERF_PacketInfo> m_kMap_kPacketInfo;
};
PERF_PacketTimeAnalyzer gs_kPacketTimeAnalyzer;
#endif
// Game Phase ---------------------------------------------------------------------------
void CPythonNetworkStream::GamePhase()
{
if (!m_kQue_stHack.empty())
{
__SendHack(m_kQue_stHack.front().c_str());
m_kQue_stHack.pop_front();
}
TPacketHeader header = 0;
bool ret = true;
#ifdef __PERFORMANCE_CHECK__
DWORD timeBeginDispatch=timeGetTime();
static std::map<DWORD, PERF_PacketInfo> kMap_kPacketInfo;
kMap_kPacketInfo.clear();
#endif
const DWORD MAX_RECV_COUNT = 4;
const DWORD SAFE_RECV_BUFSIZE = 8192;
DWORD dwRecvCount = 0;
while (ret)
{
if(dwRecvCount++ >= MAX_RECV_COUNT-1 && GetRecvBufferSize() < SAFE_RECV_BUFSIZE
&& m_strPhase == "Game") //phase_game <20><> <20>ƴϾ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><20>ִ<EFBFBD>.
break;
if (!CheckPacket(&header))
break;
#ifdef __PERFORMANCE_CHECK__
DWORD timeBeginPacket=timeGetTime();
#endif
switch (header)
{
case HEADER_GC_OBSERVER_ADD:
ret = RecvObserverAddPacket();
break;
case HEADER_GC_OBSERVER_REMOVE:
ret = RecvObserverRemovePacket();
break;
case HEADER_GC_OBSERVER_MOVE:
ret = RecvObserverMovePacket();
break;
case HEADER_GC_WARP:
ret = RecvWarpPacket();
break;
case HEADER_GC_PHASE:
ret = RecvPhasePacket();
return; // <20><><EFBFBD>߿<EFBFBD> Phase <20><> <20>ٲ<EFBFBD><D9B2><EFBFBD> <20>ϴ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> GamePhase Ż<><C5BB> - [levites]
break;
case HEADER_GC_PVP:
ret = RecvPVPPacket();
break;
case HEADER_GC_DUEL_START:
ret = RecvDuelStartPacket();
break;
case HEADER_GC_CHARACTER_ADD:
ret = RecvCharacterAppendPacket();
break;
case HEADER_GC_CHAR_ADDITIONAL_INFO:
ret = RecvCharacterAdditionalInfo();
break;
case HEADER_GC_CHARACTER_ADD2:
ret = RecvCharacterAppendPacketNew();
break;
case HEADER_GC_CHARACTER_UPDATE:
ret = RecvCharacterUpdatePacket();
break;
case HEADER_GC_CHARACTER_UPDATE2:
ret = RecvCharacterUpdatePacketNew();
break;
case HEADER_GC_CHARACTER_DEL:
ret = RecvCharacterDeletePacket();
break;
case HEADER_GC_CHAT:
ret = RecvChatPacket();
break;
case HEADER_GC_SYNC_POSITION:
ret = RecvSyncPositionPacket();
break;
case HEADER_GC_OWNERSHIP:
ret = RecvOwnerShipPacket();
break;
case HEADER_GC_WHISPER:
ret = RecvWhisperPacket();
break;
case HEADER_GC_CHARACTER_MOVE:
ret = RecvCharacterMovePacket();
break;
// Position
case HEADER_GC_CHARACTER_POSITION:
ret = RecvCharacterPositionPacket();
break;
// Battle Packet
case HEADER_GC_STUN:
ret = RecvStunPacket();
break;
case HEADER_GC_DEAD:
ret = RecvDeadPacket();
break;
case HEADER_GC_PLAYER_POINT_CHANGE:
ret = RecvPointChange();
break;
// item packet.
case HEADER_GC_ITEM_SET:
ret = RecvItemSetPacket();
break;
case HEADER_GC_ITEM_SET2:
ret = RecvItemSetPacket2();
break;
case HEADER_GC_ITEM_USE:
ret = RecvItemUsePacket();
break;
case HEADER_GC_ITEM_UPDATE:
ret = RecvItemUpdatePacket();
break;
case HEADER_GC_ITEM_GROUND_ADD:
ret = RecvItemGroundAddPacket();
break;
case HEADER_GC_ITEM_GROUND_DEL:
ret = RecvItemGroundDelPacket();
break;
case HEADER_GC_ITEM_OWNERSHIP:
ret = RecvItemOwnership();
break;
case HEADER_GC_QUICKSLOT_ADD:
ret = RecvQuickSlotAddPacket();
break;
case HEADER_GC_QUICKSLOT_DEL:
ret = RecvQuickSlotDelPacket();
break;
case HEADER_GC_QUICKSLOT_SWAP:
ret = RecvQuickSlotMovePacket();
break;
case HEADER_GC_MOTION:
ret = RecvMotionPacket();
break;
case HEADER_GC_SHOP:
ret = RecvShopPacket();
break;
case HEADER_GC_SHOP_SIGN:
ret = RecvShopSignPacket();
break;
case HEADER_GC_EXCHANGE:
ret = RecvExchangePacket();
break;
case HEADER_GC_QUEST_INFO:
ret = RecvQuestInfoPacket();
break;
case HEADER_GC_REQUEST_MAKE_GUILD:
ret = RecvRequestMakeGuild();
break;
case HEADER_GC_PING:
ret = RecvPingPacket();
break;
case HEADER_GC_SCRIPT:
ret = RecvScriptPacket();
break;
case HEADER_GC_QUEST_CONFIRM:
ret = RecvQuestConfirmPacket();
break;
case HEADER_GC_TARGET:
ret = RecvTargetPacket();
break;
case HEADER_GC_DAMAGE_INFO:
ret = RecvDamageInfoPacket();
break;
case HEADER_GC_MOUNT:
ret = RecvMountPacket();
break;
case HEADER_GC_CHANGE_SPEED:
ret = RecvChangeSpeedPacket();
break;
case HEADER_GC_PLAYER_POINTS:
ret = __RecvPlayerPoints();
break;
case HEADER_GC_CREATE_FLY:
ret = RecvCreateFlyPacket();
break;
case HEADER_GC_FLY_TARGETING:
ret = RecvFlyTargetingPacket();
break;
case HEADER_GC_ADD_FLY_TARGETING:
ret = RecvAddFlyTargetingPacket();
break;
case HEADER_GC_SKILL_LEVEL:
ret = RecvSkillLevel();
break;
case HEADER_GC_SKILL_LEVEL_NEW:
ret = RecvSkillLevelNew();
break;
case HEADER_GC_MESSENGER:
ret = RecvMessenger();
break;
case HEADER_GC_GUILD:
ret = RecvGuild();
break;
case HEADER_GC_PARTY_INVITE:
ret = RecvPartyInvite();
break;
case HEADER_GC_PARTY_ADD:
ret = RecvPartyAdd();
break;
case HEADER_GC_PARTY_UPDATE:
ret = RecvPartyUpdate();
break;
case HEADER_GC_PARTY_REMOVE:
ret = RecvPartyRemove();
break;
case HEADER_GC_PARTY_LINK:
ret = RecvPartyLink();
break;
case HEADER_GC_PARTY_UNLINK:
ret = RecvPartyUnlink();
break;
case HEADER_GC_PARTY_PARAMETER:
ret = RecvPartyParameter();
break;
case HEADER_GC_SAFEBOX_SET:
ret = RecvSafeBoxSetPacket();
break;
case HEADER_GC_SAFEBOX_DEL:
ret = RecvSafeBoxDelPacket();
break;
case HEADER_GC_SAFEBOX_WRONG_PASSWORD:
ret = RecvSafeBoxWrongPasswordPacket();
break;
case HEADER_GC_SAFEBOX_SIZE:
ret = RecvSafeBoxSizePacket();
break;
case HEADER_GC_SAFEBOX_MONEY_CHANGE:
ret = RecvSafeBoxMoneyChangePacket();
break;
case HEADER_GC_FISHING:
ret = RecvFishing();
break;
case HEADER_GC_DUNGEON:
ret = RecvDungeon();
break;
case HEADER_GC_TIME:
ret = RecvTimePacket();
break;
case HEADER_GC_WALK_MODE:
ret = RecvWalkModePacket();
break;
case HEADER_GC_CHANGE_SKILL_GROUP:
ret = RecvChangeSkillGroupPacket();
break;
case HEADER_GC_REFINE_INFORMATION:
ret = RecvRefineInformationPacket();
break;
case HEADER_GC_REFINE_INFORMATION_NEW:
ret = RecvRefineInformationPacketNew();
break;
case HEADER_GC_SEPCIAL_EFFECT:
ret = RecvSpecialEffect();
break;
case HEADER_GC_NPC_POSITION:
ret = RecvNPCList();
break;
case HEADER_GC_CHANNEL:
ret = RecvChannelPacket();
break;
case HEADER_GC_VIEW_EQUIP:
ret = RecvViewEquipPacket();
break;
case HEADER_GC_LAND_LIST:
ret = RecvLandPacket();
break;
//case HEADER_GC_TARGET_CREATE:
// ret = RecvTargetCreatePacket();
// break;
case HEADER_GC_TARGET_CREATE_NEW:
ret = RecvTargetCreatePacketNew();
break;
case HEADER_GC_TARGET_UPDATE:
ret = RecvTargetUpdatePacket();
break;
case HEADER_GC_TARGET_DELETE:
ret = RecvTargetDeletePacket();
break;
case HEADER_GC_AFFECT_ADD:
ret = RecvAffectAddPacket();
break;
case HEADER_GC_AFFECT_REMOVE:
ret = RecvAffectRemovePacket();
break;
case HEADER_GC_MALL_OPEN:
ret = RecvMallOpenPacket();
break;
case HEADER_GC_MALL_SET:
ret = RecvMallItemSetPacket();
break;
case HEADER_GC_MALL_DEL:
ret = RecvMallItemDelPacket();
break;
case HEADER_GC_LOVER_INFO:
ret = RecvLoverInfoPacket();
break;
case HEADER_GC_LOVE_POINT_UPDATE:
ret = RecvLovePointUpdatePacket();
break;
case HEADER_GC_DIG_MOTION:
ret = RecvDigMotionPacket();
break;
case HEADER_GC_HANDSHAKE:
RecvHandshakePacket();
return;
break;
case HEADER_GC_HANDSHAKE_OK:
RecvHandshakeOKPacket();
return;
break;
case HEADER_GC_HYBRIDCRYPT_KEYS:
RecvHybridCryptKeyPacket();
return;
break;
case HEADER_GC_HYBRIDCRYPT_SDB:
RecvHybridCryptSDBPacket();
return;
break;
case HEADER_GC_HS_REQUEST:
ret = RecvHSCheckRequest();
break;
case HEADER_GC_XTRAP_CS1_REQUEST:
ret = RecvXTrapVerifyRequest();
break;
case HEADER_GC_SPECIFIC_EFFECT:
ret = RecvSpecificEffect();
break;
case HEADER_GC_DRAGON_SOUL_REFINE:
ret = RecvDragonSoulRefine();
break;
default:
ret = RecvDefaultPacket(header);
break;
}
#ifdef __PERFORMANCE_CHECK__
DWORD timeEndPacket=timeGetTime();
{
PERF_PacketInfo& rkPacketInfo=kMap_kPacketInfo[header];
rkPacketInfo.dwCount++;
rkPacketInfo.dwTime+=timeEndPacket-timeBeginPacket;
}
{
PERF_PacketInfo& rkPacketInfo=gs_kPacketTimeAnalyzer.m_kMap_kPacketInfo[header];
rkPacketInfo.dwCount++;
rkPacketInfo.dwTime+=timeEndPacket-timeBeginPacket;
}
#endif
}
#ifdef __PERFORMANCE_CHECK__
DWORD timeEndDispatch=timeGetTime();
if (timeEndDispatch-timeBeginDispatch>2)
{
static FILE* fp=fopen("perf_dispatch_packet.txt", "w");
fprintf(fp, "delay %d\n", timeEndDispatch-timeBeginDispatch);
for (std::map<DWORD, PERF_PacketInfo>::iterator i=kMap_kPacketInfo.begin(); i!=kMap_kPacketInfo.end(); ++i)
{
if (i->second.dwTime>0)
fprintf(fp, "header %d: count %d, time %d\n", i->first, i->second.dwCount, i->second.dwTime);
}
fputs("=====================================================\n", fp);
fflush(fp);
}
#endif
if (!ret)
RecvErrorPacket(header);
static DWORD s_nextRefreshTime = ELTimer_GetMSec();
DWORD curTime = ELTimer_GetMSec();
if (s_nextRefreshTime > curTime)
return;
if (m_isRefreshCharacterWnd)
{
m_isRefreshCharacterWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshCharacter", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshEquipmentWnd)
{
m_isRefreshEquipmentWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshEquipment", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshInventoryWnd)
{
m_isRefreshInventoryWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshInventory", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshExchangeWnd)
{
m_isRefreshExchangeWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshExchange", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshSkillWnd)
{
m_isRefreshSkillWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshSkill", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshSafeboxWnd)
{
m_isRefreshSafeboxWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshSafebox", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshMallWnd)
{
m_isRefreshMallWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshMall", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshStatus)
{
m_isRefreshStatus=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshStatus", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshMessengerWnd)
{
m_isRefreshMessengerWnd=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshMessenger", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshGuildWndInfoPage)
{
m_isRefreshGuildWndInfoPage=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildInfoPage", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshGuildWndBoardPage)
{
m_isRefreshGuildWndBoardPage=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildBoardPage", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshGuildWndMemberPage)
{
m_isRefreshGuildWndMemberPage=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildMemberPage", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshGuildWndMemberPageGradeComboBox)
{
m_isRefreshGuildWndMemberPageGradeComboBox=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildMemberPageGradeComboBox", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshGuildWndSkillPage)
{
m_isRefreshGuildWndSkillPage=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildSkillPage", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
if (m_isRefreshGuildWndGradePage)
{
m_isRefreshGuildWndGradePage=false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildGradePage", Py_BuildValue("()"));
s_nextRefreshTime = curTime + 300;
}
}
void CPythonNetworkStream::__InitializeGamePhase()
{
__ServerTimeSync_Initialize();
m_isRefreshStatus=false;
m_isRefreshCharacterWnd=false;
m_isRefreshEquipmentWnd=false;
m_isRefreshInventoryWnd=false;
m_isRefreshExchangeWnd=false;
m_isRefreshSkillWnd=false;
m_isRefreshSafeboxWnd=false;
m_isRefreshMallWnd=false;
m_isRefreshMessengerWnd=false;
m_isRefreshGuildWndInfoPage=false;
m_isRefreshGuildWndBoardPage=false;
m_isRefreshGuildWndMemberPage=false;
m_isRefreshGuildWndMemberPageGradeComboBox=false;
m_isRefreshGuildWndSkillPage=false;
m_isRefreshGuildWndGradePage=false;
m_EmoticonStringVector.clear();
m_pInstTarget = NULL;
}
void CPythonNetworkStream::Warp(LONG lGlobalX, LONG lGlobalY)
{
CPythonBackground& rkBgMgr=CPythonBackground::Instance();
rkBgMgr.Destroy();
rkBgMgr.Create();
rkBgMgr.Warp(lGlobalX, lGlobalY);
//rkBgMgr.SetShadowLevel(CPythonBackground::SHADOW_ALL);
rkBgMgr.RefreshShadowLevel();
// NOTE : Warp <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> CenterPosition<6F><6E> Height<68><74> 0<>̱<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ī<>޶<EFBFBD><DEB6><EFBFBD> <20><><EFBFBD>ٴڿ<D9B4> <20><><EFBFBD><EFBFBD><EFBFBD>ְ<EFBFBD> <20><>
// <20><><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD><EFBFBD> Height<68><74> <20><><EFBFBD><EFBFBD> <20>DZ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>̹Ƿ<CCB9> <20><><EFBFBD><EFBFBD> <20>̵<EFBFBD><CCB5>ϸ<EFBFBD> Position<6F><6E> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ѹ<EFBFBD>
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ش<EFBFBD> - [levites]
LONG lLocalX = lGlobalX;
LONG lLocalY = lGlobalY;
__GlobalPositionToLocalPosition(lLocalX, lLocalY);
float fHeight = CPythonBackground::Instance().GetHeight(float(lLocalX), float(lLocalY));
IAbstractApplication& rkApp=IAbstractApplication::GetSingleton();
rkApp.SetCenterPosition(float(lLocalX), float(lLocalY), fHeight);
__ShowMapName(lLocalX, lLocalY);
}
void CPythonNetworkStream::__ShowMapName(LONG lLocalX, LONG lLocalY)
{
const std::string & c_rstrMapFileName = CPythonBackground::Instance().GetWarpMapName();
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "ShowMapName", Py_BuildValue("(sii)", c_rstrMapFileName.c_str(), lLocalX, lLocalY));
}
void CPythonNetworkStream::__LeaveGamePhase()
{
CInstanceBase::ClearPVPKeySystem();
__ClearNetworkActorManager();
m_bComboSkillFlag = FALSE;
IAbstractCharacterManager& rkChrMgr=IAbstractCharacterManager::GetSingleton();
rkChrMgr.Destroy();
CPythonItem& rkItemMgr=CPythonItem::Instance();
rkItemMgr.Destroy();
}
void CPythonNetworkStream::SetGamePhase()
{
if ("Game"!=m_strPhase)
m_phaseLeaveFunc.Run();
Tracen("");
Tracen("## Network - Game Phase ##");
Tracen("");
m_strPhase = "Game";
m_dwChangingPhaseTime = ELTimer_GetMSec();
m_phaseProcessFunc.Set(this, &CPythonNetworkStream::GamePhase);
m_phaseLeaveFunc.Set(this, &CPythonNetworkStream::__LeaveGamePhase);
// Main Character <20><><EFBFBD><EFBFBD>O
IAbstractPlayer & rkPlayer = IAbstractPlayer::GetSingleton();
rkPlayer.SetMainCharacterIndex(GetMainActorVID());
__RefreshStatus();
}
bool CPythonNetworkStream::RecvObserverAddPacket()
{
TPacketGCObserverAdd kObserverAddPacket;
if (!Recv(sizeof(kObserverAddPacket), &kObserverAddPacket))
return false;
CPythonMiniMap::Instance().AddObserver(
kObserverAddPacket.vid,
kObserverAddPacket.x*100.0f,
kObserverAddPacket.y*100.0f);
return true;
}
bool CPythonNetworkStream::RecvObserverRemovePacket()
{
TPacketGCObserverAdd kObserverRemovePacket;
if (!Recv(sizeof(kObserverRemovePacket), &kObserverRemovePacket))
return false;
CPythonMiniMap::Instance().RemoveObserver(
kObserverRemovePacket.vid
);
return true;
}
bool CPythonNetworkStream::RecvObserverMovePacket()
{
TPacketGCObserverMove kObserverMovePacket;
if (!Recv(sizeof(kObserverMovePacket), &kObserverMovePacket))
return false;
CPythonMiniMap::Instance().MoveObserver(
kObserverMovePacket.vid,
kObserverMovePacket.x*100.0f,
kObserverMovePacket.y*100.0f);
return true;
}
bool CPythonNetworkStream::RecvWarpPacket()
{
TPacketGCWarp kWarpPacket;
if (!Recv(sizeof(kWarpPacket), &kWarpPacket))
return false;
__DirectEnterMode_Set(m_dwSelectedCharacterIndex);
CNetworkStream::Connect((DWORD)kWarpPacket.lAddr, kWarpPacket.wPort);
return true;
}
bool CPythonNetworkStream::RecvDuelStartPacket()
{
TPacketGCDuelStart kDuelStartPacket;
if (!Recv(sizeof(kDuelStartPacket), &kDuelStartPacket))
return false;
DWORD count = (kDuelStartPacket.wSize - sizeof(kDuelStartPacket))/sizeof(DWORD);
CPythonCharacterManager & rkChrMgr = CPythonCharacterManager::Instance();
CInstanceBase* pkInstMain=rkChrMgr.GetMainInstancePtr();
if (!pkInstMain)
{
TraceError("CPythonNetworkStream::RecvDuelStartPacket - MainCharacter is NULL");
return false;
}
DWORD dwVIDSrc = pkInstMain->GetVirtualID();
DWORD dwVIDDest;
for ( DWORD i = 0; i < count; i++)
{
Recv(sizeof(dwVIDDest),&dwVIDDest);
CInstanceBase::InsertDUELKey(dwVIDSrc,dwVIDDest);
}
if(count == 0)
pkInstMain->SetDuelMode(CInstanceBase::DUEL_CANNOTATTACK);
else
pkInstMain->SetDuelMode(CInstanceBase::DUEL_START);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "CloseTargetBoard", Py_BuildValue("()"));
rkChrMgr.RefreshAllPCTextTail();
return true;
}
bool CPythonNetworkStream::RecvPVPPacket()
{
TPacketGCPVP kPVPPacket;
if (!Recv(sizeof(kPVPPacket), &kPVPPacket))
return false;
CPythonCharacterManager & rkChrMgr = CPythonCharacterManager::Instance();
CPythonPlayer & rkPlayer = CPythonPlayer::Instance();
switch (kPVPPacket.bMode)
{
case PVP_MODE_AGREE:
rkChrMgr.RemovePVPKey(kPVPPacket.dwVIDSrc, kPVPPacket.dwVIDDst);
// <20><><EFBFBD><20><>(Dst)<29><><EFBFBD><EFBFBD> <20><><EFBFBD>Ǹ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if (rkPlayer.IsMainCharacterIndex(kPVPPacket.dwVIDDst))
rkPlayer.RememberChallengeInstance(kPVPPacket.dwVIDSrc);
// <20><><EFBFBD><EFBFBD><EBBFA1> <20><><EFBFBD>Ǹ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ȿ<EFBFBD><C8BF><EFBFBD> <20><><EFBFBD><EFBFBD> <20>Ҵ<EFBFBD>
if (rkPlayer.IsMainCharacterIndex(kPVPPacket.dwVIDSrc))
rkPlayer.RememberCantFightInstance(kPVPPacket.dwVIDDst);
break;
case PVP_MODE_REVENGE:
{
rkChrMgr.RemovePVPKey(kPVPPacket.dwVIDSrc, kPVPPacket.dwVIDDst);
DWORD dwKiller = kPVPPacket.dwVIDSrc;
DWORD dwVictim = kPVPPacket.dwVIDDst;
// <20><>(victim)<29><> <20><><EFBFBD><EFBFBD><EBBFA1> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if (rkPlayer.IsMainCharacterIndex(dwVictim))
rkPlayer.RememberRevengeInstance(dwKiller);
// <20><><EFBFBD><EFBFBD>(victim)<29><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϴ<EFBFBD> <20><><EFBFBD>ȿ<EFBFBD><C8BF><EFBFBD> <20><><EFBFBD><EFBFBD> <20>Ҵ<EFBFBD>
if (rkPlayer.IsMainCharacterIndex(dwKiller))
rkPlayer.RememberCantFightInstance(dwVictim);
break;
}
case PVP_MODE_FIGHT:
rkChrMgr.InsertPVPKey(kPVPPacket.dwVIDSrc, kPVPPacket.dwVIDDst);
rkPlayer.ForgetInstance(kPVPPacket.dwVIDSrc);
rkPlayer.ForgetInstance(kPVPPacket.dwVIDDst);
break;
case PVP_MODE_NONE:
rkChrMgr.RemovePVPKey(kPVPPacket.dwVIDSrc, kPVPPacket.dwVIDDst);
rkPlayer.ForgetInstance(kPVPPacket.dwVIDSrc);
rkPlayer.ForgetInstance(kPVPPacket.dwVIDDst);
break;
}
// NOTE : PVP <20><><EFBFBD>۽<EFBFBD> TargetBoard <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʈ <20>մϴ<D5B4>.
__RefreshTargetBoardByVID(kPVPPacket.dwVIDSrc);
__RefreshTargetBoardByVID(kPVPPacket.dwVIDDst);
return true;
}
// DELETEME
/*
void CPythonNetworkStream::__SendWarpPacket()
{
TPacketCGWarp kWarpPacket;
kWarpPacket.bHeader=HEADER_GC_WARP;
if (!Send(sizeof(kWarpPacket), &kWarpPacket))
{
return;
}
}
*/
void CPythonNetworkStream::NotifyHack(const char* c_szMsg)
{
if (!m_kQue_stHack.empty())
if (c_szMsg==m_kQue_stHack.back())
return;
m_kQue_stHack.push_back(c_szMsg);
}
bool CPythonNetworkStream::__SendHack(const char* c_szMsg)
{
Tracen(c_szMsg);
TPacketCGHack kPacketHack;
kPacketHack.bHeader=HEADER_CG_HACK;
strncpy(kPacketHack.szBuf, c_szMsg, sizeof(kPacketHack.szBuf)-1);
if (!Send(sizeof(kPacketHack), &kPacketHack))
return false;
return SendSequence();
}
bool CPythonNetworkStream::SendMessengerAddByVIDPacket(DWORD vid)
{
TPacketCGMessenger packet;
packet.header = HEADER_CG_MESSENGER;
packet.subheader = MESSENGER_SUBHEADER_CG_ADD_BY_VID;
if (!Send(sizeof(packet), &packet))
return false;
if (!Send(sizeof(vid), &vid))
return false;
return SendSequence();
}
bool CPythonNetworkStream::SendMessengerAddByNamePacket(const char * c_szName)
{
TPacketCGMessenger packet;
packet.header = HEADER_CG_MESSENGER;
packet.subheader = MESSENGER_SUBHEADER_CG_ADD_BY_NAME;
if (!Send(sizeof(packet), &packet))
return false;
char szName[CHARACTER_NAME_MAX_LEN];
strncpy(szName, c_szName, CHARACTER_NAME_MAX_LEN-1);
szName[CHARACTER_NAME_MAX_LEN-1] = '\0'; // #720: <20>޽<EFBFBD><DEBD><EFBFBD> <20≯<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>÷ο<C3B7> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
if (!Send(sizeof(szName), &szName))
return false;
Tracef(" SendMessengerAddByNamePacket : %s\n", c_szName);
return SendSequence();
}
bool CPythonNetworkStream::SendMessengerRemovePacket(const char * c_szKey, const char * c_szName)
{
TPacketCGMessenger packet;
packet.header = HEADER_CG_MESSENGER;
packet.subheader = MESSENGER_SUBHEADER_CG_REMOVE;
if (!Send(sizeof(packet), &packet))
return false;
char szKey[CHARACTER_NAME_MAX_LEN];
strncpy(szKey, c_szKey, CHARACTER_NAME_MAX_LEN-1);
if (!Send(sizeof(szKey), &szKey))
return false;
__RefreshTargetBoardByName(c_szName);
return SendSequence();
}
bool CPythonNetworkStream::SendCharacterStatePacket(const TPixelPosition& c_rkPPosDst, float fDstRot, UINT eFunc, UINT uArg)
{
NANOBEGIN
if (!__CanActMainInstance())
return true;
if (fDstRot < 0.0f)
fDstRot = 360 + fDstRot;
else if (fDstRot > 360.0f)
fDstRot = fmodf(fDstRot, 360.0f);
// TODO: <20><><EFBFBD>߿<EFBFBD> <20><>Ŷ<EFBFBD≯<EFBFBD><CCB8><EFBFBD> <20>ٲ<EFBFBD><D9B2><EFBFBD>
TPacketCGMove kStatePacket;
kStatePacket.bHeader = HEADER_CG_CHARACTER_MOVE;
kStatePacket.bFunc = eFunc;
kStatePacket.bArg = uArg;
kStatePacket.bRot = fDstRot/5.0f;
kStatePacket.lX = long(c_rkPPosDst.x);
kStatePacket.lY = long(c_rkPPosDst.y);
kStatePacket.dwTime = ELTimer_GetServerMSec();
assert(kStatePacket.lX >= 0 && kStatePacket.lX < 204800);
__LocalPositionToGlobalPosition(kStatePacket.lX, kStatePacket.lY);
if (!Send(sizeof(kStatePacket), &kStatePacket))
{
Tracenf("CPythonNetworkStream::SendCharacterStatePacket(dwCmdTime=%u, fDstPos=(%f, %f), fDstRot=%f, eFunc=%d uArg=%d) - PACKET SEND ERROR",
kStatePacket.dwTime,
float(kStatePacket.lX),
float(kStatePacket.lY),
fDstRot,
kStatePacket.bFunc,
kStatePacket.bArg);
return false;
}
NANOEND
return SendSequence();
}
// NOTE : SlotIndex<65><78> <20>ӽ<EFBFBD>
bool CPythonNetworkStream::SendUseSkillPacket(DWORD dwSkillIndex, DWORD dwTargetVID)
{
TPacketCGUseSkill UseSkillPacket;
UseSkillPacket.bHeader = HEADER_CG_USE_SKILL;
UseSkillPacket.dwVnum = dwSkillIndex;
UseSkillPacket.dwTargetVID = dwTargetVID;
if (!Send(sizeof(TPacketCGUseSkill), &UseSkillPacket))
{
Tracen("CPythonNetworkStream::SendUseSkillPacket - SEND PACKET ERROR");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendChatPacket(const char * c_szChat, BYTE byType)
{
if (strlen(c_szChat) == 0)
return true;
if (strlen(c_szChat) >= 512)
return true;
if (c_szChat[0] == '/')
{
if (1 == strlen(c_szChat))
{
if (!m_strLastCommand.empty())
c_szChat = m_strLastCommand.c_str();
}
else
{
m_strLastCommand = c_szChat;
}
}
if (ClientCommand(c_szChat))
return true;
int iTextLen = strlen(c_szChat) + 1;
TPacketCGChat ChatPacket;
ChatPacket.header = HEADER_CG_CHAT;
ChatPacket.length = sizeof(ChatPacket) + iTextLen;
ChatPacket.type = byType;
if (!Send(sizeof(ChatPacket), &ChatPacket))
return false;
if (!Send(iTextLen, c_szChat))
return false;
return SendSequence();
}
//////////////////////////////////////////////////////////////////////////
// Emoticon
void CPythonNetworkStream::RegisterEmoticonString(const char * pcEmoticonString)
{
if (m_EmoticonStringVector.size() >= CInstanceBase::EMOTICON_NUM)
{
TraceError("Can't register emoticon string... vector is full (size:%d)", m_EmoticonStringVector.size() );
return;
}
m_EmoticonStringVector.push_back(pcEmoticonString);
}
bool CPythonNetworkStream::ParseEmoticon(const char * pChatMsg, DWORD * pdwEmoticon)
{
for (DWORD dwEmoticonIndex = 0; dwEmoticonIndex < m_EmoticonStringVector.size() ; ++dwEmoticonIndex)
{
if (strlen(pChatMsg) > m_EmoticonStringVector[dwEmoticonIndex].size())
continue;
const char * pcFind = strstr(pChatMsg, m_EmoticonStringVector[dwEmoticonIndex].c_str());
if (pcFind != pChatMsg)
continue;
*pdwEmoticon = dwEmoticonIndex;
return true;
}
return false;
}
// Emoticon
//////////////////////////////////////////////////////////////////////////
void CPythonNetworkStream::__ConvertEmpireText(DWORD dwEmpireID, char* szText)
{
if (dwEmpireID<1 || dwEmpireID>3)
return;
UINT uHanPos;
STextConvertTable& rkTextConvTable=m_aTextConvTable[dwEmpireID-1];
BYTE* pbText=(BYTE*)szText;
while (*pbText)
{
if (*pbText & 0x80)
{
if (pbText[0]>=0xb0 && pbText[0]<=0xc8 && pbText[1]>=0xa1 && pbText[1]<=0xfe)
{
uHanPos=(pbText[0]-0xb0)*(0xfe-0xa1+1)+(pbText[1]-0xa1);
pbText[0]=rkTextConvTable.aacHan[uHanPos][0];
pbText[1]=rkTextConvTable.aacHan[uHanPos][1];
}
pbText+=2;
}
else
{
if (*pbText>='a' && *pbText<='z')
{
*pbText=rkTextConvTable.acLower[*pbText-'a'];
}
else if (*pbText>='A' && *pbText<='Z')
{
*pbText=rkTextConvTable.acUpper[*pbText-'A'];
}
pbText++;
}
}
}
bool CPythonNetworkStream::RecvChatPacket()
{
TPacketGCChat kChat;
char buf[1024 + 1];
char line[1024 + 1];
if (!Recv(sizeof(kChat), &kChat))
return false;
UINT uChatSize=kChat.size - sizeof(kChat);
if (!Recv(uChatSize, buf))
return false;
buf[uChatSize]='\0';
// <20><><EFBFBD><EFBFBD> <20>ƶ<EFBFBD> <20><><EFBFBD><EFBFBD> ó<><C3B3>
// "<22≯<EFBFBD>: <20><><EFBFBD><EFBFBD>" <20>Է<EFBFBD><D4B7><EFBFBD> "<22><><EFBFBD><EFBFBD>: <20≯<EFBFBD>" <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϱ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><>(0x08)<29><> <20><><EFBFBD><EFBFBD>
// <20><><EFBFBD><EFBFBD> <20>ƶ<EFBFBD><C6B6><EFBFBD> <20><>ȣ<EFBFBD><C8A3> ó<><C3B3><EFBFBD><EFBFBD> (<28><><EFBFBD><EFBFBD>1) : (<28><><EFBFBD><EFBFBD>2) <20><> <20>ԷµǾ (<28><><EFBFBD><EFBFBD>2) : (<28><><EFBFBD><EFBFBD>1) <20><> <20><><EFBFBD><EFBFBD><EFBFBD>ϰ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if (LocaleService_IsEUROPE() && GetDefaultCodePage() == 1256)
{
char * p = strchr(buf, ':');
if (p && p[1] == ' ')
p[1] = 0x08;
}
if (kChat.type >= CHAT_TYPE_MAX_NUM)
return true;
if (CHAT_TYPE_COMMAND == kChat.type)
{
ServerCommand(buf);
return true;
}
if (kChat.dwVID != 0)
{
CPythonCharacterManager& rkChrMgr=CPythonCharacterManager::Instance();
CInstanceBase * pkInstChatter = rkChrMgr.GetInstancePtr(kChat.dwVID);
if (NULL == pkInstChatter)
return true;
switch (kChat.type)
{
case CHAT_TYPE_TALKING: /* <20>׳<EFBFBD> ä<><C3A4> */
case CHAT_TYPE_PARTY: /* <20><>Ƽ<EFBFBD><C6BC> */
case CHAT_TYPE_GUILD: /* <20><><EFBFBD>帻 */
case CHAT_TYPE_SHOUT: /* <20><>ġ<EFBFBD><C4A1> */
case CHAT_TYPE_WHISPER: // <20><><EFBFBD><EFBFBD><EFBFBD>ʹ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ʴ<EFBFBD> Only Client Enum
{
char * p = strchr(buf, ':');
if (p)
p += 2;
else
p = buf;
DWORD dwEmoticon;
if (ParseEmoticon(p, &dwEmoticon))
{
pkInstChatter->SetEmoticon(dwEmoticon);
return true;
}
else
{
if (gs_bEmpireLanuageEnable)
{
CInstanceBase* pkInstMain=rkChrMgr.GetMainInstancePtr();
if (pkInstMain)
if (!pkInstMain->IsSameEmpire(*pkInstChatter))
__ConvertEmpireText(pkInstChatter->GetEmpireID(), p);
}
if (m_isEnableChatInsultFilter)
{
if (false == pkInstChatter->IsNPC() && false == pkInstChatter->IsEnemy())
{
__FilterInsult(p, strlen(p));
}
}
_snprintf(line, sizeof(line), "%s", p);
}
}
break;
case CHAT_TYPE_COMMAND: /* <20><><EFBFBD><EFBFBD> */
case CHAT_TYPE_INFO: /* <20><><EFBFBD><EFBFBD> (<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20><><EFBFBD><EFBFBD>ġ<EFBFBD><C4A1> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>. <20><>) */
case CHAT_TYPE_NOTICE: /* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
case CHAT_TYPE_BIG_NOTICE:
case CHAT_TYPE_MAX_NUM:
default:
_snprintf(line, sizeof(line), "%s", buf);
break;
}
if (CHAT_TYPE_SHOUT != kChat.type)
{
CPythonTextTail::Instance().RegisterChatTail(kChat.dwVID, line);
}
if (pkInstChatter->IsPC())
CPythonChat::Instance().AppendChat(kChat.type, buf);
}
else
{
if (CHAT_TYPE_NOTICE == kChat.type)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_SetTipMessage", Py_BuildValue("(s)", buf));
}
else if (CHAT_TYPE_BIG_NOTICE == kChat.type)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_SetBigMessage", Py_BuildValue("(s)", buf));
}
else if (CHAT_TYPE_SHOUT == kChat.type)
{
char * p = strchr(buf, ':');
if (p)
{
if (m_isEnableChatInsultFilter)
__FilterInsult(p, strlen(p));
}
}
CPythonChat::Instance().AppendChat(kChat.type, buf);
}
return true;
}
bool CPythonNetworkStream::RecvWhisperPacket()
{
TPacketGCWhisper whisperPacket;
char buf[512 + 1];
if (!Recv(sizeof(whisperPacket), &whisperPacket))
return false;
assert(whisperPacket.wSize - sizeof(whisperPacket) < 512);
if (!Recv(whisperPacket.wSize - sizeof(whisperPacket), &buf))
return false;
buf[whisperPacket.wSize - sizeof(whisperPacket)] = '\0';
static char line[256];
if (CPythonChat::WHISPER_TYPE_CHAT == whisperPacket.bType || CPythonChat::WHISPER_TYPE_GM == whisperPacket.bType)
{
_snprintf(line, sizeof(line), "%s : %s", whisperPacket.szNameFrom, buf);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnRecvWhisper", Py_BuildValue("(iss)", (int) whisperPacket.bType, whisperPacket.szNameFrom, line));
}
else if (CPythonChat::WHISPER_TYPE_SYSTEM == whisperPacket.bType || CPythonChat::WHISPER_TYPE_ERROR == whisperPacket.bType)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnRecvWhisperSystemMessage", Py_BuildValue("(iss)", (int) whisperPacket.bType, whisperPacket.szNameFrom, buf));
}
else
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnRecvWhisperError", Py_BuildValue("(iss)", (int) whisperPacket.bType, whisperPacket.szNameFrom, buf));
}
return true;
}
bool CPythonNetworkStream::SendWhisperPacket(const char * name, const char * c_szChat)
{
if (strlen(c_szChat) >= 255)
return true;
int iTextLen = strlen(c_szChat) + 1;
TPacketCGWhisper WhisperPacket;
WhisperPacket.bHeader = HEADER_CG_WHISPER;
WhisperPacket.wSize = sizeof(WhisperPacket) + iTextLen;
strncpy(WhisperPacket.szNameTo, name, sizeof(WhisperPacket.szNameTo) - 1);
if (!Send(sizeof(WhisperPacket), &WhisperPacket))
return false;
if (!Send(iTextLen, c_szChat))
return false;
return SendSequence();
}
bool CPythonNetworkStream::SendMobileMessagePacket(const char * name, const char * c_szChat)
{
int iTextLen = strlen(c_szChat) + 1;
TPacketCGSMS SMSPacket;
SMSPacket.bHeader = HEADER_CG_SMS;
SMSPacket.wSize = sizeof(SMSPacket) + iTextLen;
strncpy(SMSPacket.szNameTo, name, sizeof(SMSPacket.szNameTo) - 1);
if (!Send(sizeof(SMSPacket), &SMSPacket))
return false;
if (!Send(iTextLen, c_szChat))
return false;
return SendSequence();
}
bool CPythonNetworkStream::RecvPointChange()
{
TPacketGCPointChange PointChange;
if (!Recv(sizeof(TPacketGCPointChange), &PointChange))
{
Tracen("Recv Point Change Packet Error");
return false;
}
CPythonCharacterManager& rkChrMgr = CPythonCharacterManager::Instance();
rkChrMgr.ShowPointEffect(PointChange.Type, PointChange.dwVID);
CInstanceBase * pInstance = CPythonCharacterManager::Instance().GetMainInstancePtr();
// <20>ڽ<EFBFBD><DABD><EFBFBD> Point<6E><74> <20><><EFBFBD><EFBFBD><EFBFBD>Ǿ<EFBFBD><C7BE><EFBFBD> <20><><EFBFBD><EFBFBD>..
if (pInstance)
if (PointChange.dwVID == pInstance->GetVirtualID())
{
CPythonPlayer & rkPlayer = CPythonPlayer::Instance();
rkPlayer.SetStatus(PointChange.Type, PointChange.value);
switch (PointChange.Type)
{
case POINT_STAT_RESET_COUNT:
__RefreshStatus();
break;
case POINT_LEVEL:
case POINT_ST:
case POINT_DX:
case POINT_HT:
case POINT_IQ:
__RefreshStatus();
__RefreshSkillWindow();
break;
case POINT_SKILL:
case POINT_SUB_SKILL:
case POINT_HORSE_SKILL:
__RefreshSkillWindow();
break;
case POINT_ENERGY:
if (PointChange.value == 0)
{
rkPlayer.SetStatus(POINT_ENERGY_END_TIME, 0);
}
__RefreshStatus();
break;
default:
__RefreshStatus();
break;
}
if (POINT_GOLD == PointChange.Type)
{
if (PointChange.amount > 0)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnPickMoney", Py_BuildValue("(i)", PointChange.amount));
}
}
}
return true;
}
bool CPythonNetworkStream::RecvStunPacket()
{
TPacketGCStun StunPacket;
if (!Recv(sizeof(StunPacket), &StunPacket))
{
Tracen("CPythonNetworkStream::RecvStunPacket Error");
return false;
}
//Tracef("RecvStunPacket %d\n", StunPacket.vid);
CPythonCharacterManager& rkChrMgr=CPythonCharacterManager::Instance();
CInstanceBase * pkInstSel = rkChrMgr.GetInstancePtr(StunPacket.vid);
if (pkInstSel)
{
if (CPythonCharacterManager::Instance().GetMainInstancePtr()==pkInstSel)
pkInstSel->Die();
else
pkInstSel->Stun();
}
return true;
}
bool CPythonNetworkStream::RecvDeadPacket()
{
TPacketGCDead DeadPacket;
if (!Recv(sizeof(DeadPacket), &DeadPacket))
{
Tracen("CPythonNetworkStream::RecvDeadPacket Error");
return false;
}
CPythonCharacterManager& rkChrMgr=CPythonCharacterManager::Instance();
CInstanceBase * pkChrInstSel = rkChrMgr.GetInstancePtr(DeadPacket.vid);
if (pkChrInstSel)
{
CInstanceBase* pkInstMain=rkChrMgr.GetMainInstancePtr();
if (pkInstMain==pkChrInstSel)
{
Tracenf("<EFBFBD><EFBFBD><EFBFBD>ΰ<EFBFBD> <20><><EFBFBD><EFBFBD>");
if (false == pkInstMain->GetDuelMode())
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnGameOver", Py_BuildValue("()"));
}
CPythonPlayer::Instance().NotifyDeadMainCharacter();
}
pkChrInstSel->Die();
}
return true;
}
bool CPythonNetworkStream::SendCharacterPositionPacket(BYTE iPosition)
{
TPacketCGPosition PositionPacket;
PositionPacket.header = HEADER_CG_CHARACTER_POSITION;
PositionPacket.position = iPosition;
if (!Send(sizeof(TPacketCGPosition), &PositionPacket))
{
Tracen("Send Character Position Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendOnClickPacket(DWORD vid)
{
TPacketCGOnClick OnClickPacket;
OnClickPacket.header = HEADER_CG_ON_CLICK;
OnClickPacket.vid = vid;
if (!Send(sizeof(OnClickPacket), &OnClickPacket))
{
Tracen("Send On_Click Packet Error");
return false;
}
Tracef("SendOnClickPacket\n");
return SendSequence();
}
bool CPythonNetworkStream::RecvCharacterPositionPacket()
{
TPacketGCPosition PositionPacket;
if (!Recv(sizeof(TPacketGCPosition), &PositionPacket))
return false;
CInstanceBase * pChrInstance = CPythonCharacterManager::Instance().GetInstancePtr(PositionPacket.vid);
if (!pChrInstance)
return true;
//pChrInstance->UpdatePosition(PositionPacket.position);
return true;
}
bool CPythonNetworkStream::RecvMotionPacket()
{
TPacketGCMotion MotionPacket;
if (!Recv(sizeof(TPacketGCMotion), &MotionPacket))
return false;
CInstanceBase * pMainInstance = CPythonCharacterManager::Instance().GetInstancePtr(MotionPacket.vid);
CInstanceBase * pVictimInstance = NULL;
if (0 != MotionPacket.victim_vid)
pVictimInstance = CPythonCharacterManager::Instance().GetInstancePtr(MotionPacket.victim_vid);
if (!pMainInstance)
return false;
return true;
}
bool CPythonNetworkStream::RecvShopPacket()
{
std::vector<char> vecBuffer;
vecBuffer.clear();
TPacketGCShop packet_shop;
if (!Recv(sizeof(packet_shop), &packet_shop))
return false;
int iSize = packet_shop.size - sizeof(packet_shop);
if (iSize > 0)
{
vecBuffer.resize(iSize);
if (!Recv(iSize, &vecBuffer[0]))
return false;
}
switch (packet_shop.subheader)
{
case SHOP_SUBHEADER_GC_START:
{
CPythonShop::Instance().Clear();
DWORD dwVID = *(DWORD *)&vecBuffer[0];
TPacketGCShopStart * pShopStartPacket = (TPacketGCShopStart *)&vecBuffer[4];
for (BYTE iItemIndex = 0; iItemIndex < SHOP_HOST_ITEM_MAX_NUM; ++iItemIndex)
{
CPythonShop::Instance().SetItemData(iItemIndex, pShopStartPacket->items[iItemIndex]);
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "StartShop", Py_BuildValue("(i)", dwVID));
}
break;
case SHOP_SUBHEADER_GC_START_EX:
{
CPythonShop::Instance().Clear();
TPacketGCShopStartEx * pShopStartPacket = (TPacketGCShopStartEx *)&vecBuffer[0];
size_t read_point = sizeof(TPacketGCShopStartEx);
DWORD dwVID = pShopStartPacket->owner_vid;
BYTE shop_tab_count = pShopStartPacket->shop_tab_count;
CPythonShop::instance().SetTabCount(shop_tab_count);
for (size_t i = 0; i < shop_tab_count; i++)
{
TPacketGCShopStartEx::TSubPacketShopTab* pPackTab = (TPacketGCShopStartEx::TSubPacketShopTab*)&vecBuffer[read_point];
read_point += sizeof(TPacketGCShopStartEx::TSubPacketShopTab);
CPythonShop::instance().SetTabCoinType(i, pPackTab->coin_type);
CPythonShop::instance().SetTabName(i, pPackTab->name);
struct packet_shop_item* item = &pPackTab->items[0];
for (BYTE j = 0; j < SHOP_HOST_ITEM_MAX_NUM; j++)
{
TShopItemData* itemData = (item + j);
CPythonShop::Instance().SetItemData(i, j, *itemData);
}
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "StartShop", Py_BuildValue("(i)", dwVID));
}
break;
case SHOP_SUBHEADER_GC_END:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "EndShop", Py_BuildValue("()"));
break;
case SHOP_SUBHEADER_GC_UPDATE_ITEM:
{
TPacketGCShopUpdateItem * pShopUpdateItemPacket = (TPacketGCShopUpdateItem *)&vecBuffer[0];
CPythonShop::Instance().SetItemData(pShopUpdateItemPacket->pos, pShopUpdateItemPacket->item);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshShop", Py_BuildValue("()"));
}
break;
case SHOP_SUBHEADER_GC_UPDATE_PRICE:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "SetShopSellingPrice", Py_BuildValue("(i)", *(int *)&vecBuffer[0]));
break;
case SHOP_SUBHEADER_GC_NOT_ENOUGH_MONEY:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnShopError", Py_BuildValue("(s)", "NOT_ENOUGH_MONEY"));
break;
case SHOP_SUBHEADER_GC_NOT_ENOUGH_MONEY_EX:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnShopError", Py_BuildValue("(s)", "NOT_ENOUGH_MONEY_EX"));
break;
case SHOP_SUBHEADER_GC_SOLDOUT:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnShopError", Py_BuildValue("(s)", "SOLDOUT"));
break;
case SHOP_SUBHEADER_GC_INVENTORY_FULL:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnShopError", Py_BuildValue("(s)", "INVENTORY_FULL"));
break;
case SHOP_SUBHEADER_GC_INVALID_POS:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnShopError", Py_BuildValue("(s)", "INVALID_POS"));
break;
default:
TraceError("CPythonNetworkStream::RecvShopPacket: Unknown subheader\n");
break;
}
return true;
}
bool CPythonNetworkStream::RecvExchangePacket()
{
TPacketGCExchange exchange_packet;
if (!Recv(sizeof(exchange_packet), &exchange_packet))
return false;
switch (exchange_packet.subheader)
{
case EXCHANGE_SUBHEADER_GC_START:
CPythonExchange::Instance().Clear();
CPythonExchange::Instance().Start();
CPythonExchange::Instance().SetSelfName(CPythonPlayer::Instance().GetName());
{
CInstanceBase * pCharacterInstance = CPythonCharacterManager::Instance().GetInstancePtr(exchange_packet.arg1);
if (pCharacterInstance)
CPythonExchange::Instance().SetTargetName(pCharacterInstance->GetNameString());
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "StartExchange", Py_BuildValue("()"));
break;
case EXCHANGE_SUBHEADER_GC_ITEM_ADD:
if (exchange_packet.is_me)
{
int iSlotIndex = exchange_packet.arg2.cell;
CPythonExchange::Instance().SetItemToSelf(iSlotIndex, exchange_packet.arg1, (BYTE) exchange_packet.arg3);
for (int i = 0; i < ITEM_SOCKET_SLOT_MAX_NUM; ++i)
CPythonExchange::Instance().SetItemMetinSocketToSelf(iSlotIndex, i, exchange_packet.alValues[i]);
for (int j = 0; j < ITEM_ATTRIBUTE_SLOT_MAX_NUM; ++j)
CPythonExchange::Instance().SetItemAttributeToSelf(iSlotIndex, j, exchange_packet.aAttr[j].bType, exchange_packet.aAttr[j].sValue);
}
else
{
int iSlotIndex = exchange_packet.arg2.cell;
CPythonExchange::Instance().SetItemToTarget(iSlotIndex, exchange_packet.arg1, (BYTE) exchange_packet.arg3);
for (int i = 0; i < ITEM_SOCKET_SLOT_MAX_NUM; ++i)
CPythonExchange::Instance().SetItemMetinSocketToTarget(iSlotIndex, i, exchange_packet.alValues[i]);
for (int j = 0; j < ITEM_ATTRIBUTE_SLOT_MAX_NUM; ++j)
CPythonExchange::Instance().SetItemAttributeToTarget(iSlotIndex, j, exchange_packet.aAttr[j].bType, exchange_packet.aAttr[j].sValue);
}
__RefreshExchangeWindow();
__RefreshInventoryWindow();
break;
case EXCHANGE_SUBHEADER_GC_ITEM_DEL:
if (exchange_packet.is_me)
{
CPythonExchange::Instance().DelItemOfSelf((BYTE) exchange_packet.arg1);
}
else
{
CPythonExchange::Instance().DelItemOfTarget((BYTE) exchange_packet.arg1);
}
__RefreshExchangeWindow();
__RefreshInventoryWindow();
break;
case EXCHANGE_SUBHEADER_GC_ELK_ADD:
if (exchange_packet.is_me)
CPythonExchange::Instance().SetElkToSelf(exchange_packet.arg1);
else
CPythonExchange::Instance().SetElkToTarget(exchange_packet.arg1);
__RefreshExchangeWindow();
break;
case EXCHANGE_SUBHEADER_GC_ACCEPT:
if (exchange_packet.is_me)
{
CPythonExchange::Instance().SetAcceptToSelf((BYTE) exchange_packet.arg1);
}
else
{
CPythonExchange::Instance().SetAcceptToTarget((BYTE) exchange_packet.arg1);
}
__RefreshExchangeWindow();
break;
case EXCHANGE_SUBHEADER_GC_END:
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "EndExchange", Py_BuildValue("()"));
__RefreshInventoryWindow();
CPythonExchange::Instance().End();
break;
case EXCHANGE_SUBHEADER_GC_ALREADY:
Tracef("trade_already");
break;
case EXCHANGE_SUBHEADER_GC_LESS_ELK:
Tracef("trade_less_elk");
break;
};
return true;
}
bool CPythonNetworkStream::RecvQuestInfoPacket()
{
TPacketGCQuestInfo QuestInfo;
if (!Peek(sizeof(TPacketGCQuestInfo), &QuestInfo))
{
Tracen("Recv Quest Info Packet Error #1");
return false;
}
if (!Peek(QuestInfo.size))
{
Tracen("Recv Quest Info Packet Error #2");
return false;
}
Recv(sizeof(TPacketGCQuestInfo));
const BYTE & c_rFlag = QuestInfo.flag;
enum
{
QUEST_PACKET_TYPE_NONE,
QUEST_PACKET_TYPE_BEGIN,
QUEST_PACKET_TYPE_UPDATE,
QUEST_PACKET_TYPE_END,
};
BYTE byQuestPacketType = QUEST_PACKET_TYPE_NONE;
if (0 != (c_rFlag & QUEST_SEND_IS_BEGIN))
{
BYTE isBegin;
if (!Recv(sizeof(isBegin), &isBegin))
return false;
if (isBegin)
byQuestPacketType = QUEST_PACKET_TYPE_BEGIN;
else
byQuestPacketType = QUEST_PACKET_TYPE_END;
}
else
{
byQuestPacketType = QUEST_PACKET_TYPE_UPDATE;
}
// Recv Data Start
char szTitle[30 + 1] = "";
char szClockName[16 + 1] = "";
int iClockValue = 0;
char szCounterName[16 + 1] = "";
int iCounterValue = 0;
char szIconFileName[24 + 1] = "";
if (0 != (c_rFlag & QUEST_SEND_TITLE))
{
if (!Recv(sizeof(szTitle), &szTitle))
return false;
szTitle[30]='\0';
}
if (0 != (c_rFlag & QUEST_SEND_CLOCK_NAME))
{
if (!Recv(sizeof(szClockName), &szClockName))
return false;
szClockName[16]='\0';
}
if (0 != (c_rFlag & QUEST_SEND_CLOCK_VALUE))
{
if (!Recv(sizeof(iClockValue), &iClockValue))
return false;
}
if (0 != (c_rFlag & QUEST_SEND_COUNTER_NAME))
{
if (!Recv(sizeof(szCounterName), &szCounterName))
return false;
szCounterName[16]='\0';
}
if (0 != (c_rFlag & QUEST_SEND_COUNTER_VALUE))
{
if (!Recv(sizeof(iCounterValue), &iCounterValue))
return false;
}
if (0 != (c_rFlag & QUEST_SEND_ICON_FILE))
{
if (!Recv(sizeof(szIconFileName), &szIconFileName))
return false;
szIconFileName[24]='\0';
}
// Recv Data End
CPythonQuest& rkQuest=CPythonQuest::Instance();
// Process Start
if (QUEST_PACKET_TYPE_END == byQuestPacketType)
{
rkQuest.DeleteQuestInstance(QuestInfo.index);
}
else if (QUEST_PACKET_TYPE_UPDATE == byQuestPacketType)
{
if (!rkQuest.IsQuest(QuestInfo.index))
{
rkQuest.MakeQuest(QuestInfo.index);
}
if (strlen(szTitle) > 0)
rkQuest.SetQuestTitle(QuestInfo.index, szTitle);
if (strlen(szClockName) > 0)
rkQuest.SetQuestClockName(QuestInfo.index, szClockName);
if (strlen(szCounterName) > 0)
rkQuest.SetQuestCounterName(QuestInfo.index, szCounterName);
if (strlen(szIconFileName) > 0)
rkQuest.SetQuestIconFileName(QuestInfo.index, szIconFileName);
if (c_rFlag & QUEST_SEND_CLOCK_VALUE)
rkQuest.SetQuestClockValue(QuestInfo.index, iClockValue);
if (c_rFlag & QUEST_SEND_COUNTER_VALUE)
rkQuest.SetQuestCounterValue(QuestInfo.index, iCounterValue);
}
else if (QUEST_PACKET_TYPE_BEGIN == byQuestPacketType)
{
CPythonQuest::SQuestInstance QuestInstance;
QuestInstance.dwIndex = QuestInfo.index;
QuestInstance.strTitle = szTitle;
QuestInstance.strClockName = szClockName;
QuestInstance.iClockValue = iClockValue;
QuestInstance.strCounterName = szCounterName;
QuestInstance.iCounterValue = iCounterValue;
QuestInstance.strIconFileName = szIconFileName;
CPythonQuest::Instance().RegisterQuestInstance(QuestInstance);
}
// Process Start End
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshQuest", Py_BuildValue("()"));
return true;
}
bool CPythonNetworkStream::RecvQuestConfirmPacket()
{
TPacketGCQuestConfirm kQuestConfirmPacket;
if (!Recv(sizeof(kQuestConfirmPacket), &kQuestConfirmPacket))
{
Tracen("RecvQuestConfirmPacket Error");
return false;
}
PyObject * poArg = Py_BuildValue("(sii)", kQuestConfirmPacket.msg, kQuestConfirmPacket.timeout, kQuestConfirmPacket.requestPID);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_OnQuestConfirm", poArg);
return true;
}
bool CPythonNetworkStream::RecvRequestMakeGuild()
{
TPacketGCBlank blank;
if (!Recv(sizeof(blank), &blank))
{
Tracen("RecvRequestMakeGuild Packet Error");
return false;
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "AskGuildName", Py_BuildValue("()"));
return true;
}
void CPythonNetworkStream::ToggleGameDebugInfo()
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "ToggleDebugInfo", Py_BuildValue("()"));
}
bool CPythonNetworkStream::SendExchangeStartPacket(DWORD vid)
{
if (!__CanActMainInstance())
return true;
TPacketCGExchange packet;
packet.header = HEADER_CG_EXCHANGE;
packet.subheader = EXCHANGE_SUBHEADER_CG_START;
packet.arg1 = vid;
if (!Send(sizeof(packet), &packet))
{
Tracef("send_trade_start_packet Error\n");
return false;
}
Tracef("send_trade_start_packet vid %d \n", vid);
return SendSequence();
}
bool CPythonNetworkStream::SendExchangeElkAddPacket(DWORD elk)
{
if (!__CanActMainInstance())
return true;
TPacketCGExchange packet;
packet.header = HEADER_CG_EXCHANGE;
packet.subheader = EXCHANGE_SUBHEADER_CG_ELK_ADD;
packet.arg1 = elk;
if (!Send(sizeof(packet), &packet))
{
Tracef("send_trade_elk_add_packet Error\n");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendExchangeItemAddPacket(TItemPos ItemPos, BYTE byDisplayPos)
{
if (!__CanActMainInstance())
return true;
TPacketCGExchange packet;
packet.header = HEADER_CG_EXCHANGE;
packet.subheader = EXCHANGE_SUBHEADER_CG_ITEM_ADD;
packet.Pos = ItemPos;
packet.arg2 = byDisplayPos;
if (!Send(sizeof(packet), &packet))
{
Tracef("send_trade_item_add_packet Error\n");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendExchangeItemDelPacket(BYTE pos)
{
assert(!"Can't be called function - CPythonNetworkStream::SendExchangeItemDelPacket");
return true;
if (!__CanActMainInstance())
return true;
TPacketCGExchange packet;
packet.header = HEADER_CG_EXCHANGE;
packet.subheader = EXCHANGE_SUBHEADER_CG_ITEM_DEL;
packet.arg1 = pos;
if (!Send(sizeof(packet), &packet))
{
Tracef("send_trade_item_del_packet Error\n");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendExchangeAcceptPacket()
{
if (!__CanActMainInstance())
return true;
TPacketCGExchange packet;
packet.header = HEADER_CG_EXCHANGE;
packet.subheader = EXCHANGE_SUBHEADER_CG_ACCEPT;
if (!Send(sizeof(packet), &packet))
{
Tracef("send_trade_accept_packet Error\n");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendExchangeExitPacket()
{
if (!__CanActMainInstance())
return true;
TPacketCGExchange packet;
packet.header = HEADER_CG_EXCHANGE;
packet.subheader = EXCHANGE_SUBHEADER_CG_CANCEL;
if (!Send(sizeof(packet), &packet))
{
Tracef("send_trade_exit_packet Error\n");
return false;
}
return SendSequence();
}
// PointReset <20><><EFBFBD>ӽ<EFBFBD>
bool CPythonNetworkStream::SendPointResetPacket()
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "StartPointReset", Py_BuildValue("()"));
return true;
}
bool CPythonNetworkStream::__IsPlayerAttacking()
{
CPythonCharacterManager& rkChrMgr=CPythonCharacterManager::Instance();
CInstanceBase* pkInstMain=rkChrMgr.GetMainInstancePtr();
if (!pkInstMain)
return false;
if (!pkInstMain->IsAttacking())
return false;
return true;
}
bool CPythonNetworkStream::RecvScriptPacket()
{
TPacketGCScript ScriptPacket;
if (!Recv(sizeof(TPacketGCScript), &ScriptPacket))
{
TraceError("RecvScriptPacket_RecvError");
return false;
}
if (ScriptPacket.size < sizeof(TPacketGCScript))
{
TraceError("RecvScriptPacket_SizeError");
return false;
}
ScriptPacket.size -= sizeof(TPacketGCScript);
static std::string str;
str = "";
str.resize(ScriptPacket.size+1);
if (!Recv(ScriptPacket.size, &str[0]))
return false;
str[str.size()-1] = '\0';
int iIndex = CPythonEventManager::Instance().RegisterEventSetFromString(str);
if (-1 != iIndex)
{
CPythonEventManager::Instance().SetVisibleLineCount(iIndex, 30);
CPythonNetworkStream::Instance().OnScriptEventStart(ScriptPacket.skin,iIndex);
}
return true;
}
bool CPythonNetworkStream::SendScriptAnswerPacket(int iAnswer)
{
TPacketCGScriptAnswer ScriptAnswer;
ScriptAnswer.header = HEADER_CG_SCRIPT_ANSWER;
ScriptAnswer.answer = (BYTE) iAnswer;
if (!Send(sizeof(TPacketCGScriptAnswer), &ScriptAnswer))
{
Tracen("Send Script Answer Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendScriptButtonPacket(unsigned int iIndex)
{
TPacketCGScriptButton ScriptButton;
ScriptButton.header = HEADER_CG_SCRIPT_BUTTON;
ScriptButton.idx = iIndex;
if (!Send(sizeof(TPacketCGScriptButton), &ScriptButton))
{
Tracen("Send Script Button Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendAnswerMakeGuildPacket(const char * c_szName)
{
TPacketCGAnswerMakeGuild Packet;
Packet.header = HEADER_CG_ANSWER_MAKE_GUILD;
strncpy(Packet.guild_name, c_szName, GUILD_NAME_MAX_LEN);
Packet.guild_name[GUILD_NAME_MAX_LEN] = '\0';
if (!Send(sizeof(Packet), &Packet))
{
Tracen("SendAnswerMakeGuild Packet Error");
return false;
}
// Tracef(" SendAnswerMakeGuildPacket : %s", c_szName);
return SendSequence();
}
bool CPythonNetworkStream::SendQuestInputStringPacket(const char * c_szString)
{
TPacketCGQuestInputString Packet;
Packet.bHeader = HEADER_CG_QUEST_INPUT_STRING;
strncpy(Packet.szString, c_szString, QUEST_INPUT_STRING_MAX_NUM);
if (!Send(sizeof(Packet), &Packet))
{
Tracen("SendQuestInputStringPacket Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendQuestConfirmPacket(BYTE byAnswer, DWORD dwPID)
{
TPacketCGQuestConfirm kPacket;
kPacket.header = HEADER_CG_QUEST_CONFIRM;
kPacket.answer = byAnswer;
kPacket.requestPID = dwPID;
if (!Send(sizeof(kPacket), &kPacket))
{
Tracen("SendQuestConfirmPacket Error");
return false;
}
Tracenf(" SendQuestConfirmPacket : %d, %d", byAnswer, dwPID);
return SendSequence();
}
bool CPythonNetworkStream::RecvSkillCoolTimeEnd()
{
TPacketGCSkillCoolTimeEnd kPacketSkillCoolTimeEnd;
if (!Recv(sizeof(kPacketSkillCoolTimeEnd), &kPacketSkillCoolTimeEnd))
{
Tracen("CPythonNetworkStream::RecvSkillCoolTimeEnd - RecvError");
return false;
}
CPythonPlayer::Instance().EndSkillCoolTime(kPacketSkillCoolTimeEnd.bSkill);
return true;
}
bool CPythonNetworkStream::RecvSkillLevel()
{
assert(!"CPythonNetworkStream::RecvSkillLevel - <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ʴ<EFBFBD> <20>Լ<EFBFBD>");
TPacketGCSkillLevel packet;
if (!Recv(sizeof(TPacketGCSkillLevel), &packet))
{
Tracen("CPythonNetworkStream::RecvSkillLevel - RecvError");
return false;
}
DWORD dwSlotIndex;
CPythonPlayer& rkPlayer=CPythonPlayer::Instance();
for (int i = 0; i < SKILL_MAX_NUM; ++i)
{
if (rkPlayer.GetSkillSlotIndex(i, &dwSlotIndex))
rkPlayer.SetSkillLevel(dwSlotIndex, packet.abSkillLevels[i]);
}
__RefreshSkillWindow();
__RefreshStatus();
Tracef(" >> RecvSkillLevel\n");
return true;
}
bool CPythonNetworkStream::RecvSkillLevelNew()
{
TPacketGCSkillLevelNew packet;
if (!Recv(sizeof(TPacketGCSkillLevelNew), &packet))
{
Tracen("CPythonNetworkStream::RecvSkillLevelNew - RecvError");
return false;
}
CPythonPlayer& rkPlayer=CPythonPlayer::Instance();
rkPlayer.SetSkill(7, 0);
rkPlayer.SetSkill(8, 0);
for (int i = 0; i < SKILL_MAX_NUM; ++i)
{
TPlayerSkill & rPlayerSkill = packet.skills[i];
if (i >= 112 && i <= 115 && rPlayerSkill.bLevel)
rkPlayer.SetSkill(7, i);
if (i >= 116 && i <= 119 && rPlayerSkill.bLevel)
rkPlayer.SetSkill(8, i);
rkPlayer.SetSkillLevel_(i, rPlayerSkill.bMasterType, rPlayerSkill.bLevel);
}
__RefreshSkillWindow();
__RefreshStatus();
//Tracef(" >> RecvSkillLevelNew\n");
return true;
}
bool CPythonNetworkStream::RecvDamageInfoPacket()
{
TPacketGCDamageInfo DamageInfoPacket;
if (!Recv(sizeof(TPacketGCDamageInfo), &DamageInfoPacket))
{
Tracen("Recv Target Packet Error");
return false;
}
CInstanceBase * pInstTarget = CPythonCharacterManager::Instance().GetInstancePtr(DamageInfoPacket.dwVID);
bool bSelf = (pInstTarget == CPythonCharacterManager::Instance().GetMainInstancePtr());
bool bTarget = (pInstTarget==m_pInstTarget);
if (pInstTarget)
{
if(DamageInfoPacket.damage >= 0)
pInstTarget->AddDamageEffect(DamageInfoPacket.damage,DamageInfoPacket.flag,bSelf,bTarget);
else
TraceError("Damage is equal or below 0.");
}
return true;
}
bool CPythonNetworkStream::RecvTargetPacket()
{
TPacketGCTarget TargetPacket;
if (!Recv(sizeof(TPacketGCTarget), &TargetPacket))
{
Tracen("Recv Target Packet Error");
return false;
}
CInstanceBase * pInstPlayer = CPythonCharacterManager::Instance().GetMainInstancePtr();
CInstanceBase * pInstTarget = CPythonCharacterManager::Instance().GetInstancePtr(TargetPacket.dwVID);
if (pInstPlayer && pInstTarget)
{
if (!pInstTarget->IsDead())
{
if (pInstTarget->IsPC() || pInstTarget->IsBuilding())
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "CloseTargetBoardIfDifferent", Py_BuildValue("(i)", TargetPacket.dwVID));
else if (pInstPlayer->CanViewTargetHP(*pInstTarget))
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "SetHPTargetBoard", Py_BuildValue("(ii)", TargetPacket.dwVID, TargetPacket.bHPPercent));
else
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "CloseTargetBoard", Py_BuildValue("()"));
m_pInstTarget = pInstTarget;
}
}
else
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "CloseTargetBoard", Py_BuildValue("()"));
}
return true;
}
bool CPythonNetworkStream::RecvMountPacket()
{
TPacketGCMount MountPacket;
if (!Recv(sizeof(TPacketGCMount), &MountPacket))
{
Tracen("Recv Mount Packet Error");
return false;
}
CInstanceBase * pInstance = CPythonCharacterManager::Instance().GetInstancePtr(MountPacket.vid);
if (pInstance)
{
// Mount
if (0 != MountPacket.mount_vid)
{
// pInstance->Ride(MountPacket.pos, MountPacket.mount_vid);
}
// Unmount
else
{
// pInstance->Unride(MountPacket.pos, MountPacket.x, MountPacket.y);
}
}
if (CPythonPlayer::Instance().IsMainCharacterIndex(MountPacket.vid))
{
// CPythonPlayer::Instance().SetRidingVehicleIndex(MountPacket.mount_vid);
}
return true;
}
bool CPythonNetworkStream::RecvChangeSpeedPacket()
{
TPacketGCChangeSpeed SpeedPacket;
if (!Recv(sizeof(TPacketGCChangeSpeed), &SpeedPacket))
{
Tracen("Recv Speed Packet Error");
return false;
}
CInstanceBase * pInstance = CPythonCharacterManager::Instance().GetInstancePtr(SpeedPacket.vid);
if (!pInstance)
return true;
// pInstance->SetWalkSpeed(SpeedPacket.walking_speed);
// pInstance->SetRunSpeed(SpeedPacket.running_speed);
return true;
}
///////////////////////////////////////////////////////////////////////////////////////////////////
// Recv
bool CPythonNetworkStream::SendAttackPacket(UINT uMotAttack, DWORD dwVIDVictim)
{
if (!__CanActMainInstance())
return true;
#ifdef ATTACK_TIME_LOG
static DWORD prevTime = timeGetTime();
DWORD curTime = timeGetTime();
TraceError("TIME: %.4f(%.4f) ATTACK_PACKET: %d TARGET: %d", curTime/1000.0f, (curTime-prevTime)/1000.0f, uMotAttack, dwVIDVictim);
prevTime = curTime;
#endif
TPacketCGAttack kPacketAtk;
kPacketAtk.header = HEADER_CG_ATTACK;
kPacketAtk.bType = uMotAttack;
kPacketAtk.dwVictimVID = dwVIDVictim;
if (!SendSpecial(sizeof(kPacketAtk), &kPacketAtk))
{
Tracen("Send Battle Attack Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendSpecial(int nLen, void * pvBuf)
{
BYTE bHeader = *(BYTE *) pvBuf;
switch (bHeader)
{
case HEADER_CG_ATTACK:
{
TPacketCGAttack * pkPacketAtk = (TPacketCGAttack *) pvBuf;
pkPacketAtk->bCRCMagicCubeProcPiece = GetProcessCRCMagicCubePiece();
pkPacketAtk->bCRCMagicCubeFilePiece = GetProcessCRCMagicCubePiece();
return Send(nLen, pvBuf);
}
break;
}
return Send(nLen, pvBuf);
}
bool CPythonNetworkStream::RecvAddFlyTargetingPacket()
{
TPacketGCFlyTargeting kPacket;
if (!Recv(sizeof(kPacket), &kPacket))
return false;
__GlobalPositionToLocalPosition(kPacket.lX, kPacket.lY);
Tracef("VID [%d]<5D><> Ÿ<><C5B8><EFBFBD><EFBFBD> <20>߰<EFBFBD> <20><><EFBFBD><EFBFBD>\n",kPacket.dwShooterVID);
CPythonCharacterManager & rpcm = CPythonCharacterManager::Instance();
CInstanceBase * pShooter = rpcm.GetInstancePtr(kPacket.dwShooterVID);
if (!pShooter)
{
#ifndef _DEBUG
TraceError("CPythonNetworkStream::RecvFlyTargetingPacket() - dwShooterVID[%d] NOT EXIST", kPacket.dwShooterVID);
#endif
return true;
}
CInstanceBase * pTarget = rpcm.GetInstancePtr(kPacket.dwTargetVID);
if (kPacket.dwTargetVID && pTarget)
{
pShooter->GetGraphicThingInstancePtr()->AddFlyTarget(pTarget->GetGraphicThingInstancePtr());
}
else
{
float h = CPythonBackground::Instance().GetHeight(kPacket.lX,kPacket.lY) + 60.0f; // TEMPORARY HEIGHT
pShooter->GetGraphicThingInstancePtr()->AddFlyTarget(D3DXVECTOR3(kPacket.lX,kPacket.lY,h));
//pShooter->GetGraphicThingInstancePtr()->SetFlyTarget(kPacket.kPPosTarget.x,kPacket.kPPosTarget.y,);
}
return true;
}
bool CPythonNetworkStream::RecvFlyTargetingPacket()
{
TPacketGCFlyTargeting kPacket;
if (!Recv(sizeof(kPacket), &kPacket))
return false;
__GlobalPositionToLocalPosition(kPacket.lX, kPacket.lY);
//Tracef("CPythonNetworkStream::RecvFlyTargetingPacket - VID [%d]\n",kPacket.dwShooterVID);
CPythonCharacterManager & rpcm = CPythonCharacterManager::Instance();
CInstanceBase * pShooter = rpcm.GetInstancePtr(kPacket.dwShooterVID);
if (!pShooter)
{
#ifdef _DEBUG
TraceError("CPythonNetworkStream::RecvFlyTargetingPacket() - dwShooterVID[%d] NOT EXIST", kPacket.dwShooterVID);
#endif
return true;
}
CInstanceBase * pTarget = rpcm.GetInstancePtr(kPacket.dwTargetVID);
if (kPacket.dwTargetVID && pTarget)
{
pShooter->GetGraphicThingInstancePtr()->SetFlyTarget(pTarget->GetGraphicThingInstancePtr());
}
else
{
float h = CPythonBackground::Instance().GetHeight(kPacket.lX, kPacket.lY) + 60.0f; // TEMPORARY HEIGHT
pShooter->GetGraphicThingInstancePtr()->SetFlyTarget(D3DXVECTOR3(kPacket.lX,kPacket.lY,h));
//pShooter->GetGraphicThingInstancePtr()->SetFlyTarget(kPacket.kPPosTarget.x,kPacket.kPPosTarget.y,);
}
return true;
}
bool CPythonNetworkStream::SendShootPacket(UINT uSkill)
{
TPacketCGShoot kPacketShoot;
kPacketShoot.bHeader=HEADER_CG_SHOOT;
kPacketShoot.bType=uSkill;
if (!Send(sizeof(kPacketShoot), &kPacketShoot))
{
Tracen("SendShootPacket Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendAddFlyTargetingPacket(DWORD dwTargetVID, const TPixelPosition & kPPosTarget)
{
TPacketCGFlyTargeting packet;
//CPythonCharacterManager & rpcm = CPythonCharacterManager::Instance();
packet.bHeader = HEADER_CG_ADD_FLY_TARGETING;
packet.dwTargetVID = dwTargetVID;
packet.lX = kPPosTarget.x;
packet.lY = kPPosTarget.y;
__LocalPositionToGlobalPosition(packet.lX, packet.lY);
if (!Send(sizeof(packet), &packet))
{
Tracen("Send FlyTargeting Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendFlyTargetingPacket(DWORD dwTargetVID, const TPixelPosition & kPPosTarget)
{
TPacketCGFlyTargeting packet;
//CPythonCharacterManager & rpcm = CPythonCharacterManager::Instance();
packet.bHeader = HEADER_CG_FLY_TARGETING;
packet.dwTargetVID = dwTargetVID;
packet.lX = kPPosTarget.x;
packet.lY = kPPosTarget.y;
__LocalPositionToGlobalPosition(packet.lX, packet.lY);
if (!Send(sizeof(packet), &packet))
{
Tracen("Send FlyTargeting Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::RecvCreateFlyPacket()
{
TPacketGCCreateFly kPacket;
if (!Recv(sizeof(TPacketGCCreateFly), &kPacket))
return false;
CFlyingManager& rkFlyMgr = CFlyingManager::Instance();
CPythonCharacterManager & rkChrMgr = CPythonCharacterManager::Instance();
CInstanceBase * pkStartInst = rkChrMgr.GetInstancePtr(kPacket.dwStartVID);
CInstanceBase * pkEndInst = rkChrMgr.GetInstancePtr(kPacket.dwEndVID);
if (!pkStartInst || !pkEndInst)
return true;
rkFlyMgr.CreateIndexedFly(kPacket.bType, pkStartInst->GetGraphicThingInstancePtr(), pkEndInst->GetGraphicThingInstancePtr());
return true;
}
bool CPythonNetworkStream::SendTargetPacket(DWORD dwVID)
{
TPacketCGTarget packet;
packet.header = HEADER_CG_TARGET;
packet.dwVID = dwVID;
if (!Send(sizeof(packet), &packet))
{
Tracen("Send Target Packet Error");
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::SendSyncPositionElementPacket(DWORD dwVictimVID, DWORD dwVictimX, DWORD dwVictimY)
{
TPacketCGSyncPositionElement kSyncPos;
kSyncPos.dwVID=dwVictimVID;
kSyncPos.lX=dwVictimX;
kSyncPos.lY=dwVictimY;
__LocalPositionToGlobalPosition(kSyncPos.lX, kSyncPos.lY);
if (!Send(sizeof(kSyncPos), &kSyncPos))
{
Tracen("CPythonNetworkStream::SendSyncPositionElementPacket - ERROR");
return false;
}
return true;
}
bool CPythonNetworkStream::RecvMessenger()
{
TPacketGCMessenger p;
if (!Recv(sizeof(p), &p))
return false;
int iSize = p.size - sizeof(p);
char char_name[24+1];
switch (p.subheader)
{
case MESSENGER_SUBHEADER_GC_LIST:
{
TPacketGCMessengerListOnline on;
while(iSize)
{
if (!Recv(sizeof(TPacketGCMessengerListOffline),&on))
return false;
if (!Recv(on.length, char_name))
return false;
char_name[on.length] = 0;
if (on.connected & MESSENGER_CONNECTED_STATE_ONLINE)
CPythonMessenger::Instance().OnFriendLogin(char_name);
else
CPythonMessenger::Instance().OnFriendLogout(char_name);
if (on.connected & MESSENGER_CONNECTED_STATE_MOBILE)
CPythonMessenger::Instance().SetMobile(char_name, TRUE);
iSize -= sizeof(TPacketGCMessengerListOffline);
iSize -= on.length;
}
break;
}
case MESSENGER_SUBHEADER_GC_LOGIN:
{
TPacketGCMessengerLogin p;
if (!Recv(sizeof(p),&p))
return false;
if (!Recv(p.length, char_name))
return false;
char_name[p.length] = 0;
CPythonMessenger::Instance().OnFriendLogin(char_name);
__RefreshTargetBoardByName(char_name);
break;
}
case MESSENGER_SUBHEADER_GC_LOGOUT:
{
TPacketGCMessengerLogout logout;
if (!Recv(sizeof(logout),&logout))
return false;
if (!Recv(logout.length, char_name))
return false;
char_name[logout.length] = 0;
CPythonMessenger::Instance().OnFriendLogout(char_name);
break;
}
case MESSENGER_SUBHEADER_GC_MOBILE:
{
BYTE byState; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><>ȣ<EFBFBD><C8A3> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>÷<EFBFBD><C3B7><EFBFBD>
BYTE byLength;
if (!Recv(sizeof(byState), &byState))
return false;
if (!Recv(sizeof(byLength), &byLength))
return false;
if (!Recv(byLength, char_name))
return false;
char_name[byLength] = 0;
CPythonMessenger::Instance().SetMobile(char_name, byState);
break;
}
}
return true;
}
//////////////////////////////////////////////////////////////////////////
// Party
bool CPythonNetworkStream::SendPartyInvitePacket(DWORD dwVID)
{
TPacketCGPartyInvite kPartyInvitePacket;
kPartyInvitePacket.header = HEADER_CG_PARTY_INVITE;
kPartyInvitePacket.vid = dwVID;
if (!Send(sizeof(kPartyInvitePacket), &kPartyInvitePacket))
{
Tracenf("CPythonNetworkStream::SendPartyInvitePacket [%ud] - PACKET SEND ERROR", dwVID);
return false;
}
Tracef(" << SendPartyInvitePacket : %d\n", dwVID);
return SendSequence();
}
bool CPythonNetworkStream::SendPartyInviteAnswerPacket(DWORD dwLeaderVID, BYTE byAnswer)
{
TPacketCGPartyInviteAnswer kPartyInviteAnswerPacket;
kPartyInviteAnswerPacket.header = HEADER_CG_PARTY_INVITE_ANSWER;
kPartyInviteAnswerPacket.leader_pid = dwLeaderVID;
kPartyInviteAnswerPacket.accept = byAnswer;
if (!Send(sizeof(kPartyInviteAnswerPacket), &kPartyInviteAnswerPacket))
{
Tracenf("CPythonNetworkStream::SendPartyInviteAnswerPacket [%ud %ud] - PACKET SEND ERROR", dwLeaderVID, byAnswer);
return false;
}
Tracef(" << SendPartyInviteAnswerPacket : %d, %d\n", dwLeaderVID, byAnswer);
return SendSequence();
}
bool CPythonNetworkStream::SendPartyRemovePacket(DWORD dwPID)
{
TPacketCGPartyRemove kPartyInviteRemove;
kPartyInviteRemove.header = HEADER_CG_PARTY_REMOVE;
kPartyInviteRemove.pid = dwPID;
if (!Send(sizeof(kPartyInviteRemove), &kPartyInviteRemove))
{
Tracenf("CPythonNetworkStream::SendPartyRemovePacket [%ud] - PACKET SEND ERROR", dwPID);
return false;
}
Tracef(" << SendPartyRemovePacket : %d\n", dwPID);
return SendSequence();
}
bool CPythonNetworkStream::SendPartySetStatePacket(DWORD dwVID, BYTE byState, BYTE byFlag)
{
TPacketCGPartySetState kPartySetState;
kPartySetState.byHeader = HEADER_CG_PARTY_SET_STATE;
kPartySetState.dwVID = dwVID;
kPartySetState.byState = byState;
kPartySetState.byFlag = byFlag;
if (!Send(sizeof(kPartySetState), &kPartySetState))
{
Tracenf("CPythonNetworkStream::SendPartySetStatePacket(%ud, %ud) - PACKET SEND ERROR", dwVID, byState);
return false;
}
Tracef(" << SendPartySetStatePacket : %d, %d, %d\n", dwVID, byState, byFlag);
return SendSequence();
}
bool CPythonNetworkStream::SendPartyUseSkillPacket(BYTE bySkillIndex, DWORD dwVID)
{
TPacketCGPartyUseSkill kPartyUseSkill;
kPartyUseSkill.byHeader = HEADER_CG_PARTY_USE_SKILL;
kPartyUseSkill.bySkillIndex = bySkillIndex;
kPartyUseSkill.dwTargetVID = dwVID;
if (!Send(sizeof(kPartyUseSkill), &kPartyUseSkill))
{
Tracenf("CPythonNetworkStream::SendPartyUseSkillPacket(%ud, %ud) - PACKET SEND ERROR", bySkillIndex, dwVID);
return false;
}
Tracef(" << SendPartyUseSkillPacket : %d, %d\n", bySkillIndex, dwVID);
return SendSequence();
}
bool CPythonNetworkStream::SendPartyParameterPacket(BYTE byDistributeMode)
{
TPacketCGPartyParameter kPartyParameter;
kPartyParameter.bHeader = HEADER_CG_PARTY_PARAMETER;
kPartyParameter.bDistributeMode = byDistributeMode;
if (!Send(sizeof(kPartyParameter), &kPartyParameter))
{
Tracenf("CPythonNetworkStream::SendPartyParameterPacket(%d) - PACKET SEND ERROR", byDistributeMode);
return false;
}
Tracef(" << SendPartyParameterPacket : %d\n", byDistributeMode);
return SendSequence();
}
bool CPythonNetworkStream::RecvPartyInvite()
{
TPacketGCPartyInvite kPartyInvitePacket;
if (!Recv(sizeof(kPartyInvitePacket), &kPartyInvitePacket))
return false;
CInstanceBase * pInstance = CPythonCharacterManager::Instance().GetInstancePtr(kPartyInvitePacket.leader_pid);
if (!pInstance)
{
TraceError(" CPythonNetworkStream::RecvPartyInvite - Failed to find leader instance [%d]\n", kPartyInvitePacket.leader_pid);
return true;
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RecvPartyInviteQuestion", Py_BuildValue("(is)", kPartyInvitePacket.leader_pid, pInstance->GetNameString()));
Tracef(" >> RecvPartyInvite : %d, %s\n", kPartyInvitePacket.leader_pid, pInstance->GetNameString());
return true;
}
bool CPythonNetworkStream::RecvPartyAdd()
{
TPacketGCPartyAdd kPartyAddPacket;
if (!Recv(sizeof(kPartyAddPacket), &kPartyAddPacket))
return false;
CPythonPlayer::Instance().AppendPartyMember(kPartyAddPacket.pid, kPartyAddPacket.name);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "AddPartyMember", Py_BuildValue("(is)", kPartyAddPacket.pid, kPartyAddPacket.name));
Tracef(" >> RecvPartyAdd : %d, %s\n", kPartyAddPacket.pid, kPartyAddPacket.name);
return true;
}
bool CPythonNetworkStream::RecvPartyUpdate()
{
TPacketGCPartyUpdate kPartyUpdatePacket;
if (!Recv(sizeof(kPartyUpdatePacket), &kPartyUpdatePacket))
return false;
CPythonPlayer::TPartyMemberInfo * pPartyMemberInfo;
if (!CPythonPlayer::Instance().GetPartyMemberPtr(kPartyUpdatePacket.pid, &pPartyMemberInfo))
return true;
BYTE byOldState = pPartyMemberInfo->byState;
CPythonPlayer::Instance().UpdatePartyMemberInfo(kPartyUpdatePacket.pid, kPartyUpdatePacket.state, kPartyUpdatePacket.percent_hp);
for (int i = 0; i < PARTY_AFFECT_SLOT_MAX_NUM; ++i)
{
CPythonPlayer::Instance().UpdatePartyMemberAffect(kPartyUpdatePacket.pid, i, kPartyUpdatePacket.affects[i]);
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "UpdatePartyMemberInfo", Py_BuildValue("(i)", kPartyUpdatePacket.pid));
// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ٲ<EFBFBD><D9B2><EFBFBD><EFBFBD>ٸ<EFBFBD>, TargetBoard <20><> <20><>ư<EFBFBD><C6B0> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʈ <20>Ѵ<EFBFBD>.
DWORD dwVID;
if (CPythonPlayer::Instance().PartyMemberPIDToVID(kPartyUpdatePacket.pid, &dwVID))
if (byOldState != kPartyUpdatePacket.state)
{
__RefreshTargetBoardByVID(dwVID);
}
// Tracef(" >> RecvPartyUpdate : %d, %d, %d\n", kPartyUpdatePacket.pid, kPartyUpdatePacket.state, kPartyUpdatePacket.percent_hp);
return true;
}
bool CPythonNetworkStream::RecvPartyRemove()
{
TPacketGCPartyRemove kPartyRemovePacket;
if (!Recv(sizeof(kPartyRemovePacket), &kPartyRemovePacket))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RemovePartyMember", Py_BuildValue("(i)", kPartyRemovePacket.pid));
Tracef(" >> RecvPartyRemove : %d\n", kPartyRemovePacket.pid);
return true;
}
bool CPythonNetworkStream::RecvPartyLink()
{
TPacketGCPartyLink kPartyLinkPacket;
if (!Recv(sizeof(kPartyLinkPacket), &kPartyLinkPacket))
return false;
CPythonPlayer::Instance().LinkPartyMember(kPartyLinkPacket.pid, kPartyLinkPacket.vid);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "LinkPartyMember", Py_BuildValue("(ii)", kPartyLinkPacket.pid, kPartyLinkPacket.vid));
Tracef(" >> RecvPartyLink : %d, %d\n", kPartyLinkPacket.pid, kPartyLinkPacket.vid);
return true;
}
bool CPythonNetworkStream::RecvPartyUnlink()
{
TPacketGCPartyUnlink kPartyUnlinkPacket;
if (!Recv(sizeof(kPartyUnlinkPacket), &kPartyUnlinkPacket))
return false;
CPythonPlayer::Instance().UnlinkPartyMember(kPartyUnlinkPacket.pid);
if (CPythonPlayer::Instance().IsMainCharacterIndex(kPartyUnlinkPacket.vid))
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "UnlinkAllPartyMember", Py_BuildValue("()"));
}
else
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "UnlinkPartyMember", Py_BuildValue("(i)", kPartyUnlinkPacket.pid));
}
Tracef(" >> RecvPartyUnlink : %d, %d\n", kPartyUnlinkPacket.pid, kPartyUnlinkPacket.vid);
return true;
}
bool CPythonNetworkStream::RecvPartyParameter()
{
TPacketGCPartyParameter kPartyParameterPacket;
if (!Recv(sizeof(kPartyParameterPacket), &kPartyParameterPacket))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "ChangePartyParameter", Py_BuildValue("(i)", kPartyParameterPacket.bDistributeMode));
Tracef(" >> RecvPartyParameter : %d\n", kPartyParameterPacket.bDistributeMode);
return true;
}
// Party
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
// Guild
bool CPythonNetworkStream::SendGuildAddMemberPacket(DWORD dwVID)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_ADD_MEMBER;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwVID), &dwVID))
return false;
Tracef(" SendGuildAddMemberPacket\n", dwVID);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildRemoveMemberPacket(DWORD dwPID)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_REMOVE_MEMBER;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwPID), &dwPID))
return false;
Tracef(" SendGuildRemoveMemberPacket %d\n", dwPID);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildChangeGradeNamePacket(BYTE byGradeNumber, const char * c_szName)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_CHANGE_GRADE_NAME;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(byGradeNumber), &byGradeNumber))
return false;
char szName[GUILD_GRADE_NAME_MAX_LEN+1];
strncpy(szName, c_szName, GUILD_GRADE_NAME_MAX_LEN);
szName[GUILD_GRADE_NAME_MAX_LEN] = '\0';
if (!Send(sizeof(szName), &szName))
return false;
Tracef(" SendGuildChangeGradeNamePacket %d, %s\n", byGradeNumber, c_szName);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildChangeGradeAuthorityPacket(BYTE byGradeNumber, BYTE byAuthority)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_CHANGE_GRADE_AUTHORITY;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(byGradeNumber), &byGradeNumber))
return false;
if (!Send(sizeof(byAuthority), &byAuthority))
return false;
Tracef(" SendGuildChangeGradeAuthorityPacket %d, %d\n", byGradeNumber, byAuthority);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildOfferPacket(DWORD dwExperience)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_OFFER;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwExperience), &dwExperience))
return false;
Tracef(" SendGuildOfferPacket %d\n", dwExperience);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildPostCommentPacket(const char * c_szMessage)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_POST_COMMENT;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
BYTE bySize = BYTE(strlen(c_szMessage)) + 1;
if (!Send(sizeof(bySize), &bySize))
return false;
if (!Send(bySize, c_szMessage))
return false;
Tracef(" SendGuildPostCommentPacket %d, %s\n", bySize, c_szMessage);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildDeleteCommentPacket(DWORD dwIndex)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_DELETE_COMMENT;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwIndex), &dwIndex))
return false;
Tracef(" SendGuildDeleteCommentPacket %d\n", dwIndex);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildRefreshCommentsPacket(DWORD dwHighestIndex)
{
static DWORD s_LastTime = timeGetTime() - 1001;
if (timeGetTime() - s_LastTime < 1000)
return true;
s_LastTime = timeGetTime();
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_REFRESH_COMMENT;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
Tracef(" SendGuildRefreshCommentPacket %d\n", dwHighestIndex);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildChangeMemberGradePacket(DWORD dwPID, BYTE byGrade)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_CHANGE_MEMBER_GRADE;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwPID), &dwPID))
return false;
if (!Send(sizeof(byGrade), &byGrade))
return false;
Tracef(" SendGuildChangeMemberGradePacket %d, %d\n", dwPID, byGrade);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildUseSkillPacket(DWORD dwSkillID, DWORD dwTargetVID)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_USE_SKILL;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwSkillID), &dwSkillID))
return false;
if (!Send(sizeof(dwTargetVID), &dwTargetVID))
return false;
Tracef(" SendGuildUseSkillPacket %d, %d\n", dwSkillID, dwTargetVID);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildChangeMemberGeneralPacket(DWORD dwPID, BYTE byFlag)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_CHANGE_MEMBER_GENERAL;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwPID), &dwPID))
return false;
if (!Send(sizeof(byFlag), &byFlag))
return false;
Tracef(" SendGuildChangeMemberGeneralFlagPacket %d, %d\n", dwPID, byFlag);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildInviteAnswerPacket(DWORD dwGuildID, BYTE byAnswer)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_GUILD_INVITE_ANSWER;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwGuildID), &dwGuildID))
return false;
if (!Send(sizeof(byAnswer), &byAnswer))
return false;
Tracef(" SendGuildInviteAnswerPacket %d, %d\n", dwGuildID, byAnswer);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildChargeGSPPacket(DWORD dwMoney)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_CHARGE_GSP;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwMoney), &dwMoney))
return false;
Tracef(" SendGuildChargeGSPPacket %d\n", dwMoney);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildDepositMoneyPacket(DWORD dwMoney)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_DEPOSIT_MONEY;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwMoney), &dwMoney))
return false;
Tracef(" SendGuildDepositMoneyPacket %d\n", dwMoney);
return SendSequence();
}
bool CPythonNetworkStream::SendGuildWithdrawMoneyPacket(DWORD dwMoney)
{
TPacketCGGuild GuildPacket;
GuildPacket.byHeader = HEADER_CG_GUILD;
GuildPacket.bySubHeader = GUILD_SUBHEADER_CG_WITHDRAW_MONEY;
if (!Send(sizeof(GuildPacket), &GuildPacket))
return false;
if (!Send(sizeof(dwMoney), &dwMoney))
return false;
Tracef(" SendGuildWithdrawMoneyPacket %d\n", dwMoney);
return SendSequence();
}
bool CPythonNetworkStream::RecvGuild()
{
TPacketGCGuild GuildPacket;
if (!Recv(sizeof(GuildPacket), &GuildPacket))
return false;
switch(GuildPacket.subheader)
{
case GUILD_SUBHEADER_GC_LOGIN:
{
DWORD dwPID;
if (!Recv(sizeof(DWORD), &dwPID))
return false;
// Messenger
CPythonGuild::TGuildMemberData * pGuildMemberData;
if (CPythonGuild::Instance().GetMemberDataPtrByPID(dwPID, &pGuildMemberData))
if (0 != pGuildMemberData->strName.compare(CPythonPlayer::Instance().GetName()))
CPythonMessenger::Instance().LoginGuildMember(pGuildMemberData->strName.c_str());
//Tracef(" <Login> %d\n", dwPID);
break;
}
case GUILD_SUBHEADER_GC_LOGOUT:
{
DWORD dwPID;
if (!Recv(sizeof(DWORD), &dwPID))
return false;
// Messenger
CPythonGuild::TGuildMemberData * pGuildMemberData;
if (CPythonGuild::Instance().GetMemberDataPtrByPID(dwPID, &pGuildMemberData))
if (0 != pGuildMemberData->strName.compare(CPythonPlayer::Instance().GetName()))
CPythonMessenger::Instance().LogoutGuildMember(pGuildMemberData->strName.c_str());
//Tracef(" <Logout> %d\n", dwPID);
break;
}
case GUILD_SUBHEADER_GC_REMOVE:
{
DWORD dwPID;
if (!Recv(sizeof(dwPID), &dwPID))
return false;
// Main Player <20><> <20><><EFBFBD><EFBFBD> DeleteGuild
if (CPythonGuild::Instance().IsMainPlayer(dwPID))
{
CPythonGuild::Instance().Destroy();
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "DeleteGuild", Py_BuildValue("()"));
CPythonMessenger::Instance().RemoveAllGuildMember();
__SetGuildID(0);
__RefreshMessengerWindow();
__RefreshTargetBoard();
__RefreshCharacterWindow();
}
else
{
// Get Member Name
std::string strMemberName = "";
CPythonGuild::TGuildMemberData * pData;
if (CPythonGuild::Instance().GetMemberDataPtrByPID(dwPID, &pData))
{
strMemberName = pData->strName;
CPythonMessenger::Instance().RemoveGuildMember(pData->strName.c_str());
}
CPythonGuild::Instance().RemoveMember(dwPID);
// Refresh
__RefreshTargetBoardByName(strMemberName.c_str());
__RefreshGuildWindowMemberPage();
}
Tracef(" <Remove> %d\n", dwPID);
break;
}
case GUILD_SUBHEADER_GC_LIST:
{
int iPacketSize = int(GuildPacket.size) - sizeof(GuildPacket);
for (; iPacketSize > 0;)
{
TPacketGCGuildSubMember memberPacket;
if (!Recv(sizeof(memberPacket), &memberPacket))
return false;
char szName[CHARACTER_NAME_MAX_LEN+1] = "";
if (memberPacket.byNameFlag)
{
if (!Recv(sizeof(szName), &szName))
return false;
iPacketSize -= CHARACTER_NAME_MAX_LEN+1;
}
else
{
CPythonGuild::TGuildMemberData * pMemberData;
if (CPythonGuild::Instance().GetMemberDataPtrByPID(memberPacket.pid, &pMemberData))
{
strncpy(szName, pMemberData->strName.c_str(), CHARACTER_NAME_MAX_LEN);
}
}
//Tracef(" <List> %d : %s, %d (%d, %d, %d)\n", memberPacket.pid, szName, memberPacket.byGrade, memberPacket.byJob, memberPacket.byLevel, memberPacket.dwOffer);
CPythonGuild::SGuildMemberData GuildMemberData;
GuildMemberData.dwPID = memberPacket.pid;
GuildMemberData.byGrade = memberPacket.byGrade;
GuildMemberData.strName = szName;
GuildMemberData.byJob = memberPacket.byJob;
GuildMemberData.byLevel = memberPacket.byLevel;
GuildMemberData.dwOffer = memberPacket.dwOffer;
GuildMemberData.byGeneralFlag = memberPacket.byIsGeneral;
CPythonGuild::Instance().RegisterMember(GuildMemberData);
// Messenger
if (strcmp(szName, CPythonPlayer::Instance().GetName()))
CPythonMessenger::Instance().AppendGuildMember(szName);
__RefreshTargetBoardByName(szName);
iPacketSize -= sizeof(memberPacket);
}
__RefreshGuildWindowInfoPage();
__RefreshGuildWindowMemberPage();
__RefreshMessengerWindow();
__RefreshCharacterWindow();
break;
}
case GUILD_SUBHEADER_GC_GRADE:
{
BYTE byCount;
if (!Recv(sizeof(byCount), &byCount))
return false;
for (BYTE i = 0; i < byCount; ++ i)
{
BYTE byIndex;
if (!Recv(sizeof(byCount), &byIndex))
return false;
TPacketGCGuildSubGrade GradePacket;
if (!Recv(sizeof(GradePacket), &GradePacket))
return false;
CPythonGuild::Instance().SetGradeData(byIndex, CPythonGuild::SGuildGradeData(GradePacket.auth_flag, GradePacket.grade_name));
//Tracef(" <Grade> [%d/%d] : %s, %d\n", byIndex, byCount, GradePacket.grade_name, GradePacket.auth_flag);
}
__RefreshGuildWindowGradePage();
__RefreshGuildWindowMemberPageGradeComboBox();
break;
}
case GUILD_SUBHEADER_GC_GRADE_NAME:
{
BYTE byGradeNumber;
if (!Recv(sizeof(byGradeNumber), &byGradeNumber))
return false;
char szGradeName[GUILD_GRADE_NAME_MAX_LEN+1] = "";
if (!Recv(sizeof(szGradeName), &szGradeName))
return false;
CPythonGuild::Instance().SetGradeName(byGradeNumber, szGradeName);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildGrade", Py_BuildValue("()"));
Tracef(" <Change Grade Name> %d, %s\n", byGradeNumber, szGradeName);
__RefreshGuildWindowGradePage();
__RefreshGuildWindowMemberPageGradeComboBox();
break;
}
case GUILD_SUBHEADER_GC_GRADE_AUTH:
{
BYTE byGradeNumber;
if (!Recv(sizeof(byGradeNumber), &byGradeNumber))
return false;
BYTE byAuthorityFlag;
if (!Recv(sizeof(byAuthorityFlag), &byAuthorityFlag))
return false;
CPythonGuild::Instance().SetGradeAuthority(byGradeNumber, byAuthorityFlag);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshGuildGrade", Py_BuildValue("()"));
Tracef(" <Change Grade Authority> %d, %d\n", byGradeNumber, byAuthorityFlag);
__RefreshGuildWindowGradePage();
break;
}
case GUILD_SUBHEADER_GC_INFO:
{
TPacketGCGuildInfo GuildInfo;
if (!Recv(sizeof(GuildInfo), &GuildInfo))
return false;
CPythonGuild::Instance().EnableGuild();
CPythonGuild::TGuildInfo & rGuildInfo = CPythonGuild::Instance().GetGuildInfoRef();
strncpy(rGuildInfo.szGuildName, GuildInfo.name, GUILD_NAME_MAX_LEN);
rGuildInfo.szGuildName[GUILD_NAME_MAX_LEN] = '\0';
rGuildInfo.dwGuildID = GuildInfo.guild_id;
rGuildInfo.dwMasterPID = GuildInfo.master_pid;
rGuildInfo.dwGuildLevel = GuildInfo.level;
rGuildInfo.dwCurrentExperience = GuildInfo.exp;
rGuildInfo.dwCurrentMemberCount = GuildInfo.member_count;
rGuildInfo.dwMaxMemberCount = GuildInfo.max_member_count;
rGuildInfo.dwGuildMoney = GuildInfo.gold;
rGuildInfo.bHasLand = GuildInfo.hasLand;
//Tracef(" <Info> %s, %d, %d : %d\n", GuildInfo.name, GuildInfo.master_pid, GuildInfo.level, rGuildInfo.bHasLand);
__RefreshGuildWindowInfoPage();
break;
}
case GUILD_SUBHEADER_GC_COMMENTS:
{
BYTE byCount;
if (!Recv(sizeof(byCount), &byCount))
return false;
CPythonGuild::Instance().ClearComment();
//Tracef(" >>> Comments Count : %d\n", byCount);
for (BYTE i = 0; i < byCount; ++i)
{
DWORD dwCommentID;
if (!Recv(sizeof(dwCommentID), &dwCommentID))
return false;
char szName[CHARACTER_NAME_MAX_LEN+1] = "";
if (!Recv(sizeof(szName), &szName))
return false;
char szComment[GULID_COMMENT_MAX_LEN+1] = "";
if (!Recv(sizeof(szComment), &szComment))
return false;
//Tracef(" [Comment-%d] : %s, %s\n", dwCommentID, szName, szComment);
CPythonGuild::Instance().RegisterComment(dwCommentID, szName, szComment);
}
__RefreshGuildWindowBoardPage();
break;
}
case GUILD_SUBHEADER_GC_CHANGE_EXP:
{
BYTE byLevel;
if (!Recv(sizeof(byLevel), &byLevel))
return false;
DWORD dwEXP;
if (!Recv(sizeof(dwEXP), &dwEXP))
return false;
CPythonGuild::Instance().SetGuildEXP(byLevel, dwEXP);
Tracef(" <ChangeEXP> %d, %d\n", byLevel, dwEXP);
__RefreshGuildWindowInfoPage();
break;
}
case GUILD_SUBHEADER_GC_CHANGE_MEMBER_GRADE:
{
DWORD dwPID;
if (!Recv(sizeof(dwPID), &dwPID))
return false;
BYTE byGrade;
if (!Recv(sizeof(byGrade), &byGrade))
return false;
CPythonGuild::Instance().ChangeGuildMemberGrade(dwPID, byGrade);
Tracef(" <ChangeMemberGrade> %d, %d\n", dwPID, byGrade);
__RefreshGuildWindowMemberPage();
break;
}
case GUILD_SUBHEADER_GC_SKILL_INFO:
{
CPythonGuild::TGuildSkillData & rSkillData = CPythonGuild::Instance().GetGuildSkillDataRef();
if (!Recv(sizeof(rSkillData.bySkillPoint), &rSkillData.bySkillPoint))
return false;
if (!Recv(sizeof(rSkillData.bySkillLevel), rSkillData.bySkillLevel))
return false;
if (!Recv(sizeof(rSkillData.wGuildPoint), &rSkillData.wGuildPoint))
return false;
if (!Recv(sizeof(rSkillData.wMaxGuildPoint), &rSkillData.wMaxGuildPoint))
return false;
Tracef(" <SkillInfo> %d / %d, %d\n", rSkillData.bySkillPoint, rSkillData.wGuildPoint, rSkillData.wMaxGuildPoint);
__RefreshGuildWindowSkillPage();
break;
}
case GUILD_SUBHEADER_GC_CHANGE_MEMBER_GENERAL:
{
DWORD dwPID;
if (!Recv(sizeof(dwPID), &dwPID))
return false;
BYTE byFlag;
if (!Recv(sizeof(byFlag), &byFlag))
return false;
CPythonGuild::Instance().ChangeGuildMemberGeneralFlag(dwPID, byFlag);
Tracef(" <ChangeMemberGeneralFlag> %d, %d\n", dwPID, byFlag);
__RefreshGuildWindowMemberPage();
break;
}
case GUILD_SUBHEADER_GC_GUILD_INVITE:
{
DWORD dwGuildID;
if (!Recv(sizeof(dwGuildID), &dwGuildID))
return false;
char szGuildName[GUILD_NAME_MAX_LEN+1];
if (!Recv(GUILD_NAME_MAX_LEN, &szGuildName))
return false;
szGuildName[GUILD_NAME_MAX_LEN] = 0;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RecvGuildInviteQuestion", Py_BuildValue("(is)", dwGuildID, szGuildName));
Tracef(" <Guild Invite> %d, %s\n", dwGuildID, szGuildName);
break;
}
case GUILD_SUBHEADER_GC_WAR:
{
TPacketGCGuildWar kGuildWar;
if (!Recv(sizeof(kGuildWar), &kGuildWar))
return false;
switch (kGuildWar.bWarState)
{
case GUILD_WAR_SEND_DECLARE:
Tracef(" >> GUILD_SUBHEADER_GC_WAR : GUILD_WAR_SEND_DECLARE\n");
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_GuildWar_OnSendDeclare",
Py_BuildValue("(i)", kGuildWar.dwGuildOpp)
);
break;
case GUILD_WAR_RECV_DECLARE:
Tracef(" >> GUILD_SUBHEADER_GC_WAR : GUILD_WAR_RECV_DECLARE\n");
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_GuildWar_OnRecvDeclare",
Py_BuildValue("(ii)", kGuildWar.dwGuildOpp, kGuildWar.bType)
);
break;
case GUILD_WAR_ON_WAR:
Tracef(" >> GUILD_SUBHEADER_GC_WAR : GUILD_WAR_ON_WAR : %d, %d\n", kGuildWar.dwGuildSelf, kGuildWar.dwGuildOpp);
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_GuildWar_OnStart",
Py_BuildValue("(ii)", kGuildWar.dwGuildSelf, kGuildWar.dwGuildOpp)
);
CPythonGuild::Instance().StartGuildWar(kGuildWar.dwGuildOpp);
break;
case GUILD_WAR_END:
Tracef(" >> GUILD_SUBHEADER_GC_WAR : GUILD_WAR_END\n");
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_GuildWar_OnEnd",
Py_BuildValue("(ii)", kGuildWar.dwGuildSelf, kGuildWar.dwGuildOpp)
);
CPythonGuild::Instance().EndGuildWar(kGuildWar.dwGuildOpp);
break;
}
break;
}
case GUILD_SUBHEADER_GC_GUILD_NAME:
{
DWORD dwID;
char szGuildName[GUILD_NAME_MAX_LEN+1];
int iPacketSize = int(GuildPacket.size) - sizeof(GuildPacket);
int nItemSize = sizeof(dwID) + GUILD_NAME_MAX_LEN;
assert(iPacketSize%nItemSize==0 && "GUILD_SUBHEADER_GC_GUILD_NAME");
for (; iPacketSize > 0;)
{
if (!Recv(sizeof(dwID), &dwID))
return false;
if (!Recv(GUILD_NAME_MAX_LEN, &szGuildName))
return false;
szGuildName[GUILD_NAME_MAX_LEN] = 0;
//Tracef(" >> GulidName [%d : %s]\n", dwID, szGuildName);
CPythonGuild::Instance().RegisterGuildName(dwID, szGuildName);
iPacketSize -= nItemSize;
}
break;
}
case GUILD_SUBHEADER_GC_GUILD_WAR_LIST:
{
DWORD dwSrcGuildID;
DWORD dwDstGuildID;
int iPacketSize = int(GuildPacket.size) - sizeof(GuildPacket);
int nItemSize = sizeof(dwSrcGuildID) + sizeof(dwDstGuildID);
assert(iPacketSize%nItemSize==0 && "GUILD_SUBHEADER_GC_GUILD_WAR_LIST");
for (; iPacketSize > 0;)
{
if (!Recv(sizeof(dwSrcGuildID), &dwSrcGuildID))
return false;
if (!Recv(sizeof(dwDstGuildID), &dwDstGuildID))
return false;
Tracef(" >> GulidWarList [%d vs %d]\n", dwSrcGuildID, dwDstGuildID);
CInstanceBase::InsertGVGKey(dwSrcGuildID, dwDstGuildID);
CPythonCharacterManager::Instance().ChangeGVG(dwSrcGuildID, dwDstGuildID);
iPacketSize -= nItemSize;
}
break;
}
case GUILD_SUBHEADER_GC_GUILD_WAR_END_LIST:
{
DWORD dwSrcGuildID;
DWORD dwDstGuildID;
int iPacketSize = int(GuildPacket.size) - sizeof(GuildPacket);
int nItemSize = sizeof(dwSrcGuildID) + sizeof(dwDstGuildID);
assert(iPacketSize%nItemSize==0 && "GUILD_SUBHEADER_GC_GUILD_WAR_END_LIST");
for (; iPacketSize > 0;)
{
if (!Recv(sizeof(dwSrcGuildID), &dwSrcGuildID))
return false;
if (!Recv(sizeof(dwDstGuildID), &dwDstGuildID))
return false;
Tracef(" >> GulidWarEndList [%d vs %d]\n", dwSrcGuildID, dwDstGuildID);
CInstanceBase::RemoveGVGKey(dwSrcGuildID, dwDstGuildID);
CPythonCharacterManager::Instance().ChangeGVG(dwSrcGuildID, dwDstGuildID);
iPacketSize -= nItemSize;
}
break;
}
case GUILD_SUBHEADER_GC_WAR_POINT:
{
TPacketGuildWarPoint GuildWarPoint;
if (!Recv(sizeof(GuildWarPoint), &GuildWarPoint))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_GuildWar_OnRecvPoint",
Py_BuildValue("(iii)", GuildWarPoint.dwGainGuildID, GuildWarPoint.dwOpponentGuildID, GuildWarPoint.lPoint)
);
break;
}
case GUILD_SUBHEADER_GC_MONEY_CHANGE:
{
DWORD dwMoney;
if (!Recv(sizeof(dwMoney), &dwMoney))
return false;
CPythonGuild::Instance().SetGuildMoney(dwMoney);
__RefreshGuildWindowInfoPage();
Tracef(" >> Guild Money Change : %d\n", dwMoney);
break;
}
}
return true;
}
// Guild
//////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////
// Fishing
bool CPythonNetworkStream::SendFishingPacket(int iRotation)
{
BYTE byHeader = HEADER_CG_FISHING;
if (!Send(sizeof(byHeader), &byHeader))
return false;
BYTE byPacketRotation = iRotation / 5;
if (!Send(sizeof(BYTE), &byPacketRotation))
return false;
return SendSequence();
}
bool CPythonNetworkStream::SendGiveItemPacket(DWORD dwTargetVID, TItemPos ItemPos, int iItemCount)
{
TPacketCGGiveItem GiveItemPacket;
GiveItemPacket.byHeader = HEADER_CG_GIVE_ITEM;
GiveItemPacket.dwTargetVID = dwTargetVID;
GiveItemPacket.ItemPos = ItemPos;
GiveItemPacket.byItemCount = iItemCount;
if (!Send(sizeof(GiveItemPacket), &GiveItemPacket))
return false;
return SendSequence();
}
bool CPythonNetworkStream::RecvFishing()
{
TPacketGCFishing FishingPacket;
if (!Recv(sizeof(FishingPacket), &FishingPacket))
return false;
CInstanceBase * pFishingInstance = NULL;
if (FISHING_SUBHEADER_GC_FISH != FishingPacket.subheader)
{
pFishingInstance = CPythonCharacterManager::Instance().GetInstancePtr(FishingPacket.info);
if (!pFishingInstance)
return true;
}
switch (FishingPacket.subheader)
{
case FISHING_SUBHEADER_GC_START:
pFishingInstance->StartFishing(float(FishingPacket.dir) * 5.0f);
break;
case FISHING_SUBHEADER_GC_STOP:
if (pFishingInstance->IsFishing())
pFishingInstance->StopFishing();
break;
case FISHING_SUBHEADER_GC_REACT:
if (pFishingInstance->IsFishing())
{
pFishingInstance->SetFishEmoticon(); // Fish Emoticon
pFishingInstance->ReactFishing();
}
break;
case FISHING_SUBHEADER_GC_SUCCESS:
pFishingInstance->CatchSuccess();
break;
case FISHING_SUBHEADER_GC_FAIL:
pFishingInstance->CatchFail();
if (pFishingInstance == CPythonCharacterManager::Instance().GetMainInstancePtr())
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnFishingFailure", Py_BuildValue("()"));
}
break;
case FISHING_SUBHEADER_GC_FISH:
{
DWORD dwFishID = FishingPacket.info;
if (0 == FishingPacket.info)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnFishingNotifyUnknown", Py_BuildValue("()"));
return true;
}
CItemData * pItemData;
if (!CItemManager::Instance().GetItemDataPointer(dwFishID, &pItemData))
return true;
CInstanceBase * pMainInstance = CPythonCharacterManager::Instance().GetMainInstancePtr();
if (!pMainInstance)
return true;
if (pMainInstance->IsFishing())
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnFishingNotify", Py_BuildValue("(is)", CItemData::ITEM_TYPE_FISH == pItemData->GetType(), pItemData->GetName()));
}
else
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OnFishingSuccess", Py_BuildValue("(is)", CItemData::ITEM_TYPE_FISH == pItemData->GetType(), pItemData->GetName()));
}
break;
}
}
return true;
}
// Fishing
/////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////
// Dungeon
bool CPythonNetworkStream::RecvDungeon()
{
TPacketGCDungeon DungeonPacket;
if (!Recv(sizeof(DungeonPacket), &DungeonPacket))
return false;
switch (DungeonPacket.subheader)
{
case DUNGEON_SUBHEADER_GC_TIME_ATTACK_START:
{
break;
}
case DUNGEON_SUBHEADER_GC_DESTINATION_POSITION:
{
unsigned long ulx, uly;
if (!Recv(sizeof(ulx), &ulx))
return false;
if (!Recv(sizeof(uly), &uly))
return false;
CPythonPlayer::Instance().SetDungeonDestinationPosition(ulx, uly);
break;
}
}
return true;
}
// Dungeon
/////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////
// MyShop
bool CPythonNetworkStream::SendBuildPrivateShopPacket(const char * c_szName, const std::vector<TShopItemTable> & c_rSellingItemStock)
{
TPacketCGMyShop packet;
packet.bHeader = HEADER_CG_MYSHOP;
strncpy(packet.szSign, c_szName, SHOP_SIGN_MAX_LEN);
packet.bCount = c_rSellingItemStock.size();
if (!Send(sizeof(packet), &packet))
return false;
for (std::vector<TShopItemTable>::const_iterator itor = c_rSellingItemStock.begin(); itor < c_rSellingItemStock.end(); ++itor)
{
const TShopItemTable & c_rItem = *itor;
if (!Send(sizeof(c_rItem), &c_rItem))
return false;
}
return SendSequence();
}
bool CPythonNetworkStream::RecvShopSignPacket()
{
TPacketGCShopSign p;
if (!Recv(sizeof(TPacketGCShopSign), &p))
return false;
CPythonPlayer& rkPlayer=CPythonPlayer::Instance();
if (0 == strlen(p.szSign))
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_PrivateShop_Disappear",
Py_BuildValue("(i)", p.dwVID)
);
if (rkPlayer.IsMainCharacterIndex(p.dwVID))
rkPlayer.ClosePrivateShop();
}
else
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"BINARY_PrivateShop_Appear",
Py_BuildValue("(is)", p.dwVID, p.szSign)
);
if (rkPlayer.IsMainCharacterIndex(p.dwVID))
rkPlayer.OpenPrivateShop();
}
return true;
}
/////////////////////////////////////////////////////////////////////////
bool CPythonNetworkStream::RecvTimePacket()
{
TPacketGCTime TimePacket;
if (!Recv(sizeof(TimePacket), &TimePacket))
return false;
IAbstractApplication& rkApp=IAbstractApplication::GetSingleton();
rkApp.SetServerTime(TimePacket.time);
return true;
}
bool CPythonNetworkStream::RecvWalkModePacket()
{
TPacketGCWalkMode WalkModePacket;
if (!Recv(sizeof(WalkModePacket), &WalkModePacket))
return false;
CInstanceBase * pInstance = CPythonCharacterManager::Instance().GetInstancePtr(WalkModePacket.vid);
if (pInstance)
{
if (WALKMODE_RUN == WalkModePacket.mode)
{
pInstance->SetRunMode();
}
else
{
pInstance->SetWalkMode();
}
}
return true;
}
bool CPythonNetworkStream::RecvChangeSkillGroupPacket()
{
TPacketGCChangeSkillGroup ChangeSkillGroup;
if (!Recv(sizeof(ChangeSkillGroup), &ChangeSkillGroup))
return false;
m_dwMainActorSkillGroup = ChangeSkillGroup.skill_group;
CPythonPlayer::Instance().NEW_ClearSkillData();
__RefreshCharacterWindow();
return true;
}
void CPythonNetworkStream::__TEST_SetSkillGroupFake(int iIndex)
{
m_dwMainActorSkillGroup = DWORD(iIndex);
CPythonPlayer::Instance().NEW_ClearSkillData();
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "RefreshCharacter", Py_BuildValue("()"));
}
bool CPythonNetworkStream::SendRefinePacket(BYTE byPos, BYTE byType)
{
TPacketCGRefine kRefinePacket;
kRefinePacket.header = HEADER_CG_REFINE;
kRefinePacket.pos = byPos;
kRefinePacket.type = byType;
if (!Send(sizeof(kRefinePacket), &kRefinePacket))
return false;
return SendSequence();
}
bool CPythonNetworkStream::SendSelectItemPacket(DWORD dwItemPos)
{
TPacketCGScriptSelectItem kScriptSelectItem;
kScriptSelectItem.header = HEADER_CG_SCRIPT_SELECT_ITEM;
kScriptSelectItem.selection = dwItemPos;
if (!Send(sizeof(kScriptSelectItem), &kScriptSelectItem))
return false;
return SendSequence();
}
bool CPythonNetworkStream::RecvRefineInformationPacket()
{
TPacketGCRefineInformation kRefineInfoPacket;
if (!Recv(sizeof(kRefineInfoPacket), &kRefineInfoPacket))
return false;
TRefineTable & rkRefineTable = kRefineInfoPacket.refine_table;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"OpenRefineDialog",
Py_BuildValue("(iiii)",
kRefineInfoPacket.pos,
kRefineInfoPacket.refine_table.result_vnum,
rkRefineTable.cost,
rkRefineTable.prob));
for (int i = 0; i < rkRefineTable.material_count; ++i)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "AppendMaterialToRefineDialog", Py_BuildValue("(ii)", rkRefineTable.materials[i].vnum, rkRefineTable.materials[i].count));
}
#ifdef _DEBUG
Tracef(" >> RecvRefineInformationPacket(pos=%d, result_vnum=%d, cost=%d, prob=%d)\n",
kRefineInfoPacket.pos,
kRefineInfoPacket.refine_table.result_vnum,
rkRefineTable.cost,
rkRefineTable.prob);
#endif
return true;
}
bool CPythonNetworkStream::RecvRefineInformationPacketNew()
{
TPacketGCRefineInformationNew kRefineInfoPacket;
if (!Recv(sizeof(kRefineInfoPacket), &kRefineInfoPacket))
return false;
TRefineTable & rkRefineTable = kRefineInfoPacket.refine_table;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME],
"OpenRefineDialog",
Py_BuildValue("(iiiii)",
kRefineInfoPacket.pos,
kRefineInfoPacket.refine_table.result_vnum,
rkRefineTable.cost,
rkRefineTable.prob,
kRefineInfoPacket.type)
);
for (int i = 0; i < rkRefineTable.material_count; ++i)
{
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "AppendMaterialToRefineDialog", Py_BuildValue("(ii)", rkRefineTable.materials[i].vnum, rkRefineTable.materials[i].count));
}
#ifdef _DEBUG
Tracef(" >> RecvRefineInformationPacketNew(pos=%d, result_vnum=%d, cost=%d, prob=%d, type=%d)\n",
kRefineInfoPacket.pos,
kRefineInfoPacket.refine_table.result_vnum,
rkRefineTable.cost,
rkRefineTable.prob,
kRefineInfoPacket.type);
#endif
return true;
}
bool CPythonNetworkStream::RecvNPCList()
{
TPacketGCNPCPosition kNPCPosition;
if (!Recv(sizeof(kNPCPosition), &kNPCPosition))
return false;
assert(int(kNPCPosition.size)-sizeof(kNPCPosition) == kNPCPosition.count*sizeof(TNPCPosition) && "HEADER_GC_NPC_POSITION");
CPythonMiniMap::Instance().ClearAtlasMarkInfo();
for (int i = 0; i < kNPCPosition.count; ++i)
{
TNPCPosition NPCPosition;
if (!Recv(sizeof(TNPCPosition), &NPCPosition))
return false;
CPythonMiniMap::Instance().RegisterAtlasMark(NPCPosition.bType, NPCPosition.name, NPCPosition.x, NPCPosition.y);
}
return true;
}
bool CPythonNetworkStream::__SendCRCReportPacket()
{
/*
DWORD dwProcessCRC = 0;
DWORD dwFileCRC = 0;
CFilename exeFileName;
//LPCVOID c_pvBaseAddress = NULL;
GetExeCRC(dwProcessCRC, dwFileCRC);
CFilename strRootPackFileName = CEterPackManager::Instance().GetRootPacketFileName();
strRootPackFileName.ChangeDosPath();
TPacketCGCRCReport kReportPacket;
kReportPacket.header = HEADER_CG_CRC_REPORT;
kReportPacket.byPackMode = CEterPackManager::Instance().GetSearchMode();
kReportPacket.dwBinaryCRC32 = dwFileCRC;
kReportPacket.dwProcessCRC32 = dwProcessCRC;
kReportPacket.dwRootPackCRC32 = GetFileCRC32(strRootPackFileName.c_str());
if (!Send(sizeof(kReportPacket), &kReportPacket))
Tracef("SendClientReportPacket Error");
return SendSequence();
*/
return true;
}
bool CPythonNetworkStream::SendClientVersionPacket()
{
std::string filename;
GetExcutedFileName(filename);
filename = CFileNameHelper::NoPath(filename);
CFileNameHelper::ChangeDosPath(filename);
if (LocaleService_IsEUROPE() && false == LocaleService_IsYMIR())
{
TPacketCGClientVersion2 kVersionPacket;
kVersionPacket.header = HEADER_CG_CLIENT_VERSION2;
strncpy(kVersionPacket.filename, filename.c_str(), sizeof(kVersionPacket.filename)-1);
strncpy(kVersionPacket.timestamp, "1215955205", sizeof(kVersionPacket.timestamp)-1); // # python time.time <20><><EFBFBD>ڸ<EFBFBD>
//strncpy(kVersionPacket.timestamp, __TIMESTAMP__, sizeof(kVersionPacket.timestamp)-1); // old_string_ver
//strncpy(kVersionPacket.timestamp, "1218055205", sizeof(kVersionPacket.timestamp)-1); // new_future
//strncpy(kVersionPacket.timestamp, "1214055205", sizeof(kVersionPacket.timestamp)-1); // old_past
if (!Send(sizeof(kVersionPacket), &kVersionPacket))
Tracef("SendClientReportPacket Error");
}
else
{
TPacketCGClientVersion kVersionPacket;
kVersionPacket.header = HEADER_CG_CLIENT_VERSION;
strncpy(kVersionPacket.filename, filename.c_str(), sizeof(kVersionPacket.filename)-1);
strncpy(kVersionPacket.timestamp, __TIMESTAMP__, sizeof(kVersionPacket.timestamp)-1);
if (!Send(sizeof(kVersionPacket), &kVersionPacket))
Tracef("SendClientReportPacket Error");
}
return SendSequence();
}
bool CPythonNetworkStream::RecvAffectAddPacket()
{
TPacketGCAffectAdd kAffectAdd;
if (!Recv(sizeof(kAffectAdd), &kAffectAdd))
return false;
TPacketAffectElement & rkElement = kAffectAdd.elem;
if (rkElement.bPointIdxApplyOn == POINT_ENERGY)
{
CPythonPlayer::instance().SetStatus (POINT_ENERGY_END_TIME, CPythonApplication::Instance().GetServerTimeStamp() + rkElement.lDuration);
__RefreshStatus();
}
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_NEW_AddAffect", Py_BuildValue("(iiii)", rkElement.dwType, rkElement.bPointIdxApplyOn, rkElement.lApplyValue, rkElement.lDuration));
return true;
}
bool CPythonNetworkStream::RecvAffectRemovePacket()
{
TPacketGCAffectRemove kAffectRemove;
if (!Recv(sizeof(kAffectRemove), &kAffectRemove))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_NEW_RemoveAffect", Py_BuildValue("(ii)", kAffectRemove.dwType, kAffectRemove.bApplyOn));
return true;
}
bool CPythonNetworkStream::RecvChannelPacket()
{
TPacketGCChannel kChannelPacket;
if (!Recv(sizeof(kChannelPacket), &kChannelPacket))
return false;
//Tracef(" >> CPythonNetworkStream::RecvChannelPacket(channel=%d)\n", kChannelPacket.channel);
return true;
}
bool CPythonNetworkStream::RecvViewEquipPacket()
{
TPacketGCViewEquip kViewEquipPacket;
if (!Recv(sizeof(kViewEquipPacket), &kViewEquipPacket))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "OpenEquipmentDialog", Py_BuildValue("(i)", kViewEquipPacket.dwVID));
for (int i = 0; i < WEAR_MAX_NUM; ++i)
{
TEquipmentItemSet & rItemSet = kViewEquipPacket.equips[i];
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "SetEquipmentDialogItem", Py_BuildValue("(iiii)", kViewEquipPacket.dwVID, i, rItemSet.vnum, rItemSet.count));
for (int j = 0; j < ITEM_SOCKET_SLOT_MAX_NUM; ++j)
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "SetEquipmentDialogSocket", Py_BuildValue("(iiii)", kViewEquipPacket.dwVID, i, j, rItemSet.alSockets[j]));
for (int k = 0; k < ITEM_ATTRIBUTE_SLOT_MAX_NUM; ++k)
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "SetEquipmentDialogAttr", Py_BuildValue("(iiiii)", kViewEquipPacket.dwVID, i, k, rItemSet.aAttr[k].bType, rItemSet.aAttr[k].sValue));
}
return true;
}
bool CPythonNetworkStream::RecvLandPacket()
{
TPacketGCLandList kLandList;
if (!Recv(sizeof(kLandList), &kLandList))
return false;
std::vector<DWORD> kVec_dwGuildID;
CPythonMiniMap & rkMiniMap = CPythonMiniMap::Instance();
CPythonBackground & rkBG = CPythonBackground::Instance();
CInstanceBase * pMainInstance = CPythonPlayer::Instance().NEW_GetMainActorPtr();
rkMiniMap.ClearGuildArea();
rkBG.ClearGuildArea();
int iPacketSize = (kLandList.size - sizeof(TPacketGCLandList));
for (; iPacketSize > 0; iPacketSize-=sizeof(TLandPacketElement))
{
TLandPacketElement kElement;
if (!Recv(sizeof(TLandPacketElement), &kElement))
return false;
rkMiniMap.RegisterGuildArea(kElement.dwID,
kElement.dwGuildID,
kElement.x,
kElement.y,
kElement.width,
kElement.height);
if (pMainInstance)
if (kElement.dwGuildID == pMainInstance->GetGuildID())
{
rkBG.RegisterGuildArea(kElement.x,
kElement.y,
kElement.x+kElement.width,
kElement.y+kElement.height);
}
if (0 != kElement.dwGuildID)
kVec_dwGuildID.push_back(kElement.dwGuildID);
}
__DownloadSymbol(kVec_dwGuildID);
return true;
}
bool CPythonNetworkStream::RecvTargetCreatePacket()
{
TPacketGCTargetCreate kTargetCreate;
if (!Recv(sizeof(kTargetCreate), &kTargetCreate))
return false;
CPythonMiniMap & rkpyMiniMap = CPythonMiniMap::Instance();
rkpyMiniMap.CreateTarget(kTargetCreate.lID, kTargetCreate.szTargetName);
//#ifdef _DEBUG
// char szBuf[256+1];
// _snprintf(szBuf, sizeof(szBuf), "Ÿ<><C5B8><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20>Ǿ<EFBFBD><C7BE><EFBFBD><EFBFBD>ϴ<EFBFBD> [%d:%s]", kTargetCreate.lID, kTargetCreate.szTargetName);
// CPythonChat::Instance().AppendChat(CHAT_TYPE_NOTICE, szBuf);
// Tracef(" >> RecvTargetCreatePacket %d : %s\n", kTargetCreate.lID, kTargetCreate.szTargetName);
//#endif
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_OpenAtlasWindow", Py_BuildValue("()"));
return true;
}
bool CPythonNetworkStream::RecvTargetCreatePacketNew()
{
TPacketGCTargetCreateNew kTargetCreate;
if (!Recv(sizeof(kTargetCreate), &kTargetCreate))
return false;
CPythonMiniMap & rkpyMiniMap = CPythonMiniMap::Instance();
CPythonBackground & rkpyBG = CPythonBackground::Instance();
if (CREATE_TARGET_TYPE_LOCATION == kTargetCreate.byType)
{
rkpyMiniMap.CreateTarget(kTargetCreate.lID, kTargetCreate.szTargetName);
}
else
{
rkpyMiniMap.CreateTarget(kTargetCreate.lID, kTargetCreate.szTargetName, kTargetCreate.dwVID);
rkpyBG.CreateTargetEffect(kTargetCreate.lID, kTargetCreate.dwVID);
}
//#ifdef _DEBUG
// char szBuf[256+1];
// _snprintf(szBuf, sizeof(szBuf), "ij<><C4B3><EFBFBD><EFBFBD> Ÿ<><C5B8><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20>Ǿ<EFBFBD><C7BE><EFBFBD><EFBFBD>ϴ<EFBFBD> [%d:%s:%d]", kTargetCreate.lID, kTargetCreate.szTargetName, kTargetCreate.dwVID);
// CPythonChat::Instance().AppendChat(CHAT_TYPE_NOTICE, szBuf);
// Tracef(" >> RecvTargetCreatePacketNew %d : %d/%d\n", kTargetCreate.lID, kTargetCreate.byType, kTargetCreate.dwVID);
//#endif
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_OpenAtlasWindow", Py_BuildValue("()"));
return true;
}
bool CPythonNetworkStream::RecvTargetUpdatePacket()
{
TPacketGCTargetUpdate kTargetUpdate;
if (!Recv(sizeof(kTargetUpdate), &kTargetUpdate))
return false;
CPythonMiniMap & rkpyMiniMap = CPythonMiniMap::Instance();
rkpyMiniMap.UpdateTarget(kTargetUpdate.lID, kTargetUpdate.lX, kTargetUpdate.lY);
CPythonBackground & rkpyBG = CPythonBackground::Instance();
rkpyBG.CreateTargetEffect(kTargetUpdate.lID, kTargetUpdate.lX, kTargetUpdate.lY);
//#ifdef _DEBUG
// char szBuf[256+1];
// _snprintf(szBuf, sizeof(szBuf), "Ÿ<><C5B8><EFBFBD><EFBFBD> <20><>ġ<EFBFBD><C4A1> <20><><EFBFBD><EFBFBD> <20>Ǿ<EFBFBD><C7BE><EFBFBD><EFBFBD>ϴ<EFBFBD> [%d:%d/%d]", kTargetUpdate.lID, kTargetUpdate.lX, kTargetUpdate.lY);
// CPythonChat::Instance().AppendChat(CHAT_TYPE_NOTICE, szBuf);
// Tracef(" >> RecvTargetUpdatePacket %d : %d, %d\n", kTargetUpdate.lID, kTargetUpdate.lX, kTargetUpdate.lY);
//#endif
return true;
}
bool CPythonNetworkStream::RecvTargetDeletePacket()
{
TPacketGCTargetDelete kTargetDelete;
if (!Recv(sizeof(kTargetDelete), &kTargetDelete))
return false;
CPythonMiniMap & rkpyMiniMap = CPythonMiniMap::Instance();
rkpyMiniMap.DeleteTarget(kTargetDelete.lID);
CPythonBackground & rkpyBG = CPythonBackground::Instance();
rkpyBG.DeleteTargetEffect(kTargetDelete.lID);
//#ifdef _DEBUG
// Tracef(" >> RecvTargetDeletePacket %d\n", kTargetDelete.lID);
//#endif
return true;
}
bool CPythonNetworkStream::RecvLoverInfoPacket()
{
TPacketGCLoverInfo kLoverInfo;
if (!Recv(sizeof(kLoverInfo), &kLoverInfo))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_LoverInfo", Py_BuildValue("(si)", kLoverInfo.szName, kLoverInfo.byLovePoint));
#ifdef _DEBUG
Tracef("RECV LOVER INFO : %s, %d\n", kLoverInfo.szName, kLoverInfo.byLovePoint);
#endif
return true;
}
bool CPythonNetworkStream::RecvLovePointUpdatePacket()
{
TPacketGCLovePointUpdate kLovePointUpdate;
if (!Recv(sizeof(kLovePointUpdate), &kLovePointUpdate))
return false;
PyCallClassMemberFunc(m_apoPhaseWnd[PHASE_WINDOW_GAME], "BINARY_UpdateLovePoint", Py_BuildValue("(i)", kLovePointUpdate.byLovePoint));
#ifdef _DEBUG
Tracef("RECV LOVE POINT UPDATE : %d\n", kLovePointUpdate.byLovePoint);
#endif
return true;
}
bool CPythonNetworkStream::RecvDigMotionPacket()
{
TPacketGCDigMotion kDigMotion;
if (!Recv(sizeof(kDigMotion), &kDigMotion))
return false;
#ifdef _DEBUG
Tracef(" Dig Motion [%d/%d]\n", kDigMotion.vid, kDigMotion.count);
#endif
IAbstractCharacterManager& rkChrMgr=IAbstractCharacterManager::GetSingleton();
CInstanceBase * pkInstMain = rkChrMgr.GetInstancePtr(kDigMotion.vid);
CInstanceBase * pkInstTarget = rkChrMgr.GetInstancePtr(kDigMotion.target_vid);
if (NULL == pkInstMain)
return true;
if (pkInstTarget)
pkInstMain->NEW_LookAtDestInstance(*pkInstTarget);
for (int i = 0; i < kDigMotion.count; ++i)
pkInstMain->PushOnceMotion(CRaceMotionData::NAME_DIG);
return true;
}
// <20><>ȥ<EFBFBD><C8A5> <20><>ȭ
bool CPythonNetworkStream::SendDragonSoulRefinePacket(BYTE bRefineType, TItemPos* pos)
{
TPacketCGDragonSoulRefine pk;
pk.header = HEADER_CG_DRAGON_SOUL_REFINE;
pk.bSubType = bRefineType;
memcpy (pk.ItemGrid, pos, sizeof (TItemPos) * DS_REFINE_WINDOW_MAX_NUM);
if (!Send(sizeof (pk), &pk))
{
return false;
}
return true;
}