/// @addtogroup util Util /// @brief Provides various utility functions that don't have a better home /// @{ /// @file nwnx_util.nss #include "nwnx" const string NWNX_Util = "NWNX_Util"; ///< @private /// @name Resref Types /// @anchor resref_types /// Constants for the various types of resrefs. /// /// @{ const int NWNX_UTIL_RESREF_TYPE_NSS = 2009; const int NWNX_UTIL_RESREF_TYPE_NCS = 2010; const int NWNX_UTIL_RESREF_TYPE_AREA_ARE = 2012; const int NWNX_UTIL_RESREF_TYPE_TWODA = 2017; const int NWNX_UTIL_RESREF_TYPE_AREA_GIT = 2023; const int NWNX_UTIL_RESREF_TYPE_ITEM = 2025; const int NWNX_UTIL_RESREF_TYPE_CREATURE = 2027; const int NWNX_UTIL_RESREF_TYPE_DIALOG = 2029; const int NWNX_UTIL_RESREF_TYPE_TRIGGER = 2032; const int NWNX_UTIL_RESREF_TYPE_SOUND = 2035; const int NWNX_UTIL_RESREF_TYPE_ENCOUNTER = 2040; const int NWNX_UTIL_RESREF_TYPE_DOOR = 2042; const int NWNX_UTIL_RESREF_TYPE_PLACEABLE = 2044; const int NWNX_UTIL_RESREF_TYPE_STORE = 2051; const int NWNX_UTIL_RESREF_TYPE_WAYPOINT = 2058; ///@} /// @brief A world time struct struct NWNX_Util_WorldTime { int nCalendarDay; ///< The calendar day int nTimeOfDay; ///< The time of day }; /// @brief A high resolution timestamp struct NWNX_Util_HighResTimestamp { int seconds; ///< Seconds since epoch int microseconds; ///< Microseconds }; /// @brief Gets the name of the currently executing script. /// @note If depth is > 0, it will return the name of the script that called this one via ExecuteScript(). /// @param depth to seek the executing script. /// @return The name of the currently executing script. string NWNX_Util_GetCurrentScriptName(int depth = 0); /// @brief Gets a string that contains the ascii table. /// @note The character at index 0 is a space. /// @return A string that contains all characters at their position (e.g. 'A' at 65). string NWNX_Util_GetAsciiTableString(); /// @brief Gets an integer hash of a string. /// @param str The string to hash. /// @return The hashed string as an integer. int NWNX_Util_Hash(string str); /// @brief Gets the last modified timestamp (mtime) of the module file in seconds. /// @return The mtime of the module file. int NWNX_Util_GetModuleMtime(); /// @brief Gets the module short file name. /// @return The module file as a string. string NWNX_Util_GetModuleFile(); /// @brief Gets the value of customTokenNumber. /// @param customTokenNumber The token number to query. /// @return The string representation of the token value. string NWNX_Util_GetCustomToken(int customTokenNumber); /// @brief Convert an effect type to an itemproperty type. /// @param e The effect to convert to an itemproperty. /// @return The converted itemproperty. itemproperty NWNX_Util_EffectToItemProperty(effect e); /// @brief Convert an itemproperty type to an effect type. /// @param ip The itemproperty to convert to an effect. /// @return The converted effect. effect NWNX_Util_ItemPropertyToEffect(itemproperty ip); /// @brief Strip any color codes from a string. /// @param str The string to strip of color. /// @return The new string without any color codes. string NWNX_Util_StripColors(string str); /// @brief Retrieves an environment variable. /// @param sVarname The environment variable to query. /// @return The value of the environment variable. string NWNX_Util_GetEnvironmentVariable(string sVarname); /// @brief Gets the module real life minutes per in game hour. /// @return The minutes per hour. int NWNX_Util_GetMinutesPerHour(); /// @brief Set module real life minutes per in game hour. /// @param minutes The minutes per hour. void NWNX_Util_SetMinutesPerHour(int minutes); /// @anchor util_encode_url /// @brief Encodes a string for usage in a URL. /// @param str The string to encode for a URL. /// @return The url encoded string. string NWNX_Util_EncodeStringForURL(string str); /// @brief Get the first resref of nType. /// @param nType A @ref resref_types "Resref Type". /// @param sRegexFilter Lets you filter out resrefs using a regexfilter. /// For example: **nwnx_.\*** gets you all scripts prefixed with nwnx_ /// when using the NSS resref type. /// @param bModuleResourcesOnly If TRUE only custom resources will be returned. /// @return The first resref found or "" if none is found. string NWNX_Util_GetFirstResRef(int nType, string sRegexFilter = "", int bModuleResourcesOnly = TRUE); /// @brief Get the next resref. /// @return The next resref found or "" if none is found. string NWNX_Util_GetNextResRef(); /// @brief Get the last created object. /// @param nObjectType Does not take the NWScript OBJECT_TYPE_* constants. /// Use NWNX_Consts_TranslateNWScriptObjectType() to get their NWNX equivalent. /// @param nNthLast The nth last object created. /// @return The last created object. On error, this returns OBJECT_INVALID. object NWNX_Util_GetLastCreatedObject(int nObjectType, int nNthLast = 1); /// @brief Compiles and adds a script to the UserDirectory/nwnx folder, or to the location of sAlias. /// @note Will override existing scripts that are in the module. /// @param sFileName The script filename without extension, 16 or less characters. /// @param sScriptData The script data to compile /// @param bWrapIntoMain Set to TRUE to wrap sScriptData into void main(){}. /// @param sAlias The alias of the resource directory to add the ncs file to. Default: UserDirectory/nwnx /// @return "" on success, or the compilation error. string NWNX_Util_AddScript(string sFileName, string sScriptData, int bWrapIntoMain = FALSE, string sAlias = "NWNX"); /// @brief Adds a nss file to the UserDirectory/nwnx folder, or to the location of sAlias. /// @note Will override existing nss files that are in the module /// @param sFileName The script filename without extension, 16 or less characters. /// @param sContents The contents of the nss file /// @param sAlias The alias of the resource directory to add the nss file to. Default: UserDirectory/nwnx /// @return TRUE on success. int NWNX_Util_AddNSSFile(string sFileName, string sContents, string sAlias = "NWNX"); /// @brief Remove sFileName of nType from the UserDirectory/nwnx folder, or from the location of sAlias. /// @param sFileName The filename without extension, 16 or less characters. /// @param nType The @ref resref_types "Resref Type". /// @param sAlias The alias of the resource directory to remove the file from. Default: UserDirectory/nwnx /// @return TRUE on success. int NWNX_Util_RemoveNWNXResourceFile(string sFileName, int nType, string sAlias = "NWNX"); /// @brief Set the NWScript instruction limit. /// @param nInstructionLimit The new limit or -1 to reset to default. void NWNX_Util_SetInstructionLimit(int nInstructionLimit); /// @brief Get the NWScript instruction limit. int NWNX_Util_GetInstructionLimit(); /// @brief Set the number of NWScript instructions currently executed. /// @param nInstructions The number of instructions, must be >= 0. void NWNX_Util_SetInstructionsExecuted(int nInstructions); /// @brief Get the number of NWScript instructions currently executed. int NWNX_Util_GetInstructionsExecuted(); /// @brief Register a server console command that will execute a script chunk. /// @note Example usage: NWNX_Util_RegisterServerConsoleCommand("test", "PrintString(\"Test Command -> Args: $args\");"); /// @param sCommand The name of the command. /// @param sScriptChunk The script chunk to run. You can use $args to get the console command arguments. /// @return TRUE on success. int NWNX_Util_RegisterServerConsoleCommand(string sCommand, string sScriptChunk); /// @brief Unregister a server console command that was registered with NWNX_Util_RegisterServerConsoleCommand(). /// @param sCommand The name of the command. void NWNX_Util_UnregisterServerConsoleCommand(string sCommand); /// @brief Determines if the given plugin exists and is enabled. /// @param sPlugin The name of the plugin to check. This is the case sensitive plugin name as used by NWNX_CallFunction, NWNX_PushArgumentX /// @note Example usage: NWNX_Util_PluginExists("NWNX_Creature"); /// @return TRUE if the plugin exists and is enabled, otherwise FALSE. int NWNX_Util_PluginExists(string sPlugin); /// @brief Gets the server's current working user folder. /// @return The absolute path of the server's home directory (-userDirectory) string NWNX_Util_GetUserDirectory(); /// @brief Get the return value of the last run script with a StartingConditional /// @return Return value of the last run script. int NWNX_Util_GetScriptReturnValue(); /// @brief Create a door. /// @param sResRef The ResRef of the door. /// @param locLocation The location to create the door at. /// @param sNewTag An optional new tag for the door. /// @param nAppearanceType An optional index into doortypes.2da for appearance. /// @return The door, or OBJECT_INVALID on failure. object NWNX_Util_CreateDoor(string sResRef, location locLocation, string sNewTag = "", int nAppearanceType = -1); /// @brief Set the object that will be returned by GetItemActivator. /// @param oObject An object. void NWNX_Util_SetItemActivator(object oObject); /// @brief Get the world time as calendar day and time of day. /// @note This function is useful for calculating effect expiry times. /// @param fAdjustment An adjustment in seconds, 0.0f will return the current world time, /// positive or negative values will return a world time in the future or past. /// @return A NWNX_Util_WorldTime struct with the calendar day and time of day. struct NWNX_Util_WorldTime NWNX_Util_GetWorldTime(float fAdjustment = 0.0f); /// @brief Set a server-side resource override. /// @param nResType A @ref resref_types "Resref Type". /// @param sOldName The old resource name, 16 characters or less. /// @param sNewName The new resource name or "" to clear a previous override, 16 characters or less. void NWNX_Util_SetResourceOverride(int nResType, string sOldName, string sNewName); /// @brief Get a server-side resource override. /// @param nResType A @ref resref_types "Resref Type". /// @param sName The name of the resource, 16 characters or less. /// @return The resource override, or "" if one is not set. string NWNX_Util_GetResourceOverride(int nResType, string sName); /// @brief Get if a script param is set. /// @param sParamName The script parameter name to check. /// @return TRUE if the script param is set, FALSE if not or on error. int NWNX_Util_GetScriptParamIsSet(string sParamName); /// @brief Set the module dawn hour. /// @param nDawnHour The new dawn hour void NWNX_Util_SetDawnHour(int nDawnHour); /// @brief Set the module dusk hour. /// @param nDuskHour The new dusk hour void NWNX_Util_SetDuskHour(int nDuskHour); /// @return Returns the number of microseconds since midnight on January 1, 1970. struct NWNX_Util_HighResTimestamp NWNX_Util_GetHighResTimeStamp(); /// @return Return name of a terminal, "" if not a TTY string NWNX_Util_GetTTY(); /// @brief Set the currently running script event. /// @param nEventID The ID of the event. void NWNX_Util_SetCurrentlyRunningEvent(int nEventID); /// @brief Calculate the levenshtein distance of two strings /// @param sString The string to compare with. /// @param sCompareTo The string to compare sString to. /// @return The number of characters different between the compared strings. int NWNX_Util_GetStringLevenshteinDistance(string sString, string sCompareTo); /// @} string NWNX_Util_GetCurrentScriptName(int depth = 0) { string sFunc = "GetCurrentScriptName"; NWNX_PushArgumentInt(depth); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } string NWNX_Util_GetAsciiTableString() { string sFunc = "GetAsciiTableString"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } int NWNX_Util_Hash(string str) { string sFunc = "Hash"; NWNX_PushArgumentString(str); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } int NWNX_Util_GetModuleMtime() { NWNX_CallFunction(NWNX_Util, "GetModuleMtime"); return NWNX_GetReturnValueInt(); } string NWNX_Util_GetModuleFile() { NWNX_CallFunction(NWNX_Util, "GetModuleFile"); return NWNX_GetReturnValueString(); } string NWNX_Util_GetCustomToken(int customTokenNumber) { string sFunc = "GetCustomToken"; NWNX_PushArgumentInt(customTokenNumber); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } itemproperty NWNX_Util_EffectToItemProperty(effect e) { string sFunc = "EffectTypeCast"; NWNX_PushArgumentEffect(e); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueItemProperty(); } effect NWNX_Util_ItemPropertyToEffect(itemproperty ip) { string sFunc = "EffectTypeCast"; NWNX_PushArgumentItemProperty(ip); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueEffect(); } string NWNX_Util_StripColors(string str) { string sFunc = "StripColors"; NWNX_PushArgumentString(str); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } string NWNX_Util_GetEnvironmentVariable(string sVarname) { string sFunc = "GetEnvironmentVariable"; NWNX_PushArgumentString(sVarname); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } int NWNX_Util_GetMinutesPerHour() { string sFunc = "GetMinutesPerHour"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } void NWNX_Util_SetMinutesPerHour(int minutes) { string sFunc = "SetMinutesPerHour"; NWNX_PushArgumentInt(minutes); NWNX_CallFunction(NWNX_Util, sFunc); } string NWNX_Util_EncodeStringForURL(string sURL) { string sFunc = "EncodeStringForURL"; NWNX_PushArgumentString(sURL); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } string NWNX_Util_GetFirstResRef(int nType, string sRegexFilter = "", int bModuleResourcesOnly = TRUE) { string sFunc = "GetFirstResRef"; NWNX_PushArgumentInt(bModuleResourcesOnly); NWNX_PushArgumentString(sRegexFilter); NWNX_PushArgumentInt(nType); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } string NWNX_Util_GetNextResRef() { string sFunc = "GetNextResRef"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } object NWNX_Util_GetLastCreatedObject(int nObjectType, int nNthLast = 1) { string sFunc = "GetLastCreatedObject"; NWNX_PushArgumentInt(nNthLast); NWNX_PushArgumentInt(nObjectType); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueObject(); } string NWNX_Util_AddScript(string sFileName, string sScriptData, int bWrapIntoMain = FALSE, string sAlias = "NWNX") { string sFunc = "AddScript"; NWNX_PushArgumentString(sAlias); NWNX_PushArgumentInt(bWrapIntoMain); NWNX_PushArgumentString(sScriptData); NWNX_PushArgumentString(sFileName); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } int NWNX_Util_AddNSSFile(string sFileName, string sContents, string sAlias = "NWNX") { string sFunc = "AddNSSFile"; NWNX_PushArgumentString(sAlias); NWNX_PushArgumentString(sContents); NWNX_PushArgumentString(sFileName); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } int NWNX_Util_RemoveNWNXResourceFile(string sFileName, int nType, string sAlias = "NWNX") { string sFunc = "RemoveNWNXResourceFile"; NWNX_PushArgumentString(sAlias); NWNX_PushArgumentInt(nType); NWNX_PushArgumentString(sFileName); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } void NWNX_Util_SetInstructionLimit(int nInstructionLimit) { string sFunc = "SetInstructionLimit"; NWNX_PushArgumentInt(nInstructionLimit); NWNX_CallFunction(NWNX_Util, sFunc); } int NWNX_Util_GetInstructionLimit() { string sFunc = "GetInstructionLimit"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } void NWNX_Util_SetInstructionsExecuted(int nInstructions) { string sFunc = "SetInstructionsExecuted"; NWNX_PushArgumentInt(nInstructions); NWNX_CallFunction(NWNX_Util, sFunc); } int NWNX_Util_GetInstructionsExecuted() { string sFunc = "GetInstructionsExecuted"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } int NWNX_Util_RegisterServerConsoleCommand(string sCommand, string sScriptChunk) { string sFunc = "RegisterServerConsoleCommand"; NWNX_PushArgumentString(sScriptChunk); NWNX_PushArgumentString(sCommand); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } void NWNX_Util_UnregisterServerConsoleCommand(string sCommand) { string sFunc = "UnregisterServerConsoleCommand"; NWNX_PushArgumentString(sCommand); NWNX_CallFunction(NWNX_Util, sFunc); } int NWNX_Util_PluginExists(string sPlugin) { WriteTimestampedLogEntry("WARNING: NWNX_Util_PluginExists is deprecated. You should migrate to NWNX_PluginExists."); return NWNX_PluginExists(sPlugin); } string NWNX_Util_GetUserDirectory() { string sFunc = "GetUserDirectory"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } int NWNX_Util_GetScriptReturnValue() { string sFunc = "GetScriptReturnValue"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } object NWNX_Util_CreateDoor(string sResRef, location locLocation, string sNewTag = "", int nAppearanceType = -1) { string sFunc = "CreateDoor"; vector vPosition = GetPositionFromLocation(locLocation); NWNX_PushArgumentInt(nAppearanceType); NWNX_PushArgumentString(sNewTag); NWNX_PushArgumentFloat(GetFacingFromLocation(locLocation)); NWNX_PushArgumentFloat(vPosition.z); NWNX_PushArgumentFloat(vPosition.y); NWNX_PushArgumentFloat(vPosition.x); NWNX_PushArgumentObject(GetAreaFromLocation(locLocation)); NWNX_PushArgumentString(sResRef); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueObject(); } void NWNX_Util_SetItemActivator(object oObject) { string sFunc = "SetItemActivator"; NWNX_PushArgumentObject(oObject); NWNX_CallFunction(NWNX_Util, sFunc); } struct NWNX_Util_WorldTime NWNX_Util_GetWorldTime(float fAdjustment = 0.0f) { string sFunc = "GetWorldTime"; NWNX_PushArgumentFloat(fAdjustment); NWNX_CallFunction(NWNX_Util, sFunc); struct NWNX_Util_WorldTime strWorldTime; strWorldTime.nTimeOfDay = NWNX_GetReturnValueInt(); strWorldTime.nCalendarDay = NWNX_GetReturnValueInt(); return strWorldTime; } void NWNX_Util_SetResourceOverride(int nResType, string sOldName, string sNewName) { string sFunc = "SetResourceOverride"; NWNX_PushArgumentString(sNewName); NWNX_PushArgumentString(sOldName); NWNX_PushArgumentInt(nResType); NWNX_CallFunction(NWNX_Util, sFunc); } string NWNX_Util_GetResourceOverride(int nResType, string sName) { string sFunc = "GetResourceOverride"; NWNX_PushArgumentString(sName); NWNX_PushArgumentInt(nResType); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } int NWNX_Util_GetScriptParamIsSet(string sParamName) { string sFunc = "GetScriptParamIsSet"; NWNX_PushArgumentString(sParamName); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); } void NWNX_Util_SetDawnHour(int nDawnHour) { string sFunc = "SetDawnHour"; NWNX_PushArgumentInt(nDawnHour); NWNX_CallFunction(NWNX_Util, sFunc); } void NWNX_Util_SetDuskHour(int nDuskHour) { string sFunc = "SetDuskHour"; NWNX_PushArgumentInt(nDuskHour); NWNX_CallFunction(NWNX_Util, sFunc); } struct NWNX_Util_HighResTimestamp NWNX_Util_GetHighResTimeStamp() { struct NWNX_Util_HighResTimestamp t; string sFunc = "GetHighResTimeStamp"; NWNX_CallFunction(NWNX_Util, sFunc); t.microseconds = NWNX_GetReturnValueInt(); t.seconds = NWNX_GetReturnValueInt(); return t; } string NWNX_Util_GetTTY() { string sFunc = "GetTTY"; NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueString(); } void NWNX_Util_SetCurrentlyRunningEvent(int nEventID) { string sFunc = "SetCurrentlyRunningEvent"; NWNX_PushArgumentInt(nEventID); NWNX_CallFunction(NWNX_Util, sFunc); } int NWNX_Util_GetStringLevenshteinDistance(string sString, string sCompareTo) { string sFunc = "LevenshteinDistance"; NWNX_PushArgumentString(sCompareTo); NWNX_PushArgumentString(sString); NWNX_CallFunction(NWNX_Util, sFunc); return NWNX_GetReturnValueInt(); }