You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
276 lines
7.8 KiB
276 lines
7.8 KiB
/*==LICENSE==* |
|
|
|
CyanWorlds.com Engine - MMOG client, server and tools |
|
Copyright (C) 2011 Cyan Worlds, Inc. |
|
|
|
This program is free software: you can redistribute it and/or modify |
|
it under the terms of the GNU General Public License as published by |
|
the Free Software Foundation, either version 3 of the License, or |
|
(at your option) any later version. |
|
|
|
This program is distributed in the hope that it will be useful, |
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
GNU General Public License for more details. |
|
|
|
You should have received a copy of the GNU General Public License |
|
along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
|
|
Additional permissions under GNU GPL version 3 section 7 |
|
|
|
If you modify this Program, or any covered work, by linking or |
|
combining it with any of RAD Game Tools Bink SDK, Autodesk 3ds Max SDK, |
|
NVIDIA PhysX SDK, Microsoft DirectX SDK, OpenSSL library, Independent |
|
JPEG Group JPEG library, Microsoft Windows Media SDK, or Apple QuickTime SDK |
|
(or a modified version of those libraries), |
|
containing parts covered by the terms of the Bink SDK EULA, 3ds Max EULA, |
|
PhysX SDK EULA, DirectX SDK EULA, OpenSSL and SSLeay licenses, IJG |
|
JPEG Library README, Windows Media SDK EULA, or QuickTime SDK EULA, the |
|
licensors of this Program grant you additional |
|
permission to convey the resulting work. Corresponding Source for a |
|
non-source form of such a combination shall include the source code for |
|
the parts of OpenSSL and IJG JPEG Library used as well as that of the covered |
|
work. |
|
|
|
You can contact Cyan Worlds, Inc. by email legal@cyan.com |
|
or by snail mail at: |
|
Cyan Worlds, Inc. |
|
14617 N Newport Hwy |
|
Mead, WA 99021 |
|
|
|
*==LICENSE==*/ |
|
#ifndef NO_AV_MSGS |
|
#ifndef SERVER |
|
|
|
// singular |
|
#include "plLoadAvatarMsg.h" |
|
|
|
// global |
|
#include "hsResMgr.h" |
|
|
|
// other |
|
#include "pnNetCommon/plNetApp.h" |
|
#include "HeadSpin.h" |
|
|
|
|
|
|
|
// CTOR / default |
|
plLoadCloneMsg::plLoadCloneMsg() |
|
: fValidMsg(false), |
|
fOriginatingPlayerID(0), |
|
fTriggerMsg(nil) |
|
{ |
|
SetBCastFlag(plMessage::kNetPropagate); |
|
}; |
|
|
|
// CTOR uoidToClone, requestorKey, userData, isLoading |
|
// this form is for creating new clones |
|
plLoadCloneMsg::plLoadCloneMsg(const plUoid &uoidToClone, const plKey &requestorKey, uint32_t userData) |
|
: fRequestorKey(requestorKey), |
|
fUserData(userData), |
|
fValidMsg(false), |
|
fTriggerMsg(nil), |
|
fIsLoading(true) // this constructor form is only used for loading |
|
{ |
|
SetBCastFlag(plMessage::kNetPropagate); |
|
|
|
hsKeyedObject * koRequestor = fRequestorKey->ObjectIsLoaded(); |
|
if(koRequestor) |
|
{ |
|
plNetClientApp *app = plNetClientApp::GetInstance(); |
|
plKey originalKey = hsgResMgr::ResMgr()->FindKey(uoidToClone); |
|
|
|
if(originalKey) |
|
{ |
|
// all is well. finish it off. |
|
fCloneKey = hsgResMgr::ResMgr()->CloneKey(originalKey); |
|
fOriginatingPlayerID = app->GetPlayerID(); |
|
fValidMsg = true; |
|
this->AddReceiver(plNetApp::GetInstance()->GetKey()); |
|
} else { |
|
char buffer[128]; |
|
sprintf(buffer, "Can't find key named %s", uoidToClone.GetObjectName()); |
|
hsAssert(0, buffer); |
|
} |
|
} else { |
|
hsStatusMessage("Clone requestor is not loaded."); |
|
} |
|
} |
|
|
|
// CTOR existing, requestor, userData, isLoading |
|
// this form is for unloading or other operations on existing clones |
|
plLoadCloneMsg::plLoadCloneMsg(const plKey &existing, const plKey &requestor, uint32_t userData, hsBool isLoading) |
|
: fCloneKey(existing), |
|
fRequestorKey(requestor), |
|
fUserData(userData), |
|
fValidMsg(true), |
|
fTriggerMsg(nil), |
|
fIsLoading(isLoading) |
|
{ |
|
if (plNetApp::GetInstance()) |
|
{ |
|
SetBCastFlag(plMessage::kNetPropagate); |
|
AddReceiver(plNetApp::GetInstance()->GetKey()); |
|
} |
|
if (plNetClientApp::GetInstance()) |
|
fOriginatingPlayerID = plNetClientApp::GetInstance()->GetPlayerID(); |
|
hsAssert(fRequestorKey->ObjectIsLoaded(), "Clone (unloading) requestor is not loaded."); |
|
} |
|
|
|
plLoadCloneMsg::~plLoadCloneMsg() |
|
{ |
|
hsRefCnt_SafeUnRef(fTriggerMsg); |
|
} |
|
|
|
// READ |
|
void plLoadCloneMsg::Read(hsStream* stream, hsResMgr* mgr) |
|
{ |
|
plMessage::IMsgRead(stream, mgr); |
|
fCloneKey = mgr->ReadKey(stream); |
|
fRequestorKey = mgr->ReadKey(stream); |
|
fOriginatingPlayerID = stream->ReadLE32(); |
|
fUserData = stream->ReadLE32(); |
|
fValidMsg = stream->ReadBool(); |
|
fIsLoading = stream->ReadBool(); |
|
fTriggerMsg = plMessage::ConvertNoRef(mgr->ReadCreatable(stream)); |
|
} |
|
|
|
// WRITE |
|
void plLoadCloneMsg::Write(hsStream* stream, hsResMgr* mgr) |
|
{ |
|
plMessage::IMsgWrite(stream,mgr); |
|
mgr->WriteKey(stream, fCloneKey); |
|
mgr->WriteKey(stream, fRequestorKey); |
|
stream->WriteLE32(fOriginatingPlayerID); |
|
stream->WriteLE32(fUserData); |
|
stream->WriteBool(fValidMsg); |
|
stream->WriteBool(fIsLoading); |
|
mgr->WriteCreatable(stream, fTriggerMsg); |
|
} |
|
|
|
enum LoadCloneMsgFlags |
|
{ |
|
kLoadCloneMsgCloneKey, |
|
kLoadCloneMsgRequestorKey, |
|
kLoadCloneMsgOrigPlayerID, |
|
kLoadCloneMsgUserData, |
|
kLoadCloneMsgValidMsg, |
|
kLoadCloneMsgIsLoading, |
|
kLoadCloneMsgTriggerMsg, |
|
}; |
|
|
|
void plLoadCloneMsg::ReadVersion(hsStream* stream, hsResMgr* mgr) |
|
{ |
|
plMessage::IMsgReadVersion(stream, mgr); |
|
|
|
hsBitVector contentFlags; |
|
contentFlags.Read(stream); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgCloneKey)) |
|
fCloneKey = mgr->ReadKey(stream); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgRequestorKey)) |
|
fRequestorKey = mgr->ReadKey(stream); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgOrigPlayerID)) |
|
fOriginatingPlayerID = stream->ReadLE32(); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgUserData)) |
|
fUserData = stream->ReadLE32(); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgValidMsg)) |
|
fValidMsg = stream->ReadBool(); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgIsLoading)) |
|
fIsLoading = stream->ReadBool(); |
|
|
|
if (contentFlags.IsBitSet(kLoadCloneMsgTriggerMsg)) |
|
fTriggerMsg = plMessage::ConvertNoRef(mgr->ReadCreatable(stream)); |
|
} |
|
|
|
void plLoadCloneMsg::WriteVersion(hsStream* stream, hsResMgr* mgr) |
|
{ |
|
plMessage::IMsgWriteVersion(stream,mgr); |
|
|
|
hsBitVector contentFlags; |
|
contentFlags.SetBit(kLoadCloneMsgCloneKey); |
|
contentFlags.SetBit(kLoadCloneMsgRequestorKey); |
|
contentFlags.SetBit(kLoadCloneMsgOrigPlayerID); |
|
contentFlags.SetBit(kLoadCloneMsgUserData); |
|
contentFlags.SetBit(kLoadCloneMsgValidMsg); |
|
contentFlags.SetBit(kLoadCloneMsgIsLoading); |
|
contentFlags.SetBit(kLoadCloneMsgTriggerMsg); |
|
contentFlags.Write(stream); |
|
|
|
// kLoadCloneMsgCloneKey |
|
mgr->WriteKey(stream, fCloneKey); |
|
// kLoadCloneMsgRequestorKey |
|
mgr->WriteKey(stream, fRequestorKey); |
|
// kLoadCloneMsgOrigPlayerID |
|
stream->WriteLE32(fOriginatingPlayerID); |
|
// kLoadCloneMsgUserData |
|
stream->WriteLE32(fUserData); |
|
// kLoadCloneMsgValidMsg |
|
stream->WriteBool(fValidMsg); |
|
// kLoadCloneMsgIsLoading |
|
stream->WriteBool(fIsLoading); |
|
// kLoadCloneMsgTriggerMSg |
|
mgr->WriteCreatable(stream, fTriggerMsg); |
|
} |
|
|
|
// GETCLONEKEY |
|
plKey plLoadCloneMsg::GetCloneKey() |
|
{ |
|
return fCloneKey; |
|
} |
|
|
|
// GETREQUESTORKEY |
|
plKey plLoadCloneMsg::GetRequestorKey() |
|
{ |
|
return fRequestorKey; |
|
} |
|
|
|
// ISVALIDMESSAGE |
|
hsBool plLoadCloneMsg::IsValidMessage() |
|
{ |
|
return fValidMsg; |
|
} |
|
|
|
// GETUSERDATA |
|
uint32_t plLoadCloneMsg::GetUserData() |
|
{ |
|
return fUserData; |
|
} |
|
|
|
// GETORIGINATINGPLAYERID |
|
uint32_t plLoadCloneMsg::GetOriginatingPlayerID() |
|
{ |
|
return fOriginatingPlayerID; |
|
} |
|
|
|
void plLoadCloneMsg::SetOriginatingPlayerID(uint32_t playerId) |
|
{ |
|
fOriginatingPlayerID = playerId; |
|
} |
|
|
|
hsBool plLoadCloneMsg::GetIsLoading() |
|
{ |
|
return fIsLoading; |
|
} |
|
|
|
void plLoadCloneMsg::SetTriggerMsg(plMessage *msg) |
|
{ |
|
if (fTriggerMsg != nil) |
|
hsRefCnt_SafeUnRef(fTriggerMsg); |
|
|
|
hsRefCnt_SafeRef(msg); |
|
fTriggerMsg = msg; |
|
} |
|
|
|
plMessage *plLoadCloneMsg::GetTriggerMsg() |
|
{ |
|
return fTriggerMsg; |
|
} |
|
|
|
#endif // ndef SERVER |
|
#endif // ndef NO_AV_MSGS
|
|
|