amxmodx/amxmodx/CEvent.h

162 lines
4.0 KiB
C
Raw Normal View History

2004-03-05 21:03:14 +00:00
/* AMX Mod X
2004-02-21 19:36:35 +00:00
*
2004-03-05 21:03:14 +00:00
* by the AMX Mod X Development Team
* originally developed by OLO
2004-02-21 19:36:35 +00:00
*
*
2004-03-05 21:03:14 +00:00
* 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 2 of the License, or (at
* your option) any later version.
2004-02-21 19:36:35 +00:00
*
2004-03-05 21:03:14 +00:00
* 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.
2004-02-21 19:36:35 +00:00
*
2004-03-05 21:03:14 +00:00
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
2004-02-21 19:36:35 +00:00
*
2004-03-05 21:03:14 +00:00
* In addition, as a special exception, the author gives permission to
* link the code of this program with the Half-Life Game Engine ("HL
* Engine") and Modified Game Libraries ("MODs") developed by Valve,
* L.L.C ("Valve"). You must obey the GNU General Public License in all
* respects for all of the code used other than the HL Engine and MODs
* from Valve. If you modify this file, you may extend this exception
* to your version of the file, but you are not obligated to do so. If
* you do not wish to do so, delete this exception statement from your
* version.
2004-02-21 19:36:35 +00:00
*/
2004-01-31 20:56:22 +00:00
#ifndef __CEVENTS_H__
#define __CEVENTS_H__
2004-01-31 20:56:22 +00:00
2005-09-16 23:48:51 +00:00
#define MAX_AMX_REG_MSG MAX_REG_MSGS + 16
2005-09-10 00:38:42 +00:00
enum
{
2004-01-31 20:56:22 +00:00
CS_DEATHMSG = MAX_REG_MSGS,
// CS_ROUNDEND,
// CS_ROUNDSTART,
// CS_RESTART,
};
// *****************************************************
// class EventsMngr
// *****************************************************
class EventsMngr
{
enum MsgParamType
{
2004-01-31 20:56:22 +00:00
MSG_INTEGER,
MSG_FLOAT,
MSG_STRING,
};
enum CS_EventsIds
{
2004-01-31 20:56:22 +00:00
CS_Null = 0,
CS_DeathMsg = MAX_REG_MSGS, // start from last element
// CS_RoundEnd,
// CS_RoundStart,
// CS_Restart,
};
public:
class ClEvent
{
2005-09-10 00:38:42 +00:00
friend class EventsMngr; // events manager may access our private members
int m_Func; // function to be executed
CPluginMngr::CPlugin *m_Plugin; // the plugin this ClEvent class is assigned to
// flags
bool m_FlagPlayer;
bool m_FlagWorld;
bool m_FlagOnce;
bool m_FlagDead;
bool m_FlagAlive;
float m_Stamp; // for 'once' flag
bool m_Done;
// conditions
struct cond_t
{
2004-03-14 13:57:27 +00:00
int paramId; // the message parameter id
String sValue; // value (string)
2004-03-14 13:57:27 +00:00
float fValue; // value (float)
int iValue; // value (int)
int type; // type (can be int, float, string)
cond_t *next;
};
2004-03-14 13:57:27 +00:00
cond_t *m_Conditions;
2004-03-14 13:57:27 +00:00
public:
// constructors & destructors
2005-09-10 00:38:42 +00:00
ClEvent(CPluginMngr::CPlugin* plugin, int func, int flags);
2004-01-31 20:56:22 +00:00
~ClEvent();
2004-03-14 13:57:27 +00:00
inline CPluginMngr::CPlugin* getPlugin();
inline int getFunction();
void registerFilter(char* filter); // add a condition
2004-01-31 20:56:22 +00:00
};
private:
2004-03-14 13:57:27 +00:00
struct MsgDataEntry
{
2004-01-31 20:56:22 +00:00
float fValue;
int iValue;
const char* sValue;
MsgParamType type;
};
2005-09-10 00:38:42 +00:00
2004-03-14 13:57:27 +00:00
MsgDataEntry *m_ParseVault;
int m_ParseVaultSize;
2005-09-10 00:38:42 +00:00
void NextParam(); // make sure a new parameter can be added
2004-03-14 13:57:27 +00:00
typedef CList<ClEvent> ClEventVec;
typedef ClEventVec::iterator ClEventVecIter;
2004-03-14 13:57:27 +00:00
ClEventVec m_Events[MAX_AMX_REG_MSG];
2005-09-10 00:38:42 +00:00
ClEventVec *m_ParseFun; // current Event vector
bool m_ParseNotDone;
2004-03-14 13:57:27 +00:00
int m_ParsePos; // is args. num. - 1
float* m_Timer;
2005-09-10 00:38:42 +00:00
ClEvent* getValidEvent(ClEvent* a);
2004-01-31 20:56:22 +00:00
2004-04-03 19:15:43 +00:00
int m_CurrentMsgType;
2004-01-31 20:56:22 +00:00
public:
EventsMngr();
~EventsMngr();
// Interface
ClEvent* registerEvent(CPluginMngr::CPlugin* plugin, int func, int flags, int msgid);
2005-09-16 23:48:51 +00:00
void parserInit(int msg_type, float* timer, CPlayer* pPlayer, int index);
2004-01-31 20:56:22 +00:00
void parseValue(int iValue);
void parseValue(float fValue);
void parseValue(const char *sz);
void executeEvents();
2005-09-16 23:48:51 +00:00
int getArgNum() const; //{ return (parsePos + 1); }
2004-03-31 18:05:07 +00:00
const char* getArgString(int a) const;
int getArgInteger(int a) const;
float getArgFloat(int a) const;
2004-01-31 20:56:22 +00:00
void clearEvents(void);
2005-09-10 00:38:42 +00:00
static int getEventId(const char* msg);
2004-04-03 19:15:43 +00:00
int getCurrentMsgType();
2004-01-31 20:56:22 +00:00
};
2005-09-10 00:38:42 +00:00
#endif //__CEVENTS_H__