11aefe731b
Fixed bunch of includes and a warnings Added ip addresses for admins to status KnifeAlert prints to everyone now if someone gets infected due to a knifed zombie Fixed WeaponCleaner not registering weapons if somebody disconnects Refactored custom-chatcolors to new syntax, added autoreplace and some fixes Added GFLClan.ru support to immunityreservedslots added nominate_removemap to mapchooser_extended and fixed a bug for recently played maps
161 lines
4.9 KiB
SourcePawn
161 lines
4.9 KiB
SourcePawn
//====================================================================================================
|
|
//
|
|
// Name: ForceInput
|
|
// Author: zaCade
|
|
// Description: Allows admins to force inputs on entities. (ent_fire)
|
|
//
|
|
//====================================================================================================
|
|
#include <sourcemod>
|
|
#include <sdktools>
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
// Purpose:
|
|
//----------------------------------------------------------------------------------------------------
|
|
public Plugin:myinfo =
|
|
{
|
|
name = "ForceInput",
|
|
author = "zaCade + BotoX",
|
|
description = "Allows admins to force inputs on entities. (ent_fire)",
|
|
version = "1.3",
|
|
url = ""
|
|
};
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
// Purpose:
|
|
//----------------------------------------------------------------------------------------------------
|
|
public OnPluginStart()
|
|
{
|
|
LoadTranslations("common.phrases");
|
|
|
|
RegAdminCmd("sm_forceinput", Command_ForceInput, ADMFLAG_ROOT);
|
|
RegAdminCmd("sm_forceinputplayer", Command_ForceInputPlayer, ADMFLAG_ROOT);
|
|
}
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
// Purpose:
|
|
//----------------------------------------------------------------------------------------------------
|
|
public Action:Command_ForceInputPlayer(client, args)
|
|
{
|
|
if (GetCmdArgs() < 2)
|
|
{
|
|
ReplyToCommand(client, "[SM] Usage: sm_forceinputplayer <target> <input> [parameter]");
|
|
return Plugin_Handled;
|
|
}
|
|
|
|
new String:sArguments[3][256];
|
|
GetCmdArg(1, sArguments[0], sizeof(sArguments[]));
|
|
GetCmdArg(2, sArguments[1], sizeof(sArguments[]));
|
|
GetCmdArg(3, sArguments[2], sizeof(sArguments[]));
|
|
|
|
decl String:target_name[MAX_TARGET_LENGTH];
|
|
decl target_list[MAXPLAYERS], target_count, bool:tn_is_ml;
|
|
|
|
if((target_count = ProcessTargetString(
|
|
sArguments[0],
|
|
client,
|
|
target_list,
|
|
MAXPLAYERS,
|
|
0,
|
|
target_name,
|
|
sizeof(target_name),
|
|
tn_is_ml)) <= 0)
|
|
{
|
|
ReplyToTargetError(client, target_count);
|
|
return Plugin_Handled;
|
|
}
|
|
|
|
for(new i = 0; i < target_count; i++)
|
|
{
|
|
if (sArguments[2][0])
|
|
SetVariantString(sArguments[2]);
|
|
|
|
AcceptEntityInput(target_list[i], sArguments[1], target_list[i], target_list[i]);
|
|
ReplyToCommand(client, "[SM] Input succesfull.");
|
|
}
|
|
|
|
return Plugin_Handled;
|
|
}
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
// Purpose:
|
|
//----------------------------------------------------------------------------------------------------
|
|
public Action:Command_ForceInput(client, args)
|
|
{
|
|
if (GetCmdArgs() < 2)
|
|
{
|
|
ReplyToCommand(client, "[SM] Usage: sm_forceinput <classname/targetname> <input> [parameter]");
|
|
return Plugin_Handled;
|
|
}
|
|
|
|
new String:sArguments[3][256];
|
|
GetCmdArg(1, sArguments[0], sizeof(sArguments[]));
|
|
GetCmdArg(2, sArguments[1], sizeof(sArguments[]));
|
|
GetCmdArg(3, sArguments[2], sizeof(sArguments[]));
|
|
|
|
if (StrEqual(sArguments[0], "!self"))
|
|
{
|
|
if (sArguments[2][0])
|
|
SetVariantString(sArguments[2]);
|
|
|
|
AcceptEntityInput(client, sArguments[1], client, client);
|
|
ReplyToCommand(client, "[SM] Input succesfull.");
|
|
}
|
|
else if (StrEqual(sArguments[0], "!target"))
|
|
{
|
|
new entity = INVALID_ENT_REFERENCE;
|
|
|
|
new Float:fPosition[3], Float:fAngles[3];
|
|
GetClientEyePosition(client, fPosition);
|
|
GetClientEyeAngles(client, fAngles);
|
|
|
|
new Handle:hTrace = TR_TraceRayFilterEx(fPosition, fAngles, MASK_SOLID, RayType_Infinite, TraceRayFilter, client);
|
|
|
|
if (TR_DidHit(hTrace) && ((entity = TR_GetEntityIndex(hTrace)) >= 1))
|
|
{
|
|
if (IsValidEntity(entity) || IsValidEdict(entity))
|
|
{
|
|
if (sArguments[2][0])
|
|
SetVariantString(sArguments[2]);
|
|
|
|
AcceptEntityInput(entity, sArguments[1], client, client);
|
|
ReplyToCommand(client, "[SM] Input succesfull.");
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
new entity = INVALID_ENT_REFERENCE;
|
|
|
|
while ((entity = FindEntityByClassname(entity, "*")) != INVALID_ENT_REFERENCE)
|
|
{
|
|
if (IsValidEntity(entity) || IsValidEdict(entity))
|
|
{
|
|
new String:sClassname[64], String:sTargetname[64];
|
|
GetEntPropString(entity, Prop_Data, "m_iClassname", sClassname, sizeof(sClassname));
|
|
GetEntPropString(entity, Prop_Data, "m_iName", sTargetname, sizeof(sTargetname));
|
|
|
|
if (StrEqual(sClassname, sArguments[0], false) || StrEqual(sTargetname, sArguments[0], false))
|
|
{
|
|
if (sArguments[2][0])
|
|
SetVariantString(sArguments[2]);
|
|
|
|
AcceptEntityInput(entity, sArguments[1], client, client);
|
|
ReplyToCommand(client, "[SM] Input succesfull.");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return Plugin_Handled;
|
|
}
|
|
|
|
//----------------------------------------------------------------------------------------------------
|
|
// Purpose:
|
|
//----------------------------------------------------------------------------------------------------
|
|
public bool:TraceRayFilter(entity, mask, any:client)
|
|
{
|
|
if (entity == client)
|
|
return false;
|
|
|
|
return true;
|
|
}
|