135 lines
5.6 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
#ifndef plLoadCloneMsgMsg_INC
#define plLoadCloneMsgMsg_INC
#include "pnMessage/plMessage.h"
//
#include "pnKeyedObject/plUoid.h"
/** \class plLoadCloneMsg
Tell the net client manager to allocate a new object based on copying an
existing, statically keyed object.
On the initiating machine, this will synthesize a new key and load the object.
On the remote machines, it will use the (enclosed) new key and load the object.
On both machines, the requestor will be notified after the object is loaded.
*/
class plLoadCloneMsg : public plMessage
{
public:
/** Default constructor. only useful for sending over the network, prior
to reading and writing. The clone message needs to synthesize its key
to do anything, and this constructor doesn't do that, because it doesn't
have enough information. */
plLoadCloneMsg();
/** Canonical constructor. If you're trying to initiate a clone, this is
the one you want to use.
These messages are *always* sent to the net client manager. You can't
address them.
After they are received on the remote machines, they are forwarded
the remote versions of the requestor.
\param uoidToClone - Specifies the template that will be cloned.
\param requestorKey - The key of the object that is requesting the clone. It's
strongly recommended that this be a local object, so that we don't get the same
requestor creating multiple clones by starting the process on several machines.
\param userData - Whatever you want. Will be propagated to the requestor after cloning.
*/
plLoadCloneMsg(const plUoid &uoidToClone, const plKey &requestorKey, uint32_t userData);
/** This constructor form is for when you want to send a clone message based on
an existing cloned object. The two primary uses of this are:
- unload an existing clone
- replicate a locally existing clone to other machines. You'll need
to set up the network propagation parameters yourself.
\param existing - The key to the clone you want to work on
\param requestor - Will be notified when the (un)clone is processed)
\param userData - Whatever you want. Will be propagated to the requestor.
\param isLoading - Are we loading or unloading?
*/
plLoadCloneMsg(const plKey &existing, const plKey &requestor, uint32_t userData, bool isLoading);
virtual ~plLoadCloneMsg();
CLASSNAME_REGISTER(plLoadCloneMsg);
GETINTERFACE_ANY(plLoadCloneMsg, plMessage);
// IO
void Read(hsStream* stream, hsResMgr* mgr);
void Write(hsStream* stream, hsResMgr* mgr);
void ReadVersion(hsStream* stream, hsResMgr* mgr);
void WriteVersion(hsStream* stream, hsResMgr* mgr);
plKey GetCloneKey();
plKey GetRequestorKey();
bool IsValidMessage();
uint32_t GetUserData();
uint32_t GetOriginatingPlayerID();
void SetOriginatingPlayerID(uint32_t playerId);
bool GetIsLoading();
void SetTriggerMsg(plMessage *msg);
plMessage *GetTriggerMsg();
protected:
plKey fCloneKey; // the key that will be loaded
plKey fRequestorKey; // forward the message to this guy after the clone is created
bool fValidMsg; // only gets set if the message built successfully
uint32_t fUserData; // let requestors send some data to their remote versions
uint32_t fOriginatingPlayerID; // network / player id of the client initiating the request
bool fIsLoading; // true if we're loading; false if we're unloading
plMessage *fTriggerMsg; // Handy place to store a message that caused you to request a clone,
// so you can see it and continue processing once your clone is loaded.
};
#endif
#endif // ndef SERVER
#endif // ndef NO_AV_MSGS