97 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
| #if defined _updater_included
 | |
|   #endinput
 | |
| #endif
 | |
| #define _updater_included
 | |
| 
 | |
| /**
 | |
|  * Adds your plugin to the updater. The URL will be updated if
 | |
|  * your plugin was previously added.
 | |
|  *
 | |
|  * @param url		URL to your plugin's update file.
 | |
|  * @noreturn
 | |
|  */
 | |
| native Updater_AddPlugin(const String:url[]);
 | |
| 
 | |
| /**
 | |
|  * Removes your plugin from the updater. This does not need to
 | |
|  * be called during OnPluginEnd.
 | |
|  *
 | |
|  * @noreturn
 | |
|  */
 | |
| native Updater_RemovePlugin();
 | |
| 
 | |
| /**
 | |
|  * Forces your plugin to be checked for updates. The behaviour
 | |
|  * of the update is dependant on the server's configuration.
 | |
|  *
 | |
|  * @return		True if an update was triggered. False otherwise.
 | |
|  * @error		Plugin not found in updater.
 | |
|  */
 | |
| native bool:Updater_ForceUpdate();
 | |
| 
 | |
| /**
 | |
|  * Called when your plugin is about to be checked for updates.
 | |
|  *
 | |
|  * @return		Plugin_Handled to prevent checking, Plugin_Continue to allow it.
 | |
|  */
 | |
| forward Action:Updater_OnPluginChecking();
 | |
| 
 | |
| /**
 | |
|  * Called when your plugin is about to begin downloading an available update.
 | |
|  *
 | |
|  * @return		Plugin_Handled to prevent downloading, Plugin_Continue to allow it.
 | |
|  */
 | |
| forward Action:Updater_OnPluginDownloading();
 | |
| 
 | |
| /**
 | |
|  * Called when your plugin's update files have been fully downloaded
 | |
|  * and are about to write to their proper location. This should be used
 | |
|  * to free read-only resources that require write access for your update.
 | |
|  *
 | |
|  * @note OnPluginUpdated will be called later during the same frame.
 | |
|  *
 | |
|  * @noreturn
 | |
|  */
 | |
| forward Updater_OnPluginUpdating();
 | |
| 
 | |
| /**
 | |
|  * Called when your plugin's update has been completed. It is safe
 | |
|  * to reload your plugin at this time.
 | |
|  *
 | |
|  * @noreturn
 | |
|  */
 | |
| forward Updater_OnPluginUpdated();
 | |
| 
 | |
| /**
 | |
|  * @brief Reloads a plugin.
 | |
|  *
 | |
|  * @param plugin	Plugin Handle (INVALID_HANDLE uses the calling plugin).
 | |
|  * @noreturn
 | |
|  */
 | |
| stock ReloadPlugin(Handle:plugin=INVALID_HANDLE)
 | |
| {
 | |
| 	decl String:filename[64];
 | |
| 	GetPluginFilename(plugin, filename, sizeof(filename));
 | |
| 	ServerCommand("sm plugins reload %s", filename);
 | |
| }
 | |
| 
 | |
| 
 | |
| public SharedPlugin:__pl_updater =
 | |
| {
 | |
| 	name = "updater",
 | |
| 	file = "updater.smx",
 | |
| #if defined REQUIRE_PLUGIN
 | |
| 	required = 1,
 | |
| #else
 | |
| 	required = 0,
 | |
| #endif
 | |
| };
 | |
| 
 | |
| #if !defined REQUIRE_PLUGIN
 | |
| public __pl_updater_SetNTVOptional()
 | |
| {
 | |
| 	MarkNativeAsOptional("Updater_AddPlugin");
 | |
| 	MarkNativeAsOptional("Updater_RemovePlugin");
 | |
| 	MarkNativeAsOptional("Updater_ForceUpdate");
 | |
| }
 | |
| #endif |