mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2024-12-25 15:03:34 +00:00
4fe335cc66
* Update AMFDeserializeTests.cpp Redo Amf3 functionality Overhaul the whole thing due to it being outdated and clunky to use Sometimes you want to keep the value Update AMFDeserializeTests.cpp * Fix enum and constructors Correct enum to a class and simplify names. Add a proper default constructor * Update MasterServer.cpp * Fix bugs and add more tests * Refactor: AMF with templates in mind - Remove hard coded bodge - Use templates and generics to allow for much looser typing and strengthened implementation - Move code into header only implementation for portability Refactor: Convert AMF implementation to templates - Rip out previous implementation - Remove all extraneous terminology - Add proper overloads for all types of inserts - Fix up tests and codebase * Fix compiler errors * Check for null first * Add specialization for const char* * Update tests for new template specialization * Switch BitStream to use references * Rename files * Check enum bounds on deserialize I did this on a phone
30 lines
700 B
C++
30 lines
700 B
C++
#ifndef __BEHAVIORMESSAGEBASE__H__
|
|
#define __BEHAVIORMESSAGEBASE__H__
|
|
|
|
#include <stdexcept>
|
|
#include <string>
|
|
|
|
#include "Amf3.h"
|
|
#include "dCommonVars.h"
|
|
|
|
#include "Game.h"
|
|
#include "dLogger.h"
|
|
|
|
enum class BehaviorState : uint32_t;
|
|
|
|
/**
|
|
* @brief The behaviorID target of this ControlBehaviors message
|
|
*
|
|
*/
|
|
class BehaviorMessageBase {
|
|
public:
|
|
const uint32_t GetBehaviorId() { return behaviorId; };
|
|
protected:
|
|
BehaviorMessageBase(AMFArrayValue* arguments);
|
|
int32_t GetBehaviorIdFromArgument(AMFArrayValue* arguments);
|
|
uint32_t GetActionIndexFromArgument(AMFArrayValue* arguments, const std::string& keyName = "actionIndex");
|
|
int32_t behaviorId = -1;
|
|
};
|
|
|
|
#endif //!__BEHAVIORMESSAGEBASE__H__
|