Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

116 lines
5.8 KiB

  1. //========= Copyright Valve Corporation, All rights reserved. ============//
  2. //
  3. // Purpose:
  4. //
  5. // $Workfile: $
  6. // $Date: $
  7. //
  8. //-----------------------------------------------------------------------------
  9. // $NoKeywords: $
  10. //===========================================================================//
  11. #ifndef ICONVAR_H
  12. #define ICONVAR_H
  13. #if _WIN32
  14. #pragma once
  15. #endif
  16. #include "tier0/dbg.h"
  17. #include "tier0/platform.h"
  18. #include "tier1/strtools.h"
  19. //-----------------------------------------------------------------------------
  20. // Forward declarations
  21. //-----------------------------------------------------------------------------
  22. class IConVar;
  23. class CCommand;
  24. //-----------------------------------------------------------------------------
  25. // ConVar flags
  26. //-----------------------------------------------------------------------------
  27. // The default, no flags at all
  28. #define FCVAR_NONE 0
  29. // Command to ConVars and ConCommands
  30. // ConVar Systems
  31. #define FCVAR_UNREGISTERED (1<<0) // If this is set, don't add to linked list, etc.
  32. #define FCVAR_DEVELOPMENTONLY (1<<1) // Hidden in released products. Flag is removed automatically if ALLOW_DEVELOPMENT_CVARS is defined.
  33. #define FCVAR_GAMEDLL (1<<2) // defined by the game DLL
  34. #define FCVAR_CLIENTDLL (1<<3) // defined by the client DLL
  35. #define FCVAR_HIDDEN (1<<4) // Hidden. Doesn't appear in find or autocomplete. Like DEVELOPMENTONLY, but can't be compiled out.
  36. // ConVar only
  37. #define FCVAR_PROTECTED (1<<5) // It's a server cvar, but we don't send the data since it's a password, etc. Sends 1 if it's not bland/zero, 0 otherwise as value
  38. #define FCVAR_SPONLY (1<<6) // This cvar cannot be changed by clients connected to a multiplayer server.
  39. #define FCVAR_ARCHIVE (1<<7) // set to cause it to be saved to vars.rc
  40. #define FCVAR_NOTIFY (1<<8) // notifies players when changed
  41. #define FCVAR_USERINFO (1<<9) // changes the client's info string
  42. #define FCVAR_CHEAT (1<<14) // Only useable in singleplayer / debug / multiplayer & sv_cheats
  43. #define FCVAR_PRINTABLEONLY (1<<10) // This cvar's string cannot contain unprintable characters ( e.g., used for player name etc ).
  44. #define FCVAR_UNLOGGED (1<<11) // If this is a FCVAR_SERVER, don't log changes to the log file / console if we are creating a log
  45. #define FCVAR_NEVER_AS_STRING (1<<12) // never try to print that cvar
  46. // It's a ConVar that's shared between the client and the server.
  47. // At signon, the values of all such ConVars are sent from the server to the client (skipped for local
  48. // client, of course )
  49. // If a change is requested it must come from the console (i.e., no remote client changes)
  50. // If a value is changed while a server is active, it's replicated to all connected clients
  51. #define FCVAR_REPLICATED (1<<13) // server setting enforced on clients, TODO rename to FCAR_SERVER at some time
  52. #define FCVAR_DEMO (1<<16) // record this cvar when starting a demo file
  53. #define FCVAR_DONTRECORD (1<<17) // don't record these command in demofiles
  54. #define FCVAR_RELOAD_MATERIALS (1<<20) // If this cvar changes, it forces a material reload
  55. #define FCVAR_RELOAD_TEXTURES (1<<21) // If this cvar changes, if forces a texture reload
  56. #define FCVAR_NOT_CONNECTED (1<<22) // cvar cannot be changed by a client that is connected to a server
  57. #define FCVAR_MATERIAL_SYSTEM_THREAD (1<<23) // Indicates this cvar is read from the material system thread
  58. #define FCVAR_ARCHIVE_XBOX (1<<24) // cvar written to config.cfg on the Xbox
  59. #define FCVAR_ACCESSIBLE_FROM_THREADS (1<<25) // used as a debugging tool necessary to check material system thread convars
  60. #define FCVAR_SERVER_CAN_EXECUTE (1<<28)// the server is allowed to execute this command on clients via ClientCommand/NET_StringCmd/CBaseClientState::ProcessStringCmd.
  61. #define FCVAR_SERVER_CANNOT_QUERY (1<<29)// If this is set, then the server is not allowed to query this cvar's value (via IServerPluginHelpers::StartQueryCvarValue).
  62. #define FCVAR_CLIENTCMD_CAN_EXECUTE (1<<30) // IVEngineClient::ClientCmd is allowed to execute this command.
  63. // Note: IVEngineClient::ClientCmd_Unrestricted can run any client command.
  64. #define FCVAR_EXEC_DESPITE_DEFAULT (1<<31) // -default causes a lot of commands to be ignored (but still be recorded as though they had run).
  65. // This causes them to be executed anyways.
  66. #define FCVAR_INTERNAL_USE (1<<15) // This var isn't archived, but is exposed to players--and its use is allowed in competitive play.
  67. #define FCVAR_ALLOWED_IN_COMPETITIVE (1<<18) // This convar can be changed in competitive (strict) settings mode even though it is not archived. Meant for one-offs like cl_showfps that are not user facing settings but are benign
  68. // #define FCVAR_AVAILABLE (1<<19)
  69. // #define FCVAR_AVAILABLE (1<<26)
  70. // #define FCVAR_AVAILABLE (1<<27)
  71. #define FCVAR_MATERIAL_THREAD_MASK ( FCVAR_RELOAD_MATERIALS | FCVAR_RELOAD_TEXTURES | FCVAR_MATERIAL_SYSTEM_THREAD )
  72. //-----------------------------------------------------------------------------
  73. // Called when a ConVar changes value
  74. // NOTE: For FCVAR_NEVER_AS_STRING ConVars, pOldValue == NULL
  75. //-----------------------------------------------------------------------------
  76. typedef void ( *FnChangeCallback_t )( IConVar *var, const char *pOldValue, float flOldValue );
  77. //-----------------------------------------------------------------------------
  78. // Abstract interface for ConVars
  79. //-----------------------------------------------------------------------------
  80. abstract_class IConVar
  81. {
  82. public:
  83. // Value set
  84. virtual void SetValue( const char *pValue ) = 0;
  85. virtual void SetValue( float flValue ) = 0;
  86. virtual void SetValue( int nValue ) = 0;
  87. // Return name of command
  88. virtual const char *GetName( void ) const = 0;
  89. // Accessors.. not as efficient as using GetState()/GetInfo()
  90. // if you call these methods multiple times on the same IConVar
  91. virtual bool IsFlagSet( int nFlag ) const = 0;
  92. };
  93. #endif // ICONVAR_H