2007-02-04 09:01:07 +01:00
|
|
|
/**
|
2007-02-12 10:00:55 +01:00
|
|
|
* vim: set ts=4 :
|
2007-02-04 09:01:07 +01:00
|
|
|
* ===============================================================
|
|
|
|
* SourceMod (C)2004-2007 AlliedModders LLC. All rights reserved.
|
|
|
|
* ===============================================================
|
|
|
|
*
|
|
|
|
* This file is part of the SourceMod/SourcePawn SDK. This file may only be used
|
|
|
|
* or modified under the Terms and Conditions of its License Agreement, which is found
|
|
|
|
* in LICENSE.txt. The Terms and Conditions for making SourceMod extensions/plugins
|
|
|
|
* may change at any time. To view the latest information, see:
|
|
|
|
* http://www.sourcemod.net/license.php
|
|
|
|
*
|
2007-02-16 19:50:27 +01:00
|
|
|
* Version: $Id$
|
2007-02-04 09:01:07 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#if defined _sourcemod_included
|
|
|
|
#endinput
|
|
|
|
#endif
|
|
|
|
#define _sourcemod_included
|
|
|
|
|
2007-03-15 21:44:23 +01:00
|
|
|
/**
|
|
|
|
* Plugin public information.
|
|
|
|
*/
|
2007-02-04 09:01:07 +01:00
|
|
|
struct Plugin
|
|
|
|
{
|
2007-03-15 21:44:23 +01:00
|
|
|
const String:name[], /**< Plugin Name */
|
|
|
|
const String:description[], /**< Plugin Description */
|
|
|
|
const String:author[], /**< Plugin Author */
|
|
|
|
const String:version[], /**< Plugin Version */
|
|
|
|
const String:url[], /**< Plugin URL */
|
2007-02-04 09:01:07 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#include <core>
|
|
|
|
#include <float>
|
2007-07-08 19:33:10 +02:00
|
|
|
#include <vector>
|
2007-02-04 09:01:07 +01:00
|
|
|
#include <string>
|
2007-06-01 08:33:54 +02:00
|
|
|
#include <handles>
|
|
|
|
#include <functions>
|
2007-02-04 09:01:07 +01:00
|
|
|
#include <files>
|
2007-06-01 08:33:54 +02:00
|
|
|
#include <timers>
|
|
|
|
#include <admin>
|
|
|
|
#include <dbi>
|
2007-06-07 09:22:19 +02:00
|
|
|
#include <lang>
|
2007-02-26 09:21:09 +01:00
|
|
|
#include <sorting>
|
2007-06-07 09:22:19 +02:00
|
|
|
#include <textparse>
|
2007-02-28 00:39:30 +01:00
|
|
|
#include <clients>
|
2007-06-01 08:33:54 +02:00
|
|
|
#include <console>
|
2007-03-04 05:05:03 +01:00
|
|
|
#include <events>
|
2007-06-01 08:33:54 +02:00
|
|
|
#include <bitbuffer>
|
|
|
|
#include <usermessages>
|
2007-06-07 09:22:19 +02:00
|
|
|
#include <keyvalues>
|
2007-06-01 08:33:54 +02:00
|
|
|
#include <menus>
|
2007-06-07 04:04:05 +02:00
|
|
|
#include <halflife>
|
|
|
|
|
2007-02-04 09:01:07 +01:00
|
|
|
/**
|
|
|
|
* Declare this as a struct in your plugin to expose its information.
|
|
|
|
* Example:
|
|
|
|
*
|
|
|
|
* public Plugin:myinfo =
|
|
|
|
* {
|
|
|
|
* name = "My Plugin",
|
|
|
|
* //etc
|
|
|
|
* };
|
|
|
|
*/
|
|
|
|
public Plugin:myinfo;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the plugin is fully initialized and all known external references are resolved.
|
|
|
|
* This is called even if the plugin type is "private."
|
2007-03-15 21:44:23 +01:00
|
|
|
* @note Errors in this function will cause the plugin to stop running.
|
2007-02-04 09:01:07 +01:00
|
|
|
*
|
|
|
|
* @noreturn
|
|
|
|
*/
|
2007-02-26 09:32:20 +01:00
|
|
|
forward OnPluginStart();
|
2007-02-04 09:01:07 +01:00
|
|
|
|
|
|
|
/**
|
2007-06-18 09:09:47 +02:00
|
|
|
* Called before OnPluginStart, in case the plugin wants to check for load failure.
|
2007-02-04 09:01:07 +01:00
|
|
|
* This is called even if the plugin type is "private." Any natives from modules are
|
|
|
|
* not available at this point. Thus, this forward should only be used for explicit
|
|
|
|
* pre-emptive things, such as adding dynamic natives, or setting certain types of load filters.
|
|
|
|
*
|
2007-03-15 21:44:23 +01:00
|
|
|
* @note It is not safe to call externally resolved natives until OnPluginStart().
|
|
|
|
* @note Any sort of RTE in this function will cause the plugin to fail loading.
|
2007-02-04 09:01:07 +01:00
|
|
|
*
|
|
|
|
* @param myself Handle to the plugin.
|
|
|
|
* @param late Whether or not the plugin was loaded "late" (after map load).
|
|
|
|
* @param error Error message buffer in case load failed.
|
|
|
|
* @param err_max Maximum number of characters for error message buffer.
|
|
|
|
* @return True if load success, false otherwise.
|
|
|
|
*/
|
|
|
|
forward bool:AskPluginLoad(Handle:myself, bool:late, String:error[], err_max);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the plugin is about to be unloaded.
|
|
|
|
*
|
|
|
|
* @noreturn
|
|
|
|
*/
|
|
|
|
forward OnPluginEnd();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the plugin's pause status is changing.
|
|
|
|
*
|
2007-02-12 10:00:55 +01:00
|
|
|
* @param pause True if the plugin is being paused, false otherwise.
|
2007-02-04 09:01:07 +01:00
|
|
|
* @noreturn
|
|
|
|
*/
|
|
|
|
forward OnPluginPauseChange(bool:pause);
|
|
|
|
|
2007-02-26 05:36:15 +01:00
|
|
|
/**
|
|
|
|
* Called before every server frame. Note that you should avoid
|
|
|
|
* doing expensive computations here, and you should declare large
|
|
|
|
* local arrays using 'decl' instead of 'new'.
|
|
|
|
*/
|
|
|
|
forward OnGameFrame();
|
|
|
|
|
2007-03-17 21:25:08 +01:00
|
|
|
/**
|
2007-05-02 19:45:09 +02:00
|
|
|
* Called when the map is loaded.
|
|
|
|
*
|
2007-05-02 22:44:35 +02:00
|
|
|
* @note This used to be OnServerLoad(), which is now deprecated.
|
2007-05-02 19:45:09 +02:00
|
|
|
* Plugins still using the old forward will work.
|
2007-03-17 21:25:08 +01:00
|
|
|
*/
|
2007-05-02 19:45:09 +02:00
|
|
|
forward OnMapStart();
|
2007-03-17 21:25:08 +01:00
|
|
|
|
2007-05-02 19:49:23 +02:00
|
|
|
/**
|
|
|
|
* Called right before a map ends.
|
|
|
|
*/
|
|
|
|
forward OnMapEnd();
|
|
|
|
|
2007-05-02 22:44:35 +02:00
|
|
|
/**
|
2007-06-18 09:04:22 +02:00
|
|
|
* Called when the map has loaded, servercfgfile (server.cfg) has been
|
|
|
|
* executed, and all plugin configs are done executing. This is the best
|
|
|
|
* place to inialize plugin functions which are based on cvar data.
|
2007-05-02 22:44:35 +02:00
|
|
|
*
|
2007-06-18 09:04:22 +02:00
|
|
|
* @note This will always be called once and only once per map. It will be
|
|
|
|
* called after OnMapStart().
|
|
|
|
*
|
|
|
|
* @noreturn
|
2007-05-02 22:44:35 +02:00
|
|
|
*/
|
2007-06-18 09:04:22 +02:00
|
|
|
forward OnConfigsExecuted();
|
2007-05-02 22:44:35 +02:00
|
|
|
|
2007-06-18 09:09:47 +02:00
|
|
|
/**
|
|
|
|
* @deprecated Use OnConfigsExecuted() instead.
|
|
|
|
*/
|
|
|
|
forward OnServerCfg();
|
|
|
|
|
2007-02-26 09:32:20 +01:00
|
|
|
/**
|
|
|
|
* Returns the calling plugin's Handle.
|
|
|
|
*
|
|
|
|
* @return Handle of the calling plugin.
|
|
|
|
*/
|
|
|
|
native Handle:GetMyHandle();
|
|
|
|
|
2007-03-15 21:10:25 +01:00
|
|
|
/**
|
|
|
|
* Returns an iterator that can be used to search through plugins.
|
|
|
|
*
|
|
|
|
* @return Handle to iterate with. Must be closed via
|
|
|
|
* CloseHandle().
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native Handle:GetPluginIterator();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether there are more plugins available in the iterator.
|
|
|
|
*
|
|
|
|
* @param iter Handle to the plugin iterator.
|
|
|
|
* @return True on more plugins, false otherwise.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native bool:MorePlugins(Handle:iter);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the current plugin in the iterator and advances the iterator.
|
|
|
|
*
|
|
|
|
* @param iter Handle to the plugin iterator.
|
|
|
|
* @return Current plugin the iterator is at, before
|
|
|
|
* the iterator is advanced.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native Handle:ReadPlugin(Handle:iter);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a plugin's status.
|
|
|
|
*
|
|
|
|
* @param plugin Plugin Handle (INVALID_HANDLE uses the calling plugin).
|
|
|
|
* @return Status code for the plugin.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native PluginStatus:GetPluginStatus(Handle:plugin);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a plugin's file name relative to the plugins folder.
|
|
|
|
*
|
|
|
|
* @param plugin Plugin Handle (INVALID_HANDLE uses the calling plugin).
|
|
|
|
* @param buffer Buffer to the store the file name.
|
|
|
|
* @param maxlength Maximum length of the name buffer.
|
|
|
|
* @noreturn
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native GetPluginFilename(Handle:plugin, String:buffer[], maxlength);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves whether or not a plugin is being debugged.
|
|
|
|
*
|
|
|
|
* @param plugin Plugin Handle (INVALID_HANDLE uses the calling plugin).
|
|
|
|
* @return True if being debugged, false otherwise.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native bool:IsPluginDebugging(Handle:hndl);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a plugin's public info.
|
|
|
|
*
|
|
|
|
* @param plugin Plugin Handle (INVALID_HANDLE uses the calling plugin).
|
|
|
|
* @param info Plugin info property to retrieve.
|
|
|
|
* @param buffer Buffer to store info in.
|
|
|
|
* @param maxlength Maximum length of buffer.
|
|
|
|
* @return True on success, false if property is not available.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native bool:GetPluginInfo(Handle:plugin, PluginInfo:info, String:buffer[], maxlength);
|
2007-03-02 20:10:44 +01:00
|
|
|
|
2007-05-23 03:44:00 +02:00
|
|
|
/**
|
|
|
|
* Causes the plugin to enter a failed state. An error will be thrown and
|
|
|
|
* the plugin will be paused until it is unloaded or reloaded.
|
|
|
|
*
|
|
|
|
* @param string Message to print.
|
|
|
|
* @noreturn
|
2007-05-23 03:59:58 +02:00
|
|
|
* @error Always throws SP_ERROR_ABORT.
|
2007-05-23 03:44:00 +02:00
|
|
|
*/
|
|
|
|
native SetFailState(const String:string[]);
|
|
|
|
|
2007-03-02 20:10:44 +01:00
|
|
|
/**
|
|
|
|
* Aborts the current callback and throws an error. This function
|
|
|
|
* does not return in that no code is executed following it.
|
|
|
|
*
|
|
|
|
* @param format String format.
|
|
|
|
* @param ... Format arguments.
|
|
|
|
* @noreturn
|
|
|
|
* @error Always!
|
|
|
|
*/
|
2007-03-16 21:39:32 +01:00
|
|
|
native ThrowError(const String:fmt[], any:...);
|
2007-03-02 20:10:44 +01:00
|
|
|
|
2007-02-04 09:01:07 +01:00
|
|
|
/**
|
|
|
|
* Logs a plugin message to the SourceMod logs.
|
|
|
|
*
|
2007-02-12 10:00:55 +01:00
|
|
|
* @param format String format.
|
|
|
|
* @param ... Format arguments.
|
2007-02-04 09:01:07 +01:00
|
|
|
* @noreturn
|
|
|
|
*/
|
2007-03-16 21:39:32 +01:00
|
|
|
native LogMessage(const String:format[], any:...);
|
2007-02-04 09:01:07 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs a plugin error message to the SourceMod logs.
|
|
|
|
*
|
2007-02-12 10:00:55 +01:00
|
|
|
* @param format String format.
|
|
|
|
* @param ... Format arguments.
|
2007-02-04 09:01:07 +01:00
|
|
|
* @noreturn
|
|
|
|
*/
|
2007-03-16 21:39:32 +01:00
|
|
|
native LogError(const String:format[], any:...);
|
2007-02-09 05:41:03 +01:00
|
|
|
|
2007-03-11 19:30:29 +01:00
|
|
|
/**
|
|
|
|
* Gets the system time as a unix timestamp.
|
|
|
|
*
|
|
|
|
* @param bigStamp Optional array to store the 64bit timestamp in.
|
|
|
|
* @return 32bit timestamp (number of seconds since unix epoch).
|
|
|
|
*/
|
|
|
|
native GetTime(bigStamp[2]={0,0});
|
|
|
|
|
2007-07-04 13:09:48 +02:00
|
|
|
/**
|
|
|
|
* Format date and time.
|
|
|
|
*
|
|
|
|
* @param buffer Destination string buffer.
|
|
|
|
* @param maxlength Maximum length of output string buffer.
|
|
|
|
* @param format Formatting rules.
|
2007-07-05 16:47:36 +02:00
|
|
|
* @param stamp Optional time stamp.
|
2007-07-04 13:09:48 +02:00
|
|
|
* @noreturn
|
|
|
|
*/
|
2007-07-05 16:47:36 +02:00
|
|
|
native FormatTime(String:buffer[], maxlength, const String:format[], stamp=-1);
|
2007-07-04 13:09:48 +02:00
|
|
|
|
2007-04-22 20:25:10 +02:00
|
|
|
/**
|
|
|
|
* Loads a game config file.
|
|
|
|
*
|
|
|
|
* @param file File to load. The path must be relative to the 'gamedata' folder under the config folder
|
|
|
|
* and the extension should be omitted.
|
|
|
|
* @return A handle to the game config file or INVALID_HANDLE in failure.
|
|
|
|
*/
|
|
|
|
native Handle:LoadGameConfigFile(const String:file[]);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an offset value.
|
|
|
|
*
|
|
|
|
* @param gc Game config handle.
|
|
|
|
* @param key Key to retrieve from the offset section.
|
|
|
|
* @return An offset, or -1 on failure.
|
|
|
|
*/
|
|
|
|
native GameConfGetOffset(Handle:gc, const String:key[]);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the value of a key from the "Keys" section.
|
|
|
|
*
|
|
|
|
* @param gc Game config handle.
|
|
|
|
* @param key Key to retrieve from the Keys section.
|
|
|
|
* @param buffer Destination string buffer.
|
|
|
|
* @param maxlen Maximum length of output string buffer.
|
2007-06-06 18:40:30 +02:00
|
|
|
* @return True if key existed, false otherwise.
|
2007-04-22 20:25:10 +02:00
|
|
|
*/
|
|
|
|
native bool:GameConfGetKeyValue(Handle:gc, const String:key[], String:buffer[], maxlen);
|
|
|
|
|
2007-06-06 18:40:30 +02:00
|
|
|
/**
|
|
|
|
* Returns the operating system's "tick count," which is a number of
|
|
|
|
* milliseconds since the operating system loaded. This can be used
|
|
|
|
* for basic benchmarks.
|
|
|
|
*
|
|
|
|
* @return Tick count in milliseconds.
|
|
|
|
*/
|
|
|
|
native GetSysTickCount();
|
|
|
|
|
2007-06-18 09:04:22 +02:00
|
|
|
/**
|
|
|
|
* Specifies that the given config file should be executed after plugin load.
|
|
|
|
* OnConfigsExecuted() will not be called until the config file has executed,
|
|
|
|
* but it will be called if the execution fails.
|
|
|
|
*
|
|
|
|
* @param autoCreate If true, and the config file does not exist, such a config
|
|
|
|
* file will be automatically created and populated with
|
|
|
|
* information from the plugin's registered cvars.
|
|
|
|
* @param name Name of the config file, excluding the .cfg extension.
|
|
|
|
* If empty, <plugin.filename.cfg> is assumed.
|
|
|
|
* @param folder Folder under cfg/ to use. By default this is "sourcemod."
|
|
|
|
* @noreturn
|
|
|
|
*/
|
|
|
|
native AutoExecConfig(bool:autoCreate=true, const String:name[]="", const String:folder[]="sourcemod");
|
|
|
|
|
2007-07-15 03:04:34 +02:00
|
|
|
/**
|
|
|
|
* Sets a native as optional, such that if it is unloaded, removed,
|
|
|
|
* or otherwise non-existent, the plugin will still work. Calling
|
|
|
|
* removed natives results in a run-time error.
|
|
|
|
*
|
|
|
|
* @param name Native name.
|
|
|
|
* @noreturn
|
|
|
|
*/
|
|
|
|
native MarkNativeAsOptional(const String:name[]);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Registers a library name for identifying as a dependency to
|
|
|
|
* other plugins.
|
|
|
|
*
|
|
|
|
* @param name Library name.
|
|
|
|
* @noreturn
|
|
|
|
*/
|
|
|
|
native RegPluginLibrary(const String:name[]);
|
|
|
|
|
2007-02-09 05:41:03 +01:00
|
|
|
#include <helpers>
|
2007-03-02 20:10:44 +01:00
|
|
|
#include <entity>
|