mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-10-24 08:18:10 +00:00

* 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
32 lines
1.1 KiB
C++
32 lines
1.1 KiB
C++
#include "ActionContext.h"
|
|
|
|
#include <stdexcept>
|
|
|
|
#include "Amf3.h"
|
|
|
|
ActionContext::ActionContext() {
|
|
stripId = 0;
|
|
stateId = BehaviorState::HOME_STATE;
|
|
}
|
|
|
|
ActionContext::ActionContext(AMFArrayValue* arguments, std::string customStateKey, std::string customStripKey) {
|
|
stripId = 0;
|
|
stateId = BehaviorState::HOME_STATE;
|
|
stripId = GetStripIdFromArgument(arguments, customStripKey);
|
|
stateId = GetBehaviorStateFromArgument(arguments, customStateKey);
|
|
}
|
|
|
|
BehaviorState ActionContext::GetBehaviorStateFromArgument(AMFArrayValue* arguments, const std::string& key) {
|
|
auto* stateIDValue = arguments->Get<double>(key);
|
|
if (!stateIDValue) throw std::invalid_argument("Unable to find behavior state from argument \"" + key + "\"");
|
|
|
|
return static_cast<BehaviorState>(stateIDValue->GetValue());
|
|
}
|
|
|
|
StripId ActionContext::GetStripIdFromArgument(AMFArrayValue* arguments, const std::string& key) {
|
|
auto* stripIdValue = arguments->Get<double>(key);
|
|
if (!stripIdValue) throw std::invalid_argument("Unable to find strip ID from argument \"" + key + "\"");
|
|
|
|
return static_cast<StripId>(stripIdValue->GetValue());
|
|
}
|