2017-02-26 21:00:51 +00:00
|
|
|
#ifndef OPENMW_MISCELLANEOUSAPI_HPP
|
|
|
|
#define OPENMW_MISCELLANEOUSAPI_HPP
|
|
|
|
|
|
|
|
#include "../Types.hpp"
|
|
|
|
|
|
|
|
#define MISCELLANEOUSAPI \
|
2018-05-04 00:09:54 +00:00
|
|
|
{"DoesFileExist", MiscellaneousFunctions::DoesFileExist},\
|
2017-08-18 04:13:08 +00:00
|
|
|
{"GetCaseInsensitiveFilename", MiscellaneousFunctions::GetCaseInsensitiveFilename},\
|
2017-04-03 22:47:37 +00:00
|
|
|
\
|
2017-08-18 04:13:08 +00:00
|
|
|
{"GetLastPlayerId", MiscellaneousFunctions::GetLastPlayerId},\
|
2017-04-04 09:49:29 +00:00
|
|
|
\
|
2017-08-18 04:13:08 +00:00
|
|
|
{"GetCurrentMpNum", MiscellaneousFunctions::GetCurrentMpNum},\
|
|
|
|
{"SetCurrentMpNum", MiscellaneousFunctions::SetCurrentMpNum},\
|
|
|
|
\
|
2018-01-02 14:32:38 +00:00
|
|
|
{"GetPluginEnforcementState", MiscellaneousFunctions::GetPluginEnforcementState},\
|
|
|
|
{"SetPluginEnforcementState", MiscellaneousFunctions::SetPluginEnforcementState},\
|
|
|
|
\
|
2017-08-18 04:13:08 +00:00
|
|
|
{"LogMessage", MiscellaneousFunctions::LogMessage},\
|
|
|
|
{"LogAppend", MiscellaneousFunctions::LogAppend}
|
2017-02-26 21:00:51 +00:00
|
|
|
|
|
|
|
class MiscellaneousFunctions
|
|
|
|
{
|
|
|
|
public:
|
2017-08-18 04:13:08 +00:00
|
|
|
|
2018-05-04 00:09:54 +00:00
|
|
|
/**
|
|
|
|
* \brief Check whether a certain file exists.
|
|
|
|
*
|
|
|
|
* This will be a case sensitive check on case sensitive filesystems.
|
|
|
|
*
|
|
|
|
* Whenever you want to enforce case insensitivity, use GetCaseInsensitiveFilename() instead.
|
|
|
|
*
|
|
|
|
* \return Whether the file exists or not.
|
|
|
|
*/
|
|
|
|
static bool DoesFileExist(const char *filePath) noexcept;
|
|
|
|
|
2017-08-18 04:13:08 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the first filename in a folder that has a case insensitive match with the filename
|
|
|
|
* argument.
|
|
|
|
*
|
|
|
|
* This is used to retain case insensitivity when opening data files on Linux.
|
|
|
|
*
|
|
|
|
* \return The filename that matches.
|
|
|
|
*/
|
|
|
|
static const char *GetCaseInsensitiveFilename(const char *folderPath, const char *filename) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the last player ID currently connected to the server.
|
|
|
|
*
|
|
|
|
* Every player receives a unique numerical index known as their player ID upon joining the
|
|
|
|
* server.
|
|
|
|
*
|
|
|
|
* \return The player ID.
|
|
|
|
*/
|
2017-02-26 21:00:51 +00:00
|
|
|
static unsigned int GetLastPlayerId() noexcept;
|
2017-04-03 22:47:37 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the current (latest) mpNum generated by the server.
|
|
|
|
*
|
2017-07-23 18:59:33 +00:00
|
|
|
* Every object that did not exist in an .ESM or .ESP data file and has instead been placed or
|
|
|
|
* spawned through a server-sent packet has a numerical index known as its mpNum.
|
2017-07-19 17:40:51 +00:00
|
|
|
*
|
|
|
|
* When ObjectPlace and ObjectSpawn packets are received from players, their objects lack mpNums,
|
|
|
|
* so the server assigns them some based on incrementing the server's current mpNum, with the
|
|
|
|
* operation's final mpNum becoming the server's new current mpNum.
|
|
|
|
*
|
|
|
|
* \return The mpNum.
|
|
|
|
*/
|
2017-04-04 09:43:17 +00:00
|
|
|
static int GetCurrentMpNum() noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the current (latest) mpNum generated by the server.
|
|
|
|
*
|
|
|
|
* When restarting a server, it is important to revert to the previous current (latest) mpNum
|
|
|
|
* as stored in the server's data, so as to avoid starting over from 0 and ending up assigning
|
|
|
|
* duplicate mpNums to objects.
|
|
|
|
*
|
|
|
|
* \param mpNum The number that should be used as the new current mpNum.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-04-04 09:43:17 +00:00
|
|
|
static void SetCurrentMpNum(int mpNum) noexcept;
|
|
|
|
|
2018-01-02 14:32:38 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the plugin enforcement state of the server.
|
|
|
|
*
|
|
|
|
* If true, clients are required to use the same plugins as set for the server.
|
|
|
|
*
|
|
|
|
* \return The enforcement state.
|
|
|
|
*/
|
|
|
|
static int GetPluginEnforcementState() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the plugin enforcement state of the server.
|
|
|
|
*
|
|
|
|
* If true, clients are required to use the same plugins as set for the server.
|
|
|
|
*
|
|
|
|
* \param state The new enforcement state.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetPluginEnforcementState(bool state) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Write a log message with its own timestamp.
|
|
|
|
*
|
|
|
|
* It will have "[Script]:" prepended to it so as to mark it as a script-generated log message.
|
|
|
|
*
|
|
|
|
* \param level The logging level used (0 for LOG_VERBOSE, 1 for LOG_INFO, 2 for LOG_WARN,
|
|
|
|
* 3 for LOG_ERROR, 4 for LOG_FATAL).
|
|
|
|
* \param message The message logged.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-04-03 22:47:37 +00:00
|
|
|
static void LogMessage(unsigned short level, const char *message) noexcept;
|
2017-07-19 17:40:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Write a log message without its own timestamp.
|
|
|
|
*
|
|
|
|
* It will have "[Script]:" prepended to it so as to mark it as a script-generated log message.
|
|
|
|
*
|
|
|
|
* \param level The logging level used (0 for LOG_VERBOSE, 1 for LOG_INFO, 2 for LOG_WARN,
|
|
|
|
* 3 for LOG_ERROR, 4 for LOG_FATAL).
|
|
|
|
* \param message The message logged.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-04-03 22:47:37 +00:00
|
|
|
static void LogAppend(unsigned short level, const char *message) noexcept;
|
2017-02-26 21:00:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif //OPENMW_MISCELLANEOUSAPI_HPP
|