/*==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 . 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==*/ #include "pyHeekMsg.h" #include "../../pyEnum.h" #include /////////////////////////////////////////////////////////////////////////////// // // Base Heek msg class // PYTHON_CLASS_DEFINITION(ptHeekMsg, pyHeekMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekMsg, pyHeekMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekMsg) PYTHON_NO_INIT_DEFINITION(ptHeekMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekMsg, getHeekMsgType) { return PyInt_FromLong(self->fThis->GetHeekMsgType()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekMsg, upcastToFinalHeekMsg) { return self->fThis->UpcastToFinalHeekMsg(); } PYTHON_START_METHODS_TABLE(ptHeekMsg) PYTHON_METHOD_NOARGS(ptHeekMsg, getHeekMsgType, "Returns the type of the Heek message (see PtHeekMsgTypes)"), PYTHON_METHOD_NOARGS(ptHeekMsg, upcastToFinalHeekMsg, "Returns this message as the Heek message it is"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekMsg, pyGameCliMsg, "Base class for Heek game messages"); PYTHON_EXPOSE_TYPE_DEFINITION(ptHeekMsg, pyHeekMsg); // required functions for PyObject interoperability PyObject* pyHeekMsg::New(pfGameCliMsg* msg) { ptHeekMsg *newObj = (ptHeekMsg*)ptHeekMsg_type.tp_new(&ptHeekMsg_type, NULL, NULL); if (msg && (msg->gameCli->GetGameTypeId() == kGameTypeId_Heek)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekMsg, pyHeekMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekMsg, pyHeekMsg) // Module and method definitions void pyHeekMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekMsg); PYTHON_CLASS_IMPORT_END(m); } void pyHeekMsg::AddPlasmaConstantsClasses(PyObject* m) { PYTHON_ENUM_START(PtHeekMsgTypes); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekPlayGame, kSrv2Cli_Heek_PlayGame); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekGoodbye, kSrv2Cli_Heek_Goodbye); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekWelcome, kSrv2Cli_Heek_Welcome); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekDrop, kSrv2Cli_Heek_Drop); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekSetup, kSrv2Cli_Heek_Setup); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekLightState, kSrv2Cli_Heek_LightState); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekInterfaceState, kSrv2Cli_Heek_InterfaceState); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekCountdownState, kSrv2Cli_Heek_CountdownState); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekWinLose, kSrv2Cli_Heek_WinLose); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekGameWin, kSrv2Cli_Heek_GameWin); PYTHON_ENUM_ELEMENT(PtHeekMsgTypes, kHeekPointUpdate, kSrv2Cli_Heek_PointUpdate); PYTHON_ENUM_END(m, PtHeekMsgTypes); } /////////////////////////////////////////////////////////////////////////////// // // Game client message subclasses // PYTHON_CLASS_DEFINITION(ptHeekPlayGameMsg, pyHeekPlayGameMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekPlayGameMsg, pyHeekPlayGameMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekPlayGameMsg) PYTHON_NO_INIT_DEFINITION(ptHeekPlayGameMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekPlayGameMsg, isPlaying) { PYTHON_RETURN_BOOL(self->fThis->IsPlaying()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekPlayGameMsg, isSinglePlayer) { PYTHON_RETURN_BOOL(self->fThis->IsSinglePlayer()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekPlayGameMsg, enableButtons) { PYTHON_RETURN_BOOL(self->fThis->EnableButtons()) } PYTHON_START_METHODS_TABLE(ptHeekPlayGameMsg) PYTHON_METHOD_NOARGS(ptHeekPlayGameMsg, isPlaying, "Returns true if the server accepted the play game request"), PYTHON_METHOD_NOARGS(ptHeekPlayGameMsg, isSinglePlayer, "Returns true if you are the only player at the table"), PYTHON_METHOD_NOARGS(ptHeekPlayGameMsg, enableButtons, "Returns true if we should enable the buttons at the place we sat down"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekPlayGameMsg, pyHeekMsg, "Heek message received when the server processes your play game request"); // required functions for PyObject interoperability PyObject* pyHeekPlayGameMsg::New(pfGameCliMsg* msg) { ptHeekPlayGameMsg *newObj = (ptHeekPlayGameMsg*)ptHeekPlayGameMsg_type.tp_new(&ptHeekPlayGameMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_PlayGame)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekPlayGameMsg, pyHeekPlayGameMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekPlayGameMsg, pyHeekPlayGameMsg) // Module and method definitions void pyHeekPlayGameMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekPlayGameMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekGoodbyeMsg, pyHeekGoodbyeMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekGoodbyeMsg, pyHeekGoodbyeMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekGoodbyeMsg) PYTHON_NO_INIT_DEFINITION(ptHeekGoodbyeMsg) PYTHON_START_METHODS_TABLE(ptHeekGoodbyeMsg) PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekGoodbyeMsg, pyHeekMsg, "Heek message received when the server processes leave request"); // required functions for PyObject interoperability PyObject* pyHeekGoodbyeMsg::New(pfGameCliMsg* msg) { ptHeekGoodbyeMsg *newObj = (ptHeekGoodbyeMsg*)ptHeekGoodbyeMsg_type.tp_new(&ptHeekGoodbyeMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_Goodbye)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekGoodbyeMsg, pyHeekGoodbyeMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekGoodbyeMsg, pyHeekGoodbyeMsg) // Module and method definitions void pyHeekGoodbyeMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekGoodbyeMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekWelcomeMsg, pyHeekWelcomeMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekWelcomeMsg, pyHeekWelcomeMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekWelcomeMsg) PYTHON_NO_INIT_DEFINITION(ptHeekWelcomeMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekWelcomeMsg, points) { return PyLong_FromUnsignedLong(self->fThis->Points()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekWelcomeMsg, rank) { return PyLong_FromUnsignedLong(self->fThis->Rank()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekWelcomeMsg, name) { std::wstring retVal = self->fThis->Name(); return PyUnicode_FromWideChar(retVal.c_str(), retVal.length()); } PYTHON_START_METHODS_TABLE(ptHeekWelcomeMsg) PYTHON_METHOD_NOARGS(ptHeekWelcomeMsg, points, "Returns the new player's points"), PYTHON_METHOD_NOARGS(ptHeekWelcomeMsg, rank, "Returns the new player's rank"), PYTHON_METHOD_NOARGS(ptHeekWelcomeMsg, name, "Returns the new player's name"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekWelcomeMsg, pyHeekMsg, "Heek message received when a new player sits down"); // required functions for PyObject interoperability PyObject* pyHeekWelcomeMsg::New(pfGameCliMsg* msg) { ptHeekWelcomeMsg *newObj = (ptHeekWelcomeMsg*)ptHeekWelcomeMsg_type.tp_new(&ptHeekWelcomeMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_Welcome)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekWelcomeMsg, pyHeekWelcomeMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekWelcomeMsg, pyHeekWelcomeMsg) // Module and method definitions void pyHeekWelcomeMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekWelcomeMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekDropMsg, pyHeekDropMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekDropMsg, pyHeekDropMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekDropMsg) PYTHON_NO_INIT_DEFINITION(ptHeekDropMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekDropMsg, position) { return PyLong_FromUnsignedLong(self->fThis->Position()); } PYTHON_START_METHODS_TABLE(ptHeekDropMsg) PYTHON_METHOD_NOARGS(ptHeekDropMsg, position, "Returns player position to cleanup and dump"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekDropMsg, pyHeekMsg, "Heek message received when another player's position needs to be reset/modified"); // required functions for PyObject interoperability PyObject* pyHeekDropMsg::New(pfGameCliMsg* msg) { ptHeekDropMsg *newObj = (ptHeekDropMsg*)ptHeekDropMsg_type.tp_new(&ptHeekDropMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_Drop)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekDropMsg, pyHeekDropMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekDropMsg, pyHeekDropMsg) // Module and method definitions void pyHeekDropMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekDropMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekSetupMsg, pyHeekSetupMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekSetupMsg, pyHeekSetupMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekSetupMsg) PYTHON_NO_INIT_DEFINITION(ptHeekSetupMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekSetupMsg, position) { return PyInt_FromLong(self->fThis->Position()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekSetupMsg, buttonState) { PYTHON_RETURN_BOOL(self->fThis->ButtonState()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekSetupMsg, lightOn) { std::vector lights = self->fThis->LightOn(); PyObject* retVal = PyList_New(lights.size()); for (unsigned i = 0; i < lights.size(); ++i) PyList_SetItem(retVal, i, PyInt_FromLong(lights[i] ? 1 : 0)); return retVal; } PYTHON_START_METHODS_TABLE(ptHeekSetupMsg) PYTHON_METHOD_NOARGS(ptHeekSetupMsg, position, "Returns the position this message is for"), PYTHON_METHOD_NOARGS(ptHeekSetupMsg, buttonState, "Returns whether the buttons are enabled or not"), PYTHON_METHOD_NOARGS(ptHeekSetupMsg, lightOn, "Returns a list of bools representing lights on or off"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekSetupMsg, pyHeekMsg, "Heek message for setting up each position's state"); // required functions for PyObject interoperability PyObject* pyHeekSetupMsg::New(pfGameCliMsg* msg) { ptHeekSetupMsg *newObj = (ptHeekSetupMsg*)ptHeekSetupMsg_type.tp_new(&ptHeekSetupMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_Setup)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekSetupMsg, pyHeekSetupMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekSetupMsg, pyHeekSetupMsg) // Module and method definitions void pyHeekSetupMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekSetupMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekLightStateMsg, pyHeekLightStateMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekLightStateMsg, pyHeekLightStateMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekLightStateMsg) PYTHON_NO_INIT_DEFINITION(ptHeekLightStateMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekLightStateMsg, lightNum) { return PyInt_FromLong(self->fThis->LightNum()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekLightStateMsg, state) { return PyInt_FromLong(self->fThis->State()); } PYTHON_START_METHODS_TABLE(ptHeekLightStateMsg) PYTHON_METHOD_NOARGS(ptHeekLightStateMsg, lightNum, "Returns the index of the light this refers to"), PYTHON_METHOD_NOARGS(ptHeekLightStateMsg, state, "Returns state the light should be switched to (see PtHeekLightStates)"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekLightStateMsg, pyHeekMsg, "Heek message received when one of your local lights needs to change state"); // required functions for PyObject interoperability PyObject* pyHeekLightStateMsg::New(pfGameCliMsg* msg) { ptHeekLightStateMsg *newObj = (ptHeekLightStateMsg*)ptHeekLightStateMsg_type.tp_new(&ptHeekLightStateMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_LightState)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekLightStateMsg, pyHeekLightStateMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekLightStateMsg, pyHeekLightStateMsg) // Module and method definitions void pyHeekLightStateMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekLightStateMsg); PYTHON_CLASS_IMPORT_END(m); } void pyHeekLightStateMsg::AddPlasmaConstantsClasses(PyObject* m) { PYTHON_ENUM_START(PtHeekLightStates); PYTHON_ENUM_ELEMENT(PtHeekLightStates, kHeekLightOn, kHeekLightOn); PYTHON_ENUM_ELEMENT(PtHeekLightStates, kHeekLightOff, kHeekLightOff); PYTHON_ENUM_ELEMENT(PtHeekLightStates, kHeekLightFlash, kHeekLightFlash); PYTHON_ENUM_END(m, PtHeekLightStates); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekInterfaceStateMsg, pyHeekInterfaceStateMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekInterfaceStateMsg, pyHeekInterfaceStateMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekInterfaceStateMsg) PYTHON_NO_INIT_DEFINITION(ptHeekInterfaceStateMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekInterfaceStateMsg, buttonsEnabled) { PYTHON_RETURN_BOOL(self->fThis->ButtonsEnabled()); } PYTHON_START_METHODS_TABLE(ptHeekInterfaceStateMsg) PYTHON_METHOD_NOARGS(ptHeekInterfaceStateMsg, buttonsEnabled, "Returns whether your buttons should be enabled"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekInterfaceStateMsg, pyHeekMsg, "Heek message received when your interface buttons need to enable or disable"); // required functions for PyObject interoperability PyObject* pyHeekInterfaceStateMsg::New(pfGameCliMsg* msg) { ptHeekInterfaceStateMsg *newObj = (ptHeekInterfaceStateMsg*)ptHeekInterfaceStateMsg_type.tp_new(&ptHeekInterfaceStateMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_InterfaceState)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekInterfaceStateMsg, pyHeekInterfaceStateMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekInterfaceStateMsg, pyHeekInterfaceStateMsg) // Module and method definitions void pyHeekInterfaceStateMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekInterfaceStateMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekCountdownStateMsg, pyHeekCountdownStateMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekCountdownStateMsg, pyHeekCountdownStateMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekCountdownStateMsg) PYTHON_NO_INIT_DEFINITION(ptHeekCountdownStateMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekCountdownStateMsg, state) { return PyInt_FromLong(self->fThis->State()); } PYTHON_START_METHODS_TABLE(ptHeekCountdownStateMsg) PYTHON_METHOD_NOARGS(ptHeekCountdownStateMsg, state, "Returns state the countdown should be switched to (see PtHeekCountdownStates)"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekCountdownStateMsg, pyHeekMsg, "Heek message received by game admin when the countdown state needs to change"); // required functions for PyObject interoperability PyObject* pyHeekCountdownStateMsg::New(pfGameCliMsg* msg) { ptHeekCountdownStateMsg *newObj = (ptHeekCountdownStateMsg*)ptHeekCountdownStateMsg_type.tp_new(&ptHeekCountdownStateMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_CountdownState)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekCountdownStateMsg, pyHeekCountdownStateMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekCountdownStateMsg, pyHeekCountdownStateMsg) // Module and method definitions void pyHeekCountdownStateMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekCountdownStateMsg); PYTHON_CLASS_IMPORT_END(m); } void pyHeekCountdownStateMsg::AddPlasmaConstantsClasses(PyObject* m) { PYTHON_ENUM_START(PtHeekCountdownStates); PYTHON_ENUM_ELEMENT(PtHeekCountdownStates, kHeekCountdownStart, kHeekCountdownStart); PYTHON_ENUM_ELEMENT(PtHeekCountdownStates, kHeekCountdownStop, kHeekCountdownStop); PYTHON_ENUM_ELEMENT(PtHeekCountdownStates, kHeekCountdownIdle, kHeekCountdownIdle); PYTHON_ENUM_END(m, PtHeekCountdownStates); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekWinLoseMsg, pyHeekWinLoseMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekWinLoseMsg, pyHeekWinLoseMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekWinLoseMsg) PYTHON_NO_INIT_DEFINITION(ptHeekWinLoseMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekWinLoseMsg, win) { PYTHON_RETURN_BOOL(self->fThis->Win()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekWinLoseMsg, choice) { return PyInt_FromLong(self->fThis->Choice()); } PYTHON_START_METHODS_TABLE(ptHeekWinLoseMsg) PYTHON_METHOD_NOARGS(ptHeekWinLoseMsg, win, "Returns true if you won"), PYTHON_METHOD_NOARGS(ptHeekWinLoseMsg, choice, "Returns the choice that won or lost (see PtHeekGameChoice)"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekWinLoseMsg, pyHeekMsg, "Heek message received when the round is over and you won or lost"); // required functions for PyObject interoperability PyObject* pyHeekWinLoseMsg::New(pfGameCliMsg* msg) { ptHeekWinLoseMsg *newObj = (ptHeekWinLoseMsg*)ptHeekWinLoseMsg_type.tp_new(&ptHeekWinLoseMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_WinLose)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekWinLoseMsg, pyHeekWinLoseMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekWinLoseMsg, pyHeekWinLoseMsg) // Module and method definitions void pyHeekWinLoseMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekWinLoseMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekGameWinMsg, pyHeekGameWinMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekGameWinMsg, pyHeekGameWinMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekGameWinMsg) PYTHON_NO_INIT_DEFINITION(ptHeekGameWinMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekGameWinMsg, choice) { return PyInt_FromLong(self->fThis->Choice()); } PYTHON_START_METHODS_TABLE(ptHeekGameWinMsg) PYTHON_METHOD_NOARGS(ptHeekGameWinMsg, choice, "Returns the choice that won (see PtHeekGameChoice)"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekGameWinMsg, pyHeekMsg, "Heek message received by game admin when a game is won"); // required functions for PyObject interoperability PyObject* pyHeekGameWinMsg::New(pfGameCliMsg* msg) { ptHeekGameWinMsg *newObj = (ptHeekGameWinMsg*)ptHeekGameWinMsg_type.tp_new(&ptHeekGameWinMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_GameWin)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekGameWinMsg, pyHeekGameWinMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekGameWinMsg, pyHeekGameWinMsg) // Module and method definitions void pyHeekGameWinMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekGameWinMsg); PYTHON_CLASS_IMPORT_END(m); } /////////////////////////////////////////////////////////////////////////////// PYTHON_CLASS_DEFINITION(ptHeekPointUpdateMsg, pyHeekPointUpdateMsg); PYTHON_DEFAULT_NEW_DEFINITION(ptHeekPointUpdateMsg, pyHeekPointUpdateMsg) PYTHON_DEFAULT_DEALLOC_DEFINITION(ptHeekPointUpdateMsg) PYTHON_NO_INIT_DEFINITION(ptHeekPointUpdateMsg) PYTHON_METHOD_DEFINITION_NOARGS(ptHeekPointUpdateMsg, displayUpdate) { PYTHON_RETURN_BOOL(self->fThis->DisplayUpdate()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekPointUpdateMsg, points) { return PyLong_FromUnsignedLong(self->fThis->Points()); } PYTHON_METHOD_DEFINITION_NOARGS(ptHeekPointUpdateMsg, rank) { return PyLong_FromUnsignedLong(self->fThis->Rank()); } PYTHON_START_METHODS_TABLE(ptHeekPointUpdateMsg) PYTHON_METHOD_NOARGS(ptHeekPointUpdateMsg, displayUpdate, "Returns whether you should display a message to the user"), PYTHON_METHOD_NOARGS(ptHeekPointUpdateMsg, points, "Returns your new amount of points"), PYTHON_METHOD_NOARGS(ptHeekPointUpdateMsg, rank, "Returns your new rank"), PYTHON_END_METHODS_TABLE; // Type structure definition PLASMA_DEFAULT_TYPE_WBASE(ptHeekPointUpdateMsg, pyHeekMsg, "Heek message received when the number of points you have needs to be changed"); // required functions for PyObject interoperability PyObject* pyHeekPointUpdateMsg::New(pfGameCliMsg* msg) { ptHeekPointUpdateMsg *newObj = (ptHeekPointUpdateMsg*)ptHeekPointUpdateMsg_type.tp_new(&ptHeekPointUpdateMsg_type, NULL, NULL); if (msg && (msg->netMsg->messageId == kSrv2Cli_Heek_PointUpdate)) newObj->fThis->message = msg; return (PyObject*)newObj; } PYTHON_CLASS_CHECK_IMPL(ptHeekPointUpdateMsg, pyHeekPointUpdateMsg) PYTHON_CLASS_CONVERT_FROM_IMPL(ptHeekPointUpdateMsg, pyHeekPointUpdateMsg) // Module and method definitions void pyHeekPointUpdateMsg::AddPlasmaClasses(PyObject* m) { PYTHON_CLASS_IMPORT_START(m); PYTHON_CLASS_IMPORT(m, ptHeekPointUpdateMsg); PYTHON_CLASS_IMPORT_END(m); }