Add a OnPlayerRunCmdPre forward (#1760)
Adds an OnPlayerRunCmdPre forward in order for plugins to be able to hook OnPlayerRunCmd with the guarantee that none of the parameters have been modified by other plugins. As such, OnPlayerRunCmdPre's parameters cannot be modified and are read-only. Plugins that wish to use OnPlayerRunCmdPre can maintain backwards compatibility with SourceMod 1.10 by falling back to OnPlayerRunCmd if the Pre variant was never fired.
This commit is contained in:
		
							parent
							
								
									4e0c47a1d5
								
							
						
					
					
						commit
						5292721f0b
					
				| @ -69,6 +69,7 @@ CHookManager::CHookManager() | |||||||
| 	: replay_enabled("replay_enabled", false) | 	: replay_enabled("replay_enabled", false) | ||||||
| #endif | #endif | ||||||
| { | { | ||||||
|  | 	m_usercmdsPreFwd = NULL; | ||||||
| 	m_usercmdsFwd = NULL; | 	m_usercmdsFwd = NULL; | ||||||
| 	m_usercmdsPostFwd = NULL; | 	m_usercmdsPostFwd = NULL; | ||||||
| 	m_netFileSendFwd = NULL; | 	m_netFileSendFwd = NULL; | ||||||
| @ -98,6 +99,19 @@ void CHookManager::Initialize() | |||||||
| 	plsys->AddPluginsListener(this); | 	plsys->AddPluginsListener(this); | ||||||
| 	sharesys->AddCapabilityProvider(myself, this, FEATURECAP_PLAYERRUNCMD_11PARAMS); | 	sharesys->AddCapabilityProvider(myself, this, FEATURECAP_PLAYERRUNCMD_11PARAMS); | ||||||
| 	 | 	 | ||||||
|  | 	m_usercmdsPreFwd = forwards->CreateForward("OnPlayerRunCmdPre", ET_Ignore, 11, NULL, | ||||||
|  | 		Param_Cell,			// int client
 | ||||||
|  | 		Param_Cell,			// int buttons
 | ||||||
|  | 		Param_Cell,			// int impulse
 | ||||||
|  | 		Param_Array,		// float vel[3]
 | ||||||
|  | 		Param_Array,		// float angles[3]
 | ||||||
|  | 		Param_Cell,			// int weapon
 | ||||||
|  | 		Param_Cell,			// int subtype
 | ||||||
|  | 		Param_Cell,			// int cmdnum
 | ||||||
|  | 		Param_Cell,			// int tickcount
 | ||||||
|  | 		Param_Cell,			// int seed
 | ||||||
|  | 		Param_Array);		// int mouse[2]
 | ||||||
|  | 
 | ||||||
| 	m_usercmdsFwd = forwards->CreateForward("OnPlayerRunCmd", ET_Event, 11, NULL, | 	m_usercmdsFwd = forwards->CreateForward("OnPlayerRunCmd", ET_Event, 11, NULL, | ||||||
| 		Param_Cell,			// client
 | 		Param_Cell,			// client
 | ||||||
| 		Param_CellByRef,	// buttons
 | 		Param_CellByRef,	// buttons
 | ||||||
| @ -179,6 +193,7 @@ void CHookManager::Shutdown() | |||||||
| 	} | 	} | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | 	forwards->ReleaseForward(m_usercmdsPreFwd); | ||||||
| 	forwards->ReleaseForward(m_usercmdsFwd); | 	forwards->ReleaseForward(m_usercmdsFwd); | ||||||
| 	forwards->ReleaseForward(m_usercmdsPostFwd); | 	forwards->ReleaseForward(m_usercmdsPostFwd); | ||||||
| 	forwards->ReleaseForward(m_netFileSendFwd); | 	forwards->ReleaseForward(m_netFileSendFwd); | ||||||
| @ -283,7 +298,10 @@ void CHookManager::PlayerRunCmd(CUserCmd *ucmd, IMoveHelper *moveHelper) | |||||||
| 		RETURN_META(MRES_IGNORED); | 		RETURN_META(MRES_IGNORED); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (m_usercmdsFwd->GetFunctionCount() == 0) | 	bool hasUsercmdsPreFwds = (m_usercmdsPreFwd->GetFunctionCount() > 0); | ||||||
|  | 	bool hasUsercmdsFwds = (m_usercmdsFwd->GetFunctionCount() > 0); | ||||||
|  | 
 | ||||||
|  | 	if (!hasUsercmdsPreFwds && !hasUsercmdsFwds) | ||||||
| 	{ | 	{ | ||||||
| 		RETURN_META(MRES_IGNORED); | 		RETURN_META(MRES_IGNORED); | ||||||
| 	} | 	} | ||||||
| @ -312,6 +330,24 @@ void CHookManager::PlayerRunCmd(CUserCmd *ucmd, IMoveHelper *moveHelper) | |||||||
| 	cell_t angles[3] = {sp_ftoc(ucmd->viewangles.x), sp_ftoc(ucmd->viewangles.y), sp_ftoc(ucmd->viewangles.z)}; | 	cell_t angles[3] = {sp_ftoc(ucmd->viewangles.x), sp_ftoc(ucmd->viewangles.y), sp_ftoc(ucmd->viewangles.z)}; | ||||||
| 	cell_t mouse[2] = {ucmd->mousedx, ucmd->mousedy}; | 	cell_t mouse[2] = {ucmd->mousedx, ucmd->mousedy}; | ||||||
| 	 | 	 | ||||||
|  | 	if (hasUsercmdsPreFwds) | ||||||
|  | 	{ | ||||||
|  | 		m_usercmdsPreFwd->PushCell(client); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->buttons); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->impulse); | ||||||
|  | 		m_usercmdsPreFwd->PushArray(vel, 3); | ||||||
|  | 		m_usercmdsPreFwd->PushArray(angles, 3); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->weaponselect); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->weaponsubtype); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->command_number); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->tick_count); | ||||||
|  | 		m_usercmdsPreFwd->PushCell(ucmd->random_seed); | ||||||
|  | 		m_usercmdsPreFwd->PushArray(mouse, 2); | ||||||
|  | 		m_usercmdsPreFwd->Execute(); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (hasUsercmdsFwds) | ||||||
|  | 	{ | ||||||
| 		m_usercmdsFwd->PushCell(client); | 		m_usercmdsFwd->PushCell(client); | ||||||
| 		m_usercmdsFwd->PushCellByRef(&ucmd->buttons); | 		m_usercmdsFwd->PushCellByRef(&ucmd->buttons); | ||||||
| 		m_usercmdsFwd->PushCellByRef(&impulse); | 		m_usercmdsFwd->PushCellByRef(&impulse); | ||||||
| @ -340,6 +376,7 @@ void CHookManager::PlayerRunCmd(CUserCmd *ucmd, IMoveHelper *moveHelper) | |||||||
| 		{ | 		{ | ||||||
| 			RETURN_META(MRES_SUPERCEDE); | 			RETURN_META(MRES_SUPERCEDE); | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	RETURN_META(MRES_IGNORED); | 	RETURN_META(MRES_IGNORED); | ||||||
| } | } | ||||||
| @ -576,7 +613,7 @@ void CHookManager::OnPluginLoaded(IPlugin *plugin) | |||||||
| 	if (PRCH_enabled) | 	if (PRCH_enabled) | ||||||
| 	{ | 	{ | ||||||
| 		bool changed = false; | 		bool changed = false; | ||||||
| 		if (!PRCH_used && (m_usercmdsFwd->GetFunctionCount() > 0)) | 		if (!PRCH_used && ((m_usercmdsFwd->GetFunctionCount() > 0) || (m_usercmdsPreFwd->GetFunctionCount() > 0))) | ||||||
| 		{ | 		{ | ||||||
| 			PRCH_used = true; | 			PRCH_used = true; | ||||||
| 			changed = true; | 			changed = true; | ||||||
| @ -634,7 +671,7 @@ void CHookManager::OnPluginLoaded(IPlugin *plugin) | |||||||
| 
 | 
 | ||||||
| void CHookManager::OnPluginUnloaded(IPlugin *plugin) | void CHookManager::OnPluginUnloaded(IPlugin *plugin) | ||||||
| { | { | ||||||
| 	if (PRCH_used && !m_usercmdsFwd->GetFunctionCount()) | 	if (PRCH_used && (!m_usercmdsFwd->GetFunctionCount() && !m_usercmdsPreFwd->GetFunctionCount())) | ||||||
| 	{ | 	{ | ||||||
| 		for (size_t i = 0; i < m_runUserCmdHooks.size(); ++i) | 		for (size_t i = 0; i < m_runUserCmdHooks.size(); ++i) | ||||||
| 		{ | 		{ | ||||||
|  | |||||||
| @ -77,6 +77,7 @@ private: | |||||||
| 	void NetChannelHook(int client); | 	void NetChannelHook(int client); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | 	IForward *m_usercmdsPreFwd; | ||||||
| 	IForward *m_usercmdsFwd; | 	IForward *m_usercmdsFwd; | ||||||
| 	IForward *m_usercmdsPostFwd; | 	IForward *m_usercmdsPostFwd; | ||||||
| 	IForward *m_netFileSendFwd; | 	IForward *m_netFileSendFwd; | ||||||
|  | |||||||
| @ -37,6 +37,23 @@ | |||||||
| 
 | 
 | ||||||
| #define FEATURECAP_PLAYERRUNCMD_11PARAMS    "SDKTools PlayerRunCmd 11Params"
 | #define FEATURECAP_PLAYERRUNCMD_11PARAMS    "SDKTools PlayerRunCmd 11Params"
 | ||||||
| 
 | 
 | ||||||
|  | /** | ||||||
|  |  * Called when a clients movement buttons are being processed (Read Only) | ||||||
|  |  * | ||||||
|  |  * @param client        Index of the client. | ||||||
|  |  * @param buttons       Current commands (as bitflags - see entity_prop_stocks.inc). | ||||||
|  |  * @param impulse       Current impulse command. | ||||||
|  |  * @param vel           Players desired velocity. | ||||||
|  |  * @param angles        Players desired view angles. | ||||||
|  |  * @param weapon        Entity index of the new weapon if player switches weapon, 0 otherwise. | ||||||
|  |  * @param subtype       Weapon subtype when selected from a menu. | ||||||
|  |  * @param cmdnum        Command number. Increments from the first command sent. | ||||||
|  |  * @param tickcount     Tick count. A client's prediction based on the server's GetGameTickCount value. | ||||||
|  |  * @param seed          Random seed. Used to determine weapon recoil, spread, and other predicted elements. | ||||||
|  |  * @param mouse         Mouse direction (x, y). | ||||||
|  |  */ | ||||||
|  | forward void OnPlayerRunCmdPre(int client, int buttons, int impulse, const float vel[3], const float angles[3], int weapon, int subtype, int cmdnum, int tickcount, int seed, const int mouse[2]); | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * Called when a clients movement buttons are being processed |  * Called when a clients movement buttons are being processed | ||||||
|  * |  * | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user