2004-02-21 19:36:35 +00:00
|
|
|
/* AMX Mod X
|
|
|
|
* NextMap Plugin
|
2004-01-31 20:56:22 +00:00
|
|
|
*
|
2004-02-21 19:36:35 +00:00
|
|
|
* by the AMX Mod X Development Team
|
|
|
|
* originally developed by OLO
|
2004-01-31 20:56:22 +00:00
|
|
|
*
|
2004-02-21 19:36:35 +00:00
|
|
|
* This file is part of AMX Mod X.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation; either version 2 of the License, or (at
|
|
|
|
* your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*
|
|
|
|
* In addition, as a special exception, the author gives permission to
|
|
|
|
* link the code of this program with the Half-Life Game Engine ("HL
|
|
|
|
* Engine") and Modified Game Libraries ("MODs") developed by Valve,
|
|
|
|
* L.L.C ("Valve"). You must obey the GNU General Public License in all
|
|
|
|
* respects for all of the code used other than the HL Engine and MODs
|
|
|
|
* from Valve. If you modify this file, you may extend this exception
|
|
|
|
* to your version of the file, but you are not obligated to do so. If
|
|
|
|
* you do not wish to do so, delete this exception statement from your
|
|
|
|
* version.
|
2004-01-31 20:56:22 +00:00
|
|
|
*/
|
|
|
|
|
2004-03-05 19:35:38 +00:00
|
|
|
#include <amxmodx>
|
2004-01-31 20:56:22 +00:00
|
|
|
|
|
|
|
// WARNING: If you comment this line make sure
|
|
|
|
// that in your mapcycle file maps don't repeat.
|
|
|
|
// However the same map in a row is still valid.
|
|
|
|
#define OBEY_MAPCYCLE
|
|
|
|
|
|
|
|
new g_nextMap[32]
|
|
|
|
new g_mapCycle[32]
|
|
|
|
new g_pos
|
2013-07-31 18:18:55 +00:00
|
|
|
new g_currentMap[32]
|
|
|
|
|
|
|
|
// pcvars
|
|
|
|
new g_mp_friendlyfire, g_mp_chattime
|
|
|
|
new g_amx_nextmap
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
public plugin_init()
|
|
|
|
{
|
|
|
|
register_plugin("NextMap", AMXX_VERSION_STR, "AMXX Dev Team")
|
|
|
|
register_dictionary("nextmap.txt")
|
|
|
|
register_event("30", "changeMap", "a")
|
|
|
|
register_clcmd("say nextmap", "sayNextMap", 0, "- displays nextmap")
|
2006-01-07 03:26:50 +00:00
|
|
|
register_clcmd("say currentmap", "sayCurrentMap", 0, "- display current map")
|
2005-09-12 21:06:24 +00:00
|
|
|
|
2013-07-31 18:18:55 +00:00
|
|
|
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")
|
|
|
|
}
|
|
|
|
|
|
|
|
get_mapname(g_currentMap, charsmax(g_currentMap))
|
|
|
|
|
|
|
|
new szString[40], szString2[32], szString3[8]
|
|
|
|
|
|
|
|
get_localinfo("lastmapcycle", szString, charsmax(szString))
|
|
|
|
parse(szString, szString2, charsmax(szString2), szString3, charsmax(szString3))
|
2005-09-12 21:06:24 +00:00
|
|
|
|
2013-07-31 18:18:55 +00:00
|
|
|
get_cvar_string("mapcyclefile", g_mapCycle, charsmax(g_mapCycle))
|
2005-09-12 21:06:24 +00:00
|
|
|
|
|
|
|
if (!equal(g_mapCycle, szString2))
|
|
|
|
g_pos = 0 // mapcyclefile has been changed - go from first
|
2013-07-31 18:18:55 +00:00
|
|
|
else
|
|
|
|
g_pos = str_to_num(szString3)
|
2005-09-12 21:06:24 +00:00
|
|
|
|
2013-07-31 18:18:55 +00:00
|
|
|
readMapCycle(g_mapCycle, g_nextMap, charsmax(g_nextMap))
|
|
|
|
set_pcvar_string(g_amx_nextmap, g_nextMap)
|
|
|
|
formatex(szString, charsmax(szString), "%s %d", g_mapCycle, g_pos) // save lastmapcycle settings
|
|
|
|
set_localinfo("lastmapcycle", szString)
|
2004-01-31 20:56:22 +00:00
|
|
|
}
|
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
getNextMapName(szArg[], iMax)
|
|
|
|
{
|
2013-07-31 18:18:55 +00:00
|
|
|
new len = get_pcvar_string(g_amx_nextmap, szArg, iMax)
|
2005-09-12 21:06:24 +00:00
|
|
|
|
2007-05-20 15:03:26 +00:00
|
|
|
if (ValidMap(szArg)) return len
|
2005-09-12 21:06:24 +00:00
|
|
|
len = copy(szArg, iMax, g_nextMap)
|
2013-07-31 18:18:55 +00:00
|
|
|
set_pcvar_string(g_amx_nextmap, g_nextMap)
|
2005-09-12 21:06:24 +00:00
|
|
|
|
|
|
|
return len
|
2004-01-31 20:56:22 +00:00
|
|
|
}
|
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
public sayNextMap()
|
|
|
|
{
|
|
|
|
new name[32]
|
|
|
|
|
2013-07-31 18:18:55 +00:00
|
|
|
getNextMapName(name, charsmax(name))
|
2005-09-12 21:06:24 +00:00
|
|
|
client_print(0, print_chat, "%L %s", LANG_PLAYER, "NEXT_MAP", name)
|
2004-01-31 20:56:22 +00:00
|
|
|
}
|
|
|
|
|
2006-01-07 03:26:50 +00:00
|
|
|
public sayCurrentMap()
|
|
|
|
{
|
2013-07-31 18:18:55 +00:00
|
|
|
client_print(0, print_chat, "%L: %s", LANG_PLAYER, "PLAYED_MAP", g_currentMap)
|
2006-01-07 03:26:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public sayFFStatus()
|
|
|
|
{
|
2013-07-31 18:18:55 +00:00
|
|
|
client_print(0, print_chat, "%L: %L", LANG_PLAYER, "FRIEND_FIRE", LANG_PLAYER, get_pcvar_num(g_mp_friendlyfire) ? "ON" : "OFF")
|
2006-01-07 03:26:50 +00:00
|
|
|
}
|
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
public delayedChange(param[])
|
|
|
|
{
|
2014-03-20 18:05:41 +00:00
|
|
|
if (g_mp_chattime) {
|
|
|
|
set_pcvar_float(g_mp_chattime, get_pcvar_float(g_mp_chattime) - 2.0)
|
|
|
|
}
|
2005-09-12 21:06:24 +00:00
|
|
|
server_cmd("changelevel %s", param)
|
2004-02-23 20:03:40 +00:00
|
|
|
}
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
public changeMap()
|
|
|
|
{
|
|
|
|
new string[32]
|
2014-03-20 18:05:41 +00:00
|
|
|
new Float:chattime = g_mp_chattime ? get_pcvar_float(g_mp_chattime) : 10.0; // mp_chattime defaults to 10 in other mods
|
2005-09-12 21:06:24 +00:00
|
|
|
|
2014-03-20 18:05:41 +00:00
|
|
|
if (g_mp_chattime) {
|
|
|
|
set_pcvar_float(g_mp_chattime, chattime + 2.0) // make sure mp_chattime is long
|
|
|
|
}
|
2013-07-31 18:18:55 +00:00
|
|
|
new len = getNextMapName(string, charsmax(string)) + 1
|
2005-09-12 21:06:24 +00:00
|
|
|
set_task(chattime, "delayedChange", 0, string, len) // change with 1.5 sec. delay
|
2004-01-31 20:56:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
new g_warning[] = "WARNING: Couldn't find a valid map or the file doesn't exist (file ^"%s^")"
|
|
|
|
|
2007-05-20 15:03:26 +00:00
|
|
|
stock bool:ValidMap(mapname[])
|
|
|
|
{
|
|
|
|
if ( is_map_valid(mapname) )
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
// If the is_map_valid check failed, check the end of the string
|
|
|
|
new len = strlen(mapname) - 4;
|
|
|
|
|
|
|
|
// The mapname was too short to possibly house the .bsp extension
|
|
|
|
if (len < 0)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if ( equali(mapname[len], ".bsp") )
|
|
|
|
{
|
|
|
|
// If the ending was .bsp, then cut it off.
|
|
|
|
// the string is byref'ed, so this copies back to the loaded text.
|
|
|
|
mapname[len] = '^0';
|
|
|
|
|
|
|
|
// recheck
|
|
|
|
if ( is_map_valid(mapname) )
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2004-01-31 20:56:22 +00:00
|
|
|
#if defined OBEY_MAPCYCLE
|
2005-09-12 21:06:24 +00:00
|
|
|
readMapCycle(szFileName[], szNext[], iNext)
|
|
|
|
{
|
|
|
|
new b, i = 0, iMaps = 0
|
|
|
|
new szBuffer[32], szFirst[32]
|
|
|
|
|
|
|
|
if (file_exists(szFileName))
|
|
|
|
{
|
2013-07-31 18:18:55 +00:00
|
|
|
while (read_file(szFileName, i++, szBuffer, charsmax(szBuffer), b))
|
2005-09-12 21:06:24 +00:00
|
|
|
{
|
2007-05-20 15:03:26 +00:00
|
|
|
if (!isalnum(szBuffer[0]) || !ValidMap(szBuffer)) continue
|
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
if (!iMaps)
|
2013-07-31 18:18:55 +00:00
|
|
|
copy(szFirst, charsmax(szFirst), szBuffer)
|
2005-09-12 21:06:24 +00:00
|
|
|
|
|
|
|
if (++iMaps > g_pos)
|
|
|
|
{
|
|
|
|
copy(szNext, iNext, szBuffer)
|
|
|
|
g_pos = iMaps
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!iMaps)
|
|
|
|
{
|
|
|
|
log_amx(g_warning, szFileName)
|
2013-07-31 18:18:55 +00:00
|
|
|
copy(szNext, iNext, g_currentMap)
|
2005-09-12 21:06:24 +00:00
|
|
|
}
|
2013-07-31 18:18:55 +00:00
|
|
|
else
|
|
|
|
copy(szNext, iNext, szFirst)
|
2005-09-12 21:06:24 +00:00
|
|
|
g_pos = 1
|
2004-01-31 20:56:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
2005-09-12 21:06:24 +00:00
|
|
|
readMapCycle(szFileName[], szNext[], iNext)
|
|
|
|
{
|
|
|
|
new b, i = 0, iMaps = 0
|
2013-07-31 18:18:55 +00:00
|
|
|
new szBuffer[32], szFirst[32]
|
2005-09-12 21:06:24 +00:00
|
|
|
|
|
|
|
new a = g_pos
|
|
|
|
|
|
|
|
if (file_exists(szFileName))
|
|
|
|
{
|
2013-07-31 18:18:55 +00:00
|
|
|
while (read_file(szFileName, i++, szBuffer, charsmax(szBuffer), b))
|
2005-09-12 21:06:24 +00:00
|
|
|
{
|
2007-05-20 15:03:26 +00:00
|
|
|
if (!isalnum(szBuffer[0]) || !ValidMap(szBuffer)) continue
|
2005-09-12 21:06:24 +00:00
|
|
|
|
|
|
|
if (!iMaps)
|
|
|
|
{
|
|
|
|
iMaps = 1
|
2013-07-31 18:18:55 +00:00
|
|
|
copy(szFirst, charsmax(szFirst), szBuffer)
|
2005-09-12 21:06:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (iMaps == 1)
|
|
|
|
{
|
2013-07-31 18:18:55 +00:00
|
|
|
if (equali(g_currentMap, szBuffer))
|
2005-09-12 21:06:24 +00:00
|
|
|
{
|
|
|
|
if (a-- == 0)
|
|
|
|
iMaps = 2
|
|
|
|
}
|
|
|
|
} else {
|
2013-07-31 18:18:55 +00:00
|
|
|
if (equali(g_currentMap, szBuffer))
|
2005-09-12 21:06:24 +00:00
|
|
|
++g_pos
|
|
|
|
else
|
|
|
|
g_pos = 0
|
|
|
|
|
|
|
|
copy(szNext, iNext, szBuffer)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!iMaps)
|
|
|
|
{
|
|
|
|
log_amx(g_warning, szFileName)
|
2013-07-31 18:18:55 +00:00
|
|
|
copy(szNext, iNext, g_currentMap)
|
2005-09-12 21:06:24 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
copy(szNext, iNext, szFirst)
|
|
|
|
|
|
|
|
g_pos = 0
|
2004-01-31 20:56:22 +00:00
|
|
|
}
|
2005-09-12 21:06:24 +00:00
|
|
|
#endif
|