1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
/***************************************************************************
* Copyright (C) 2005-2019 by the FIFE team *
* http://www.fifengine.net *
* This file is part of FIFE. *
* *
* FIFE is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Lesser General Public *
* License as published by the Free Software Foundation; either *
* version 2.1 of the License, or (at your option) any later version. *
* *
* This library 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 *
* Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public *
* License along with this library; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
#ifndef FIFE_EVENTCHANNEL_COMMAND_H
#define FIFE_EVENTCHANNEL_COMMAND_H
// Standard C++ library includes
//
// 3rd party library includes
//
// FIFE includes
// These includes are split up in two parts, separated by one empty line
// First block: files included from the FIFE root src directory
// Second block: files included from the same folder
//
#include "eventchannel/base/event.h"
#include "commandids.h"
namespace FIFE {
/** Class for commands
* Commands are arbitrary events e.g. send from one subsystem to another
*/
class Command: public Event {
public:
/** Constructor.
*/
Command():
Event(),
m_commandType(CMD_UNKNOWN),
m_code(0) {}
/** Destructor.
*/
virtual ~Command() {}
/** Gets the type of this command
* @return type of this command
*/
CommandType getCommandType() const { return m_commandType; }
/** Sets the type of this command
*/
void setCommandType(CommandType type) { m_commandType = type; }
/** Gets the code of this command. Meaning of code depends on the command type
* @return code of this command
*/
int32_t getCode() const { return m_code; }
/** Sets the code of this command. Meaning of code depends on the command type
*/
void setCode(int32_t code) { m_code = code; }
/** Marks events as consumed.
*/
virtual void consume() { Event::consume(); }
/** Checks whether event is consumed.
*/
virtual bool isConsumed() const { return Event::isConsumed(); }
/** Gets the source of the event.
*/
virtual IEventSource* getSource() const { return Event::getSource(); }
/** Sets the source of the event.
*/
virtual void setSource(IEventSource* source) { Event::setSource(source); }
/** Gets the timestamp of the event.
*/
virtual int32_t getTimeStamp() const { return Event::getTimeStamp(); }
/** Sets the timestamp of the event.
*/
virtual void setTimeStamp(int32_t timestamp ) { Event::setTimeStamp(timestamp); }
/** Gets the name of the event.
*/
virtual const std::string& getName() const {
const static std::string eventName("Command");
return eventName;
}
/** Gets the debugstring of the event.
*/
virtual std::string getDebugString() const { return Event::getDebugString(); }
private:
CommandType m_commandType;
int32_t m_code;
};
} //FIFE
#endif
|