mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2024-12-26 06:45:37 +03:00
Fix last mapcycle issue and apply general optimizations in nextmap plugin (bug 5817, r=arkshine)
This commit is contained in:
parent
30394243ff
commit
9b5c7afc00
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user