Fix last mapcycle issue and apply general optimizations in nextmap plugin (bug 5817, r=arkshine)

This commit is contained in:
connorr 2013-07-31 20:18:55 +02:00
parent 30394243ff
commit 9b5c7afc00

View File

@ -42,6 +42,11 @@
new g_nextMap[32] new g_nextMap[32]
new g_mapCycle[32] new g_mapCycle[32]
new g_pos new g_pos
new g_currentMap[32]
// pcvars
new g_mp_friendlyfire, g_mp_chattime
new g_amx_nextmap
public plugin_init() public plugin_init()
{ {
@ -50,32 +55,42 @@ public plugin_init()
register_event("30", "changeMap", "a") register_event("30", "changeMap", "a")
register_clcmd("say nextmap", "sayNextMap", 0, "- displays nextmap") register_clcmd("say nextmap", "sayNextMap", 0, "- displays nextmap")
register_clcmd("say currentmap", "sayCurrentMap", 0, "- display current map") register_clcmd("say currentmap", "sayCurrentMap", 0, "- display current map")
g_amx_nextmap = register_cvar("amx_nextmap", "", FCVAR_SERVER|FCVAR_EXTDLL|FCVAR_SPONLY)
g_mp_chattime = get_cvar_pointer("mp_chattime")
g_mp_friendlyfire = get_cvar_pointer("mp_friendlyfire")
if( g_mp_friendlyfire )
{
register_clcmd("say ff", "sayFFStatus", 0, "- display friendly fire status") register_clcmd("say ff", "sayFFStatus", 0, "- display friendly fire status")
register_cvar("amx_nextmap", "", FCVAR_SERVER|FCVAR_EXTDLL|FCVAR_SPONLY) }
new szString[32], szString2[32], szString3[8] get_mapname(g_currentMap, charsmax(g_currentMap))
get_localinfo("lastmapcycle", szString, 31) new szString[40], szString2[32], szString3[8]
parse(szString, szString2, 31, szString3, 7)
g_pos = str_to_num(szString3) get_localinfo("lastmapcycle", szString, charsmax(szString))
get_cvar_string("mapcyclefile", g_mapCycle, 31) parse(szString, szString2, charsmax(szString2), szString3, charsmax(szString3))
get_cvar_string("mapcyclefile", g_mapCycle, charsmax(g_mapCycle))
if (!equal(g_mapCycle, szString2)) if (!equal(g_mapCycle, szString2))
g_pos = 0 // mapcyclefile has been changed - go from first g_pos = 0 // mapcyclefile has been changed - go from first
else
g_pos = str_to_num(szString3)
readMapCycle(g_mapCycle, g_nextMap, 31) readMapCycle(g_mapCycle, g_nextMap, charsmax(g_nextMap))
set_cvar_string("amx_nextmap", g_nextMap) set_pcvar_string(g_amx_nextmap, g_nextMap)
format(szString3, 31, "%s %d", g_mapCycle, g_pos) // save lastmapcycle settings formatex(szString, charsmax(szString), "%s %d", g_mapCycle, g_pos) // save lastmapcycle settings
set_localinfo("lastmapcycle", szString3) set_localinfo("lastmapcycle", szString)
} }
getNextMapName(szArg[], iMax) getNextMapName(szArg[], iMax)
{ {
new len = get_cvar_string("amx_nextmap", szArg, iMax) new len = get_pcvar_string(g_amx_nextmap, szArg, iMax)
if (ValidMap(szArg)) return len if (ValidMap(szArg)) return len
len = copy(szArg, iMax, g_nextMap) len = copy(szArg, iMax, g_nextMap)
set_cvar_string("amx_nextmap", g_nextMap) set_pcvar_string(g_amx_nextmap, g_nextMap)
return len return len
} }
@ -84,36 +99,33 @@ public sayNextMap()
{ {
new name[32] new name[32]
getNextMapName(name, 31) getNextMapName(name, charsmax(name))
client_print(0, print_chat, "%L %s", LANG_PLAYER, "NEXT_MAP", name) client_print(0, print_chat, "%L %s", LANG_PLAYER, "NEXT_MAP", name)
} }
public sayCurrentMap() public sayCurrentMap()
{ {
new mapname[32] client_print(0, print_chat, "%L: %s", LANG_PLAYER, "PLAYED_MAP", g_currentMap)
get_mapname(mapname, 31)
client_print(0, print_chat, "%L: %s", LANG_PLAYER, "PLAYED_MAP", mapname)
} }
public sayFFStatus() public sayFFStatus()
{ {
client_print(0, print_chat, "%L: %L", LANG_PLAYER, "FRIEND_FIRE", LANG_PLAYER, get_cvar_num("mp_friendlyfire") ? "ON" : "OFF") client_print(0, print_chat, "%L: %L", LANG_PLAYER, "FRIEND_FIRE", LANG_PLAYER, get_pcvar_num(g_mp_friendlyfire) ? "ON" : "OFF")
} }
public delayedChange(param[]) public delayedChange(param[])
{ {
set_cvar_float("mp_chattime", get_cvar_float("mp_chattime") - 2.0) set_pcvar_float(g_mp_chattime, get_pcvar_float(g_mp_chattime) - 2.0)
server_cmd("changelevel %s", param) server_cmd("changelevel %s", param)
} }
public changeMap() public changeMap()
{ {
new string[32] new string[32]
new Float:chattime = get_cvar_float("mp_chattime") new Float:chattime = get_pcvar_float(g_mp_chattime)
set_cvar_float("mp_chattime", chattime + 2.0) // make sure mp_chattime is long set_pcvar_float(g_mp_chattime, chattime + 2.0) // make sure mp_chattime is long
new len = getNextMapName(string, 31) + 1 new len = getNextMapName(string, charsmax(string)) + 1
set_task(chattime, "delayedChange", 0, string, len) // change with 1.5 sec. delay set_task(chattime, "delayedChange", 0, string, len) // change with 1.5 sec. delay
} }
@ -157,12 +169,12 @@ readMapCycle(szFileName[], szNext[], iNext)
if (file_exists(szFileName)) if (file_exists(szFileName))
{ {
while (read_file(szFileName, i++, szBuffer, 31, b)) while (read_file(szFileName, i++, szBuffer, charsmax(szBuffer), b))
{ {
if (!isalnum(szBuffer[0]) || !ValidMap(szBuffer)) continue if (!isalnum(szBuffer[0]) || !ValidMap(szBuffer)) continue
if (!iMaps) if (!iMaps)
copy(szFirst, 31, szBuffer) copy(szFirst, charsmax(szFirst), szBuffer)
if (++iMaps > g_pos) if (++iMaps > g_pos)
{ {
@ -176,9 +188,9 @@ readMapCycle(szFileName[], szNext[], iNext)
if (!iMaps) if (!iMaps)
{ {
log_amx(g_warning, szFileName) log_amx(g_warning, szFileName)
get_mapname(szFirst, 31) copy(szNext, iNext, g_currentMap)
} }
else
copy(szNext, iNext, szFirst) copy(szNext, iNext, szFirst)
g_pos = 1 g_pos = 1
} }
@ -188,33 +200,31 @@ readMapCycle(szFileName[], szNext[], iNext)
readMapCycle(szFileName[], szNext[], iNext) readMapCycle(szFileName[], szNext[], iNext)
{ {
new b, i = 0, iMaps = 0 new b, i = 0, iMaps = 0
new szBuffer[32], szFirst[32], szCurrent[32] new szBuffer[32], szFirst[32]
get_mapname(szCurrent, 31)
new a = g_pos new a = g_pos
if (file_exists(szFileName)) if (file_exists(szFileName))
{ {
while (read_file(szFileName, i++, szBuffer, 31, b)) while (read_file(szFileName, i++, szBuffer, charsmax(szBuffer), b))
{ {
if (!isalnum(szBuffer[0]) || !ValidMap(szBuffer)) continue if (!isalnum(szBuffer[0]) || !ValidMap(szBuffer)) continue
if (!iMaps) if (!iMaps)
{ {
iMaps = 1 iMaps = 1
copy(szFirst, 31, szBuffer) copy(szFirst, charsmax(szFirst), szBuffer)
} }
if (iMaps == 1) if (iMaps == 1)
{ {
if (equali(szCurrent, szBuffer)) if (equali(g_currentMap, szBuffer))
{ {
if (a-- == 0) if (a-- == 0)
iMaps = 2 iMaps = 2
} }
} else { } else {
if (equali(szCurrent, szBuffer)) if (equali(g_currentMap, szBuffer))
++g_pos ++g_pos
else else
g_pos = 0 g_pos = 0
@ -228,7 +238,7 @@ readMapCycle(szFileName[], szNext[], iNext)
if (!iMaps) if (!iMaps)
{ {
log_amx(g_warning, szFileName) log_amx(g_warning, szFileName)
copy(szNext, iNext, szCurrent) copy(szNext, iNext, g_currentMap)
} }
else else
copy(szNext, iNext, szFirst) copy(szNext, iNext, szFirst)