mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2025-01-12 23:08:03 +03:00
Fixed amb230 - radius_damage didn't completely kill players on some mods
This commit is contained in:
parent
74c6290dc0
commit
fc2b220c38
@ -136,12 +136,15 @@ static cell AMX_NATIVE_CALL RadiusDamage_AMXModX(AMX *amx, cell *params)
|
|||||||
Vector vOrigin = Vector(fCurrentX, fCurrentY, fCurrentZ);
|
Vector vOrigin = Vector(fCurrentX, fCurrentY, fCurrentZ);
|
||||||
|
|
||||||
edict_t *pSearchEnt = NULL;
|
edict_t *pSearchEnt = NULL;
|
||||||
while((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 5 * iRadiusMultiplier)) != NULL) {
|
while ((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 5 * iRadiusMultiplier)) != NULL)
|
||||||
if(FStrEq(STRING(pSearchEnt->v.classname), "player")) {
|
{
|
||||||
if(pSearchEnt->v.takedamage != DAMAGE_NO) {
|
if (FStrEq(STRING(pSearchEnt->v.classname), "player"))
|
||||||
|
{
|
||||||
|
if (pSearchEnt->v.takedamage != DAMAGE_NO)
|
||||||
|
{
|
||||||
pSearchEnt->v.health -= 10 + RANDOM_FLOAT(0, 1 * iDamageMultiplier);
|
pSearchEnt->v.health -= 10 + RANDOM_FLOAT(0, 1 * iDamageMultiplier);
|
||||||
if(pSearchEnt->v.health < 1) {
|
if (pSearchEnt->v.health < 1)
|
||||||
pSearchEnt->v.health = 1;
|
{
|
||||||
MDLL_ClientKill(pSearchEnt);
|
MDLL_ClientKill(pSearchEnt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -150,12 +153,15 @@ static cell AMX_NATIVE_CALL RadiusDamage_AMXModX(AMX *amx, cell *params)
|
|||||||
|
|
||||||
pSearchEnt = NULL;
|
pSearchEnt = NULL;
|
||||||
|
|
||||||
while((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 4 * iRadiusMultiplier)) != NULL) {
|
while ((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 4 * iRadiusMultiplier)) != NULL)
|
||||||
if(FStrEq(STRING(pSearchEnt->v.classname), "player")) {
|
{
|
||||||
if(pSearchEnt->v.takedamage != DAMAGE_NO) {
|
if (FStrEq(STRING(pSearchEnt->v.classname), "player"))
|
||||||
|
{
|
||||||
|
if (pSearchEnt->v.takedamage != DAMAGE_NO)
|
||||||
|
{
|
||||||
pSearchEnt->v.health -= 25 + RANDOM_FLOAT(0, 2 * iDamageMultiplier);
|
pSearchEnt->v.health -= 25 + RANDOM_FLOAT(0, 2 * iDamageMultiplier);
|
||||||
if(pSearchEnt->v.health < 1) {
|
if (pSearchEnt->v.health < 1)
|
||||||
pSearchEnt->v.health = 1;
|
{
|
||||||
MDLL_ClientKill(pSearchEnt);
|
MDLL_ClientKill(pSearchEnt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -164,12 +170,15 @@ static cell AMX_NATIVE_CALL RadiusDamage_AMXModX(AMX *amx, cell *params)
|
|||||||
|
|
||||||
pSearchEnt = NULL;
|
pSearchEnt = NULL;
|
||||||
|
|
||||||
while((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 3 * iRadiusMultiplier)) != NULL) {
|
while ((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 3 * iRadiusMultiplier)) != NULL)
|
||||||
if(FStrEq(STRING(pSearchEnt->v.classname), "player")) {
|
{
|
||||||
if(pSearchEnt->v.takedamage != DAMAGE_NO) {
|
if (FStrEq(STRING(pSearchEnt->v.classname), "player"))
|
||||||
|
{
|
||||||
|
if (pSearchEnt->v.takedamage != DAMAGE_NO)
|
||||||
|
{
|
||||||
pSearchEnt->v.health -= 50 + RANDOM_FLOAT(0, 3 * iDamageMultiplier);
|
pSearchEnt->v.health -= 50 + RANDOM_FLOAT(0, 3 * iDamageMultiplier);
|
||||||
if(pSearchEnt->v.health < 1) {
|
if (pSearchEnt->v.health < 1)
|
||||||
pSearchEnt->v.health = 1;
|
{
|
||||||
MDLL_ClientKill(pSearchEnt);
|
MDLL_ClientKill(pSearchEnt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -178,9 +187,14 @@ static cell AMX_NATIVE_CALL RadiusDamage_AMXModX(AMX *amx, cell *params)
|
|||||||
|
|
||||||
pSearchEnt = NULL;
|
pSearchEnt = NULL;
|
||||||
|
|
||||||
while((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 2 * iRadiusMultiplier)) != NULL) {
|
while ((pSearchEnt = UTIL_FindEntityInSphere(pSearchEnt, vOrigin, 2 * iRadiusMultiplier)) != NULL)
|
||||||
if(FStrEq(STRING(pSearchEnt->v.classname), "player")) {
|
{
|
||||||
if(pSearchEnt->v.takedamage != DAMAGE_NO) MDLL_ClientKill(pSearchEnt);
|
if (FStrEq(STRING(pSearchEnt->v.classname), "player"))
|
||||||
|
{
|
||||||
|
if (pSearchEnt->v.takedamage != DAMAGE_NO)
|
||||||
|
{
|
||||||
|
MDLL_ClientKill(pSearchEnt);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user