Check map objectives in d4d32d912299 using the new get_map_objectives native.

This commit is contained in:
Vincent Herbet 2013-08-10 12:03:08 +02:00
parent beca0030e4
commit 25fe31aa34

View File

@ -36,10 +36,6 @@
#include <amxmisc> #include <amxmisc>
#include <csx> #include <csx>
#define AMXMODX_NOAUTOLOAD
#include <engine>
#include <fakemeta>
public MultiKill public MultiKill
public MultiKillSound public MultiKillSound
public BombPlanting public BombPlanting
@ -110,8 +106,6 @@ const TEAM_CT = 2
new g_connected[33] new g_connected[33]
new g_bIsBombMap = false
new g_MultiKillMsg[7][] = new g_MultiKillMsg[7][] =
{ {
"Multi-Kill! %s^n%L %d %L (%d %L)", "Multi-Kill! %s^n%L %d %L (%d %L)",
@ -224,12 +218,8 @@ public plugin_init()
register_event("StatusValue", "hideStatus", "bef", "1=1", "2=0") register_event("StatusValue", "hideStatus", "bef", "1=1", "2=0")
new mapname[32], n = get_mapname(mapname, charsmax(mapname)) new mapname[32], n = get_mapname(mapname, charsmax(mapname))
new CLASSNAME[] = "classname", INFO_BOMB_TARGET[] = "info_bomb_target", FUNC_BOMB_TARGET[] = "func_bomb_target" if ((get_map_objectives() & MapObjective_Bomb) || (equali(mapname, "de_", 3) || equali(mapname, "csde_", 5)))
if( ( LibraryExists("engine", LibType_Library) && ( find_ent_by_class(0, INFO_BOMB_TARGET) > 0 || find_ent_by_class(0, FUNC_BOMB_TARGET) > 0 ) )
|| ( LibraryExists("fakemeta", LibType_Library) && ( engfunc(EngFunc_FindEntityByString, 0, CLASSNAME, INFO_BOMB_TARGET) > 0 || engfunc(EngFunc_FindEntityByString, 0, CLASSNAME, FUNC_BOMB_TARGET) > 0 ) )
|| (equali(mapname, "de_", 3) || equali(mapname, "csde_", 5)) )
{ {
g_bIsBombMap = true
register_event("StatusIcon", "eGotBomb", "be", "1=1", "1=2", "2=c4") register_event("StatusIcon", "eGotBomb", "be", "1=1", "1=2", "2=c4")
register_event("TextMsg", "eBombPickUp", "bc", "2&#Got_bomb") register_event("TextMsg", "eBombPickUp", "bc", "2&#Got_bomb")
register_event("TextMsg", "eBombDrop", "bc", "2&#Game_bomb_d") register_event("TextMsg", "eBombDrop", "bc", "2&#Game_bomb_d")
@ -428,29 +418,6 @@ copy_sound(dest[], len, src[])
} }
} }
public plugin_natives()
{
set_module_filter("module_filter")
set_native_filter("native_filter")
}
public module_filter(const module[])
{
if (equali(module, "engine")
|| equali(module, "fakemeta"))
return PLUGIN_HANDLED
return PLUGIN_CONTINUE
}
public native_filter(const name[], index, trap)
{
if (!trap)
return PLUGIN_HANDLED
return PLUGIN_CONTINUE
}
public plugin_cfg() public plugin_cfg()
{ {
new g_addStast[] = "amx_statscfg add ^"%s^" %s" new g_addStast[] = "amx_statscfg add ^"%s^" %s"
@ -1055,17 +1022,6 @@ public bomb_planted(planter)
public bomb_planting(planter) public bomb_planting(planter)
{ {
// obviously we are on a bomb map and detection (engine and fakemeta are not loaded) failed
// register now missing event, better than nothing
if( !g_bIsBombMap )
{
g_bIsBombMap = true
register_event("StatusIcon", "eGotBomb", "be", "1=1", "1=2", "2=c4")
register_event("TextMsg", "eBombPickUp", "bc", "2&#Got_bomb")
register_event("TextMsg", "eBombDrop", "bc", "2&#Game_bomb_d")
register_event("BarTime", "eStopDefuse", "b", "1=0")
}
if (BombPlanting) if (BombPlanting)
announceEvent(planter, "PLANT_BOMB") announceEvent(planter, "PLANT_BOMB")
} }