2012-01-28 02:16:49 +01:00
|
|
|
/**
|
|
|
|
* vim: set ts=4 :
|
|
|
|
* =============================================================================
|
|
|
|
* SourceMod (C)2004-2011 AlliedModders LLC. All rights reserved.
|
|
|
|
* =============================================================================
|
|
|
|
*
|
|
|
|
* This file is part of the SourceMod/SourcePawn SDK.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU General Public License, version 3.0, as published by the
|
|
|
|
* Free Software Foundation.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
2012-01-28 02:16:49 +01:00
|
|
|
* 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, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* As a special exception, AlliedModders LLC gives you permission to link the
|
|
|
|
* code of this program (as well as its derivative works) to "Half-Life 2," the
|
|
|
|
* "Source Engine," the "SourcePawn JIT," and any Game MODs that run on software
|
|
|
|
* by the Valve Corporation. You must obey the GNU General Public License in
|
|
|
|
* all respects for all other code used. Additionally, AlliedModders LLC grants
|
|
|
|
* this exception to all derivative works. AlliedModders LLC defines further
|
|
|
|
* exceptions, found in LICENSE.txt (as of this writing, version JULY-31-2007),
|
|
|
|
* or <http://www.sourcemod.net/license.php>.
|
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if defined _sdktools_gamerules_included
|
2019-09-27 13:14:44 +02:00
|
|
|
#endinput
|
2012-01-28 02:16:49 +01:00
|
|
|
#endif
|
|
|
|
#define _sdktools_gamerules_included
|
|
|
|
|
|
|
|
enum RoundState {
|
|
|
|
// initialize the game, create teams
|
|
|
|
RoundState_Init,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Before players have joined the game. Periodically checks to see if enough players are ready
|
|
|
|
//to start a game. Also reverts to this when there are no active players
|
|
|
|
RoundState_Pregame,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//The game is about to start, wait a bit and spawn everyone
|
|
|
|
RoundState_StartGame,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//All players are respawned, frozen in place
|
|
|
|
RoundState_Preround,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Round is on, playing normally
|
|
|
|
RoundState_RoundRunning,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Someone has won the round
|
|
|
|
RoundState_TeamWin,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Noone has won, manually restart the game, reset scores
|
|
|
|
RoundState_Restart,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Noone has won, restart the game
|
|
|
|
RoundState_Stalemate,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Game is over, showing the scoreboard etc
|
|
|
|
RoundState_GameOver,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2012-01-28 02:16:49 +01:00
|
|
|
//Game is over, doing bonus round stuff
|
|
|
|
RoundState_Bonus,
|
2019-09-27 13:14:44 +02:00
|
|
|
|
2014-07-30 11:03:42 +02:00
|
|
|
//Between rounds
|
2019-09-27 13:14:44 +02:00
|
|
|
RoundState_BetweenRounds
|
2012-01-28 02:16:49 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves an integer value from a property of the gamerules entity.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property name.
|
|
|
|
* @param size Number of bytes to read (valid values are 1, 2, or 4).
|
|
|
|
* This value is auto-detected, and the size parameter is
|
|
|
|
* only used as a fallback in case detection fails.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @return Value at the given property offset.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native int GameRules_GetProp(const char[] prop, int size=4, int element=0);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets an integer value for a property of the gamerules entity.
|
|
|
|
*
|
2019-09-27 13:14:44 +02:00
|
|
|
* @param prop Property name.
|
|
|
|
* @param value Value to set.
|
|
|
|
* @param size Number of bytes to write (valid values are 1, 2, or 4).
|
|
|
|
* This value is auto-detected, and the size parameter is
|
|
|
|
* only used as a fallback in case detection fails.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @param changeState This parameter is ignored.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native void GameRules_SetProp(const char[] prop, any value, int size=4, int element=0, bool changeState=false);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a float value from a property of the gamerules entity.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property name.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @return Value at the given property offset.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native float GameRules_GetPropFloat(const char[] prop, int element=0);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a float value for a property of the gamerules entity.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property name.
|
|
|
|
* @param value Value to set.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @param changeState This parameter is ignored.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native void GameRules_SetPropFloat(const char[] prop, float value, int element=0, bool changeState=false);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a entity index from a property of the gamerules entity.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property name.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @return Entity index at the given property.
|
|
|
|
* If there is no entity, or the entity is not valid,
|
|
|
|
* then -1 is returned.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native int GameRules_GetPropEnt(const char[] prop, int element=0);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets an entity index for a property of the gamerules entity.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property name.
|
|
|
|
* @param other Entity index to set, or -1 to unset.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @param changeState This parameter is ignored.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native void GameRules_SetPropEnt(const char[] prop, int other, int element=0, bool changeState=false);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a vector of floats from the gamerules entity, given a named network property.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property name.
|
|
|
|
* @param vec Vector buffer to store data in.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native void GameRules_GetPropVector(const char[] prop, float vec[3], int element=0);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a vector of floats in the gamerules entity, given a named network property.
|
|
|
|
*
|
2019-09-27 13:14:44 +02:00
|
|
|
* @param prop Property name.
|
|
|
|
* @param vec Vector to set.
|
|
|
|
* @param element Element # (starting from 0) if property is an array.
|
|
|
|
* @param changeState This parameter is ignored.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native void GameRules_SetPropVector(const char[] prop, const float vec[3], int element=0, bool changeState=false);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a gamerules property as a string.
|
2019-09-27 13:14:44 +02:00
|
|
|
*
|
|
|
|
* @param prop Property to use.
|
|
|
|
* @param buffer Destination string buffer.
|
|
|
|
* @param maxlen Maximum length of output string buffer.
|
|
|
|
* @return Number of non-null bytes written.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native int GameRules_GetPropString(const char[] prop, char[] buffer, int maxlen);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a gamerules property as a string.
|
|
|
|
*
|
2019-09-27 13:14:44 +02:00
|
|
|
* @param prop Property to use.
|
|
|
|
* @param buffer String to set.
|
|
|
|
* @param changeState This parameter is ignored.
|
|
|
|
* @return Number of non-null bytes written.
|
|
|
|
* @error Not supported.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
native int GameRules_SetPropString(const char[] prop, const char[] buffer, bool changeState=false);
|
2012-01-28 02:16:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the current round state.
|
|
|
|
*
|
2019-09-27 13:14:44 +02:00
|
|
|
* @return Round state.
|
|
|
|
* @error Game doesn't support round state.
|
2012-01-28 02:16:49 +01:00
|
|
|
*/
|
2016-08-23 15:34:00 +02:00
|
|
|
stock RoundState GameRules_GetRoundState()
|
2012-01-28 02:16:49 +01:00
|
|
|
{
|
2016-08-23 15:34:00 +02:00
|
|
|
return view_as<RoundState>(GameRules_GetProp("m_iRoundState"));
|
2012-01-28 02:16:49 +01:00
|
|
|
}
|