mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 23:23:52 +00:00
2d0840cb3a
This commit changes the style of tes3mp serverside scripting mods. Short list of changes: * Break compatibility with old server mods * OOP style lua API * Basic dependency checker, allowing the installation of multiple server mods without changing configs * Remove support for C++ plugins * Change outdated LuaBridge to [sol2](https://github.com/ThePhD/sol2); * Support GCC, Clang and MSVC compilers * New environment variables: "TES3MP_SERVER_DIR" and "TES3MP_SERVER_USERDIR"; * New entity "Command controller" for registering new chat commands; * New Event system * Simplified Timer API * All Lua mods now run in their own environments * Add global namespace - Data that can be used for communicating between mods * Player and Actor inherit base class NetActor
76 lines
2.1 KiB
C++
76 lines
2.1 KiB
C++
//
|
|
// Created by koncord on 04.03.17.
|
|
//
|
|
|
|
#ifndef OPENMW_UTILS_HPP
|
|
#define OPENMW_UTILS_HPP
|
|
|
|
#include <cstddef>
|
|
#include <regex>
|
|
#include <vector>
|
|
|
|
#include <components/esm/loadcell.hpp>
|
|
|
|
#include <components/openmw-mp/Utils.hpp>
|
|
#include <components/openmw-mp/Log.hpp>
|
|
|
|
#define Singleton(className)\
|
|
public:\
|
|
className(className const&) = delete;\
|
|
className(className&&) = delete;\
|
|
className& operator=(className const&) = delete;\
|
|
className& operator=(className &&) = delete;\
|
|
protected:\
|
|
className();\
|
|
~className();\
|
|
public:\
|
|
static className &Get() {static className instance; return instance;}\
|
|
private:
|
|
|
|
#if (!defined(DEBUG_PRINTF) && defined(DEBUG))
|
|
#define DEBUG_PRINTF(...) LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, __VA_ARGS__)
|
|
#else
|
|
#define DEBUG_PRINTF(...)
|
|
#endif
|
|
|
|
|
|
namespace Utils
|
|
{
|
|
const std::vector<std::string> split(const std::string &str, int delimiter);
|
|
|
|
ESM::Cell getCellFromDescription(std::string cellDescription);
|
|
|
|
template<size_t N>
|
|
constexpr unsigned int hash(const char(&str)[N], size_t I = N)
|
|
{
|
|
return (I == 1 ? ((2166136261u ^ str[0]) * 16777619u) : ((hash(str, I - 1) ^ str[I - 1]) * 16777619u));
|
|
}
|
|
|
|
inline unsigned int hash(const char *str, std::size_t I)
|
|
{
|
|
return (I == 1 ? ((2166136261u ^ str[0]) * 16777619u) : ((hash(str, I - 1) ^ str[I - 1]) * 16777619u));
|
|
}
|
|
|
|
template<typename F, typename T, typename E = void>
|
|
struct is_static_castable : std::false_type
|
|
{
|
|
};
|
|
template<typename F, typename T>
|
|
struct is_static_castable<F, T, typename std::conditional<true, void, decltype(static_cast<T>(std::declval<F>()))>::type>
|
|
: std::true_type
|
|
{
|
|
};
|
|
|
|
template<typename T, typename F>
|
|
inline static typename std::enable_if<is_static_castable<F *, T *>::value, T *>::type static_or_dynamic_cast(
|
|
F *from)
|
|
{ return static_cast<T *>(from); }
|
|
|
|
template<typename T, typename F>
|
|
inline static typename std::enable_if<!is_static_castable<F *, T *>::value, T *>::type static_or_dynamic_cast(
|
|
F *from)
|
|
{ return dynamic_cast<T *>(from); }
|
|
}
|
|
|
|
|
|
#endif //OPENMW_UTILS_HPP
|