mirror of https://github.com/AxioDL/metaforce.git
152 lines
4.2 KiB
C++
Executable File
152 lines
4.2 KiB
C++
Executable File
#ifndef CVAR_HPP
|
|
#define CVAR_HPP
|
|
|
|
#include <string>
|
|
#include <functional>
|
|
#include <Athena/Types.hpp>
|
|
#include <Athena/Global.hpp>
|
|
#include <Athena/DNAYaml.hpp>
|
|
|
|
namespace HECL
|
|
{
|
|
namespace DNACVAR
|
|
{
|
|
enum class EType : atUint8
|
|
{
|
|
Boolean,
|
|
Integer,
|
|
Float,
|
|
Literal,
|
|
Vec4f
|
|
};
|
|
|
|
enum EFlags
|
|
{
|
|
All = -1, // NOTE: is this really necessary? It seems rather overkill
|
|
System = (1 << 0),
|
|
Game = (1 << 1),
|
|
Editor = (1 << 2),
|
|
Gui = (1 << 3),
|
|
Cheat = (1 << 4),
|
|
Hidden = (1 << 5),
|
|
ReadOnly = (1 << 6),
|
|
Archive = (1 << 7),
|
|
Modified = (1 << 8)
|
|
};
|
|
ENABLE_BITWISE_ENUM(EFlags)
|
|
|
|
class CVar : public Athena::io::DNAYaml<Athena::BigEndian>
|
|
{
|
|
public:
|
|
DECL_YAML
|
|
String<-1> m_name;
|
|
String<-1> m_value;
|
|
Value<EType> m_type;
|
|
};
|
|
|
|
struct CVarContainer : public Athena::io::DNAYaml<Athena::BigEndian>
|
|
{
|
|
DECL_YAML
|
|
Value<atUint32> magic = 'CVAR';
|
|
Value<atUint32> cvarCount;
|
|
Vector<CVar, DNA_COUNT(cvarCount)> cvars;
|
|
};
|
|
|
|
}
|
|
|
|
class CVarManager;
|
|
class CVar : protected DNACVAR::CVar
|
|
{
|
|
friend class CVarManager;
|
|
Delete _d;
|
|
|
|
public:
|
|
typedef std::function<void(CVar*)> ListenerFunc;
|
|
|
|
using EType = DNACVAR::EType;
|
|
using EFlags = DNACVAR::EFlags;
|
|
|
|
CVar(const std::string& name, const std::string& value, const std::string& help, EType type, EFlags flags, CVarManager& parent);
|
|
CVar(const std::string& name, const std::string& value, const std::string& help, EFlags flags, CVarManager& parent);
|
|
CVar(const std::string& name, float value, const std::string& help, EFlags flags, CVarManager& parent);
|
|
CVar(const std::string& name, bool value, const std::string& help, EFlags flags, CVarManager& parent);
|
|
CVar(const std::string& name, int value, const std::string& help, EFlags flags, CVarManager& parent);
|
|
CVar(const std::string& name, const atVec4f& value, const std::string& help, EFlags flags, CVarManager& parent);
|
|
|
|
|
|
const std::string& name() const { return m_name; }
|
|
std::string help() const;
|
|
|
|
atVec4f toVec4f(bool* isValid = nullptr) const;
|
|
float toFloat(bool* isValid = nullptr) const;
|
|
bool toBoolean(bool* isValid = nullptr) const;
|
|
int toInteger(bool* isValid = nullptr) const;
|
|
const std::wstring toWideLiteral(bool* isValid = nullptr) const;
|
|
const std::string toLiteral(bool* isValid = nullptr) const;
|
|
|
|
bool fromVec4f(const atVec4f& val);
|
|
bool fromFloat(float val);
|
|
bool fromBoolean(bool val);
|
|
bool fromInteger(int val);
|
|
bool fromLiteral(const std::string& val);
|
|
bool fromLiteral(const std::wstring& val);
|
|
|
|
bool isFloat() const { return m_type == EType::Float; }
|
|
bool isBoolean() const { return m_type == EType::Boolean; }
|
|
bool isInteger() const { return m_type == EType::Integer; }
|
|
bool isLiteral() const { return m_type == EType::Literal; }
|
|
bool isVec4f() const { return m_type == EType::Vec4f; }
|
|
bool isModified() const;
|
|
bool isReadOnly() const;
|
|
bool isCheat() const;
|
|
bool isHidden() const;
|
|
bool isArchive() const;
|
|
void clearModified();
|
|
void setModified();
|
|
|
|
EType type() const { return m_type; }
|
|
EFlags flags() const { return m_flags; }
|
|
|
|
/*!
|
|
* \brief Unlocks the CVar for writing if it is ReadOnly.
|
|
* <b>Handle with care!!!</b> if you use unlock(), make sure
|
|
* you lock the cvar using lock()
|
|
* \see lock
|
|
*/
|
|
void unlock();
|
|
|
|
/*!
|
|
* \brief Locks the CVar to prevent writing if it is ReadOnly.
|
|
* Unlike its partner function unlock, lock is harmless
|
|
* \see unlock
|
|
*/
|
|
void lock();
|
|
|
|
void addListener(ListenerFunc func) { m_listeners.push_back(func); }
|
|
|
|
private:
|
|
void dispatch();
|
|
std::string m_help;
|
|
std::string m_defaultValue;
|
|
EFlags m_flags;
|
|
bool m_allowedWrite;
|
|
|
|
CVarManager& m_mgr;
|
|
|
|
std::vector<ListenerFunc> m_listeners;
|
|
};
|
|
|
|
|
|
|
|
class CVarUnlocker
|
|
{
|
|
CVar* m_cvar;
|
|
public:
|
|
CVarUnlocker(CVar* cvar) : m_cvar(cvar) { if (m_cvar) m_cvar->unlock(); }
|
|
~CVarUnlocker() { if (m_cvar) m_cvar->lock(); }
|
|
};
|
|
|
|
}
|
|
#endif // CVAR_HPP
|
|
|