List of CS:GO Script Functions: Difference between revisions
| No edit summary | No edit summary | ||
| (85 intermediate revisions by 31 users not shown) | |||
| Line 1: | Line 1: | ||
| {{LanguageBar}} | |||
| {{Delisted|csgo}} | |||
| {{toc-right}} | {{toc-right}} | ||
| {{sq}} This list contains the engine-related Squirrel classes, functions and variables available for [[VScript]] in {{csgo|4}}. The official documentation can be printed in the console by setting <code>developer</code> to non-zero, loading a map, and executing <code>script_help</code>. | |||
| {{sq}} This list contains  | |||
| == Variables == | |||
| {| class="standard-table" | |||
| !Instance | |||
| !Type | |||
| !Description | |||
| |- | |||
| |<code>Entities</code> | |||
| |<code>[[#CEntities|CEntities]]</code> | |||
| |Provides access to spawned entities in the server. | |||
| |- | |||
| |} | |||
| == Constants == | |||
| {| class="standard-table" | |||
| !Instance | |||
| !Type | |||
| !Value | |||
| |- | |||
| |<code>_charsize_</code> | |||
| |integer | |||
| | 1 | |||
| |- | |||
| |<code>_floatsize_</code> | |||
| |integer | |||
| | 4 | |||
| |- | |||
| |<code>_intsize_</code> | |||
| |integer | |||
| | 4 | |||
| |- | |||
| |<code>_version_</code> | |||
| |string | |||
| | "Squirrel 2.2.3 stable" | |||
| |- | |||
| |<code>RAND_MAX</code> | |||
| |integer | |||
| | 32767 | |||
| |- | |||
| |<code>PI</code> | |||
| |float | |||
| | 3.14159 | |||
| |} | |||
| {{note|These are simply global variables, namely table slots in the root table. They can be changed at will, for example <code>::PI {{=}} 3</code>.}} | |||
| == Classes == | |||
| === CBaseEntity === | |||
| This is a script handle class for entities. All entities spawned have a script handle using this or one of its subclasses.  | |||
| All script handles in-game are accessible from [[#CEntities|Entities]]. Entity scripts can use <code>self</code> to access their own script handle. <code>activator</code> and <code>caller</code> variables can be accessed on function calls. | |||
| =  | ==== Methods ==== | ||
| {| class="standard-table" style="width:  | {| class="standard-table" style="width: 75%;" | ||
| ! Function | ! Function | ||
| ! Signature | ! Signature | ||
| ! Description | ! Description | ||
| |- | |||
| | <code>__KeyValueFromInt</code> | |||
| | <code>bool __KeyValueFromInt(string ''key'', int ''value'')</code> | |||
| | Sets entity [[keyvalue]] from an integer. | |||
| |- | |||
| | <code>__KeyValueFromFloat</code> | |||
| | <code>bool __KeyValueFromFloat(string ''key'', float ''value'')</code> | |||
| | Sets entity keyvalue from a float. | |||
| |- | |||
| | <code>__KeyValueFromString</code> | |||
| | <code>bool __KeyValueFromString(string ''key'', string ''value'')</code> | |||
| | Sets entity keyvalue from a string. | |||
| |- | |||
| | <code>__KeyValueFromVector</code> | |||
| | <code>bool __KeyValueFromVector(string ''key'', Vector ''value'')</code> | |||
| | Sets entity keyvalue from a [[#Vector|Vector]]. | |||
| |- | |- | ||
| | <code>ConnectOutput</code> | | <code>ConnectOutput</code> | ||
| | <code>void  | | <code>void ConnectOutput(string ''output'', string ''function'')</code> | ||
| | Adds an I/O connection that will call the named function when the specified output fires | | Adds an [[I/O]] connection that will call the named function when the specified output fires.  | ||
| |- | |- | ||
| | <code>DisconnectOutput</code> | | <code>DisconnectOutput</code> | ||
| | <code>void  | | <code>void DisconnectOutput(string ''output'', string ''function'')</code> | ||
| | Removes a connected script function from an I/O event. | | Removes a connected script function from an I/O event. | ||
| |- | |||
| | <code>Destroy</code> | |||
| | <code>void Destroy()</code> | |||
| | Kills the entity. | |||
| |- | |- | ||
| | <code>EmitSound</code> | | <code>EmitSound</code> | ||
| | <code>void  | | <code>void EmitSound(string ''soundname'')</code> | ||
| | Plays a sound from this entity. | | Plays a sound from this entity. | ||
| |- | |- | ||
| | <code>entindex</code> | | <code>entindex</code> | ||
| | <code>int  | | <code>int entindex()</code> | ||
| | Returns the entity index. | |||
| |- | |- | ||
| | <code>EyePosition</code> | | <code>EyePosition</code> | ||
| | <code>Vector  | | <code>Vector EyePosition()</code> | ||
| | Get vector to eye position - absolute  | | Get vector to the eye position - absolute coordinates. | ||
| |- | |- | ||
| | <code>FirstMoveChild</code> | | <code>FirstMoveChild</code> | ||
| | <code>handle  | | <code>handle FirstMoveChild()</code> | ||
| | If in hierarchy, get the first move child. | |||
| |- | |- | ||
| | <code>GetAngles</code> | | <code>GetAngles</code> | ||
| | <code>Vector  | | <code>Vector GetAngles()</code> | ||
| | Get entity pitch, yaw, roll as a  | | Get the entity local angles ([[angles|pitch, yaw, roll]]) as a Vector object. | ||
| |- | |- | ||
| | <code>GetAngularVelocity</code> | | <code>GetAngularVelocity</code> | ||
| | <code>Vector  | | <code>Vector GetAngularVelocity()</code> | ||
| | Get the local angular velocity - returns a  | | Get the local angular velocity - returns a Vector of pitch, yaw, roll. | ||
| |- | |- | ||
| | <code>GetBoundingMaxs</code> | | <code>GetBoundingMaxs</code> | ||
| | <code>Vector  | | <code>Vector GetBoundingMaxs()</code> | ||
| | Get a vector containing max bounds, centered on object | | Get a vector containing max bounds in local space. | ||
| |- | |||
| | <code>GetBoundingMaxsOriented</code> | |||
| | <code>Vector GetBoundingMaxsOriented()</code> | |||
| | Get a vector containing max bounds, centered on object, taking the object's orientation into account. | |||
| |- | |- | ||
| | <code>GetBoundingMins</code> | | <code>GetBoundingMins</code> | ||
| | <code>Vector  | | <code>Vector GetBoundingMins()</code> | ||
| | Get a vector containing min bounds, centered on object | | Get a vector containing min bounds in local space. | ||
| |- | |||
| | <code>GetBoundingMinsOriented</code> | |||
| | <code>Vector GetBoundingMinsOriented()</code> | |||
| | Get a vector containing min bounds, centered on object, taking the object's orientation into account. | |||
| |- | |- | ||
| | <code>GetCenter</code> | | <code>GetCenter</code> | ||
| | <code>Vector  | | <code>Vector GetCenter()</code> | ||
| | Get vector to center of object  | | Get vector to center of object in world space. | ||
| |- | |- | ||
| | <code>GetClassname</code> | | <code>GetClassname</code> | ||
| | <code>string  | | <code>string GetClassname()</code> | ||
| | Get entity [[classname]]. | |||
| |- | |- | ||
| | <code>GetForwardVector</code> | | <code>GetForwardVector</code> | ||
| | <code>Vector  | | <code>Vector GetForwardVector()</code> | ||
| | Get the forward vector of the entity | | Get the forward vector of the entity in world space. | ||
| |- | |- | ||
| | <code>GetHealth</code> | | <code>GetHealth</code> | ||
| | <code>int  | | <code>int GetHealth()</code> | ||
| | Returns the current [[health]]. | |||
| |- | |- | ||
| | <code>GetLeftVector</code> | | <code>GetLeftVector</code> | ||
| | <code>Vector  | | <code>Vector GetLeftVector()</code> | ||
| | Get the  | | Get the ''right'' vector of the entity in world space. | ||
| |- | |- | ||
| | <code>GetMaxHealth</code> | | <code>GetMaxHealth</code> | ||
| | <code>int  | | <code>int GetMaxHealth()</code> | ||
| | Returns the maximum health. | |||
| |- | |- | ||
| | <code>GetModelKeyValues</code> | | <code>GetModelKeyValues</code> | ||
| | <code> | | <code>CScriptKeyValues GetModelKeyValues()</code> | ||
| |  | | Returns the [[$keyvalues]] block of the entity's model as a [[#CScriptKeyValues]] object. Note that this is ''not'' the keyvalues of the entity itself. | ||
| |- | |- | ||
| | <code>GetModelName</code> | | <code>GetModelName</code> | ||
| | <code>string  | | <code>string GetModelName()</code> | ||
| | Returns the  | | Returns the value of the entity's <code>model</code> keyvalue or <code>""</code>. | ||
| |- | |- | ||
| | <code>GetMoveParent</code> | | <code>GetMoveParent</code> | ||
| | <code>handle  | | <code>handle GetMoveParent()</code> | ||
| | If in hierarchy, retrieves the entity's parent | | If in hierarchy, retrieves the entity's parent. | ||
| |- | |- | ||
| | <code>GetName</code> | | <code>GetName</code> | ||
| | <code>string  | | <code>string GetName()</code> | ||
| | Returns the [[targetname]] of the entity. | |||
| |- | |- | ||
| | <code>GetOrigin</code> | | <code>GetOrigin</code> | ||
| | <code>Vector  | | <code>Vector GetOrigin()</code> | ||
| | Returns this entity's local origin. | |||
| |- | |- | ||
| | <code>GetOwner</code> | | <code>GetOwner</code> | ||
| | <code>handle  | | <code>handle GetOwner()</code> | ||
| | Gets this entity's owner | | Gets this entity's owner. | ||
| |- | |- | ||
| | <code>GetPreTemplateName</code> | | <code>GetPreTemplateName</code> | ||
| | <code>string  | | <code>string GetPreTemplateName()</code> | ||
| | Get the entity name stripped of template unique decoration | | Get the entity name stripped of template unique decoration. This is the <code>&048</code> suffix added by templates that do not preserve the entity name. | ||
| |- | |- | ||
| | <code>GetRootMoveParent</code> | | <code>GetRootMoveParent</code> | ||
| | <code>handle  | | <code>handle GetRootMoveParent()</code> | ||
| | If in hierarchy, walks up the hierarchy to find the root parent | | If in hierarchy, walks up the hierarchy to find the root parent. | ||
| |- | |- | ||
| | <code>GetScriptId</code> | | <code>GetScriptId</code> | ||
| | <code>string  | | <code>string GetScriptId()</code> | ||
| |  | | Returns the thinkfunction keyvalue of the entity. | ||
| |- | |- | ||
| | <code>GetScriptScope</code> | | <code>GetScriptScope</code> | ||
| | <code>handle  | | <code>handle GetScriptScope()</code> | ||
| | Retrieve the  | | Retrieve the table storing the Entity Script data associated with this entity. | ||
| |- | |- | ||
| | <code>GetSoundDuration</code> | | <code>GetSoundDuration</code> | ||
| | <code>float  | | <code>float GetSoundDuration(string ''soundname'', string ''actormodel'')</code> | ||
| | Returns float duration of the sound.  | | Returns float duration of the sound. {{todo|Does this work correctly only with .wav files?}} | ||
| |- | |- | ||
| | <code>GetTeam</code> | | <code>GetTeam</code> | ||
| | <code>int  | | <code>int GetTeam()</code> | ||
| | Get the team this entity is on. | |||
| |- | |- | ||
| | <code>GetUpVector</code> | | <code>GetUpVector</code> | ||
| | <code>Vector  | | <code>Vector GetUpVector()</code> | ||
| | Get the up vector of the entity | | Get the up vector of the entity in world space. | ||
| |- | |- | ||
| | <code>GetVelocity</code> | | <code>GetVelocity</code> | ||
| | <code>Vector  | | <code>Vector GetVelocity()</code> | ||
| | Get the velocity of the entity. | |||
| |- | |- | ||
| | <code>IsValid</code> | | <code>IsValid</code> | ||
| | <code>bool IsValid()</code> | |||
| | Whether the handle belongs to a valid entity. | |||
| |- | |- | ||
| | <code>NextMovePeer</code> | | <code>NextMovePeer</code> | ||
| | <code>handle  | | <code>handle NextMovePeer()</code> | ||
| | Return the next entity in the same movement hierarchy. | |||
| |- | |||
| | <code>PrecacheModel</code> | |||
| | <code>void PrecacheModel(string ''modelname'')</code> | |||
| | Precache a model. Expensive. | |||
| |- | |||
| | <code>PrecacheScriptSound</code> | |||
| | <code>void PrecacheScriptSound(string ''soundname'')</code> | |||
| | Precache a sound. Expensive. | |||
| |- | |- | ||
| | <code>PrecacheSoundScript</code> | | <code>PrecacheSoundScript</code> | ||
| | <code>void  | | <code>void PrecacheSoundScript(string ''soundscript'')</code> | ||
| | Precache a sound for later playing. | | Precache a sound for later playing. Expensive. | ||
| |- | |- | ||
| | <code>SetAbsOrigin</code> | | <code>SetAbsOrigin</code> | ||
| | <code>void  | | <code>void SetAbsOrigin(Vector ''position'')</code> | ||
| |  | | Set absolute origin. | ||
| |- | |- | ||
| | <code>SetAngles</code> | | <code>SetAngles</code> | ||
| | <code>void  | | <code>void SetAngles(float ''pitch'', float ''yaw'', float ''roll'')</code> | ||
| | Set entity pitch, yaw, roll | | Set entity local angles ([[angles|pitch, yaw, roll]]). | ||
| |- | |- | ||
| | <code>SetAngularVelocity</code> | | <code>SetAngularVelocity</code> | ||
| | <code>void  | | <code>void SetAngularVelocity(float ''pitch'', float ''yaw'', float ''roll'')</code> | ||
| | Set the local angular velocity - takes float pitch,yaw,roll velocities | | Set the local angular velocity - takes float pitch, yaw, roll velocities. | ||
| |- | |- | ||
| | <code>SetForwardVector</code> | | <code>SetForwardVector</code> | ||
| | <code>void  | | <code>void SetForwardVector(Vector ''forwardvec'')</code> | ||
| |  | | Sets entity forward vector in local space. | ||
| |- | |- | ||
| | <code>SetHealth</code> | | <code>SetHealth</code> | ||
| | <code>void  | | <code>void SetHealth(int ''health'')</code> | ||
| | Sets the current [[health]]. | |||
| |- | |- | ||
| | <code>SetMaxHealth</code> | | <code>SetMaxHealth</code> | ||
| | <code>void  | | <code>void SetMaxHealth(int ''health'')</code> | ||
| | Sets the maximum health. | |||
| |- | |- | ||
| | <code>SetModel</code> | | <code>SetModel</code> | ||
| | <code>void  | | <code>void SetModel(string ''modelname'')</code> | ||
| | Changes the model of the entity. Does not precache the model. | |||
| |- | |- | ||
| | <code>SetOrigin</code> | | <code>SetOrigin</code> | ||
| | <code>void  | | <code>void SetOrigin(Vector ''position'')</code> | ||
| | Set local origin. "Teleports" the entity. | |||
| |- | |- | ||
| | <code>SetOwner</code> | | <code>SetOwner</code> | ||
| | <code>void  | | <code>void SetOwner(handle ''owner'')</code> | ||
| | Sets this entity's owner | | Sets this entity's owner. | ||
| |- | |- | ||
| | <code>SetSize</code> | | <code>SetSize</code> | ||
| | <code>void  | | <code>void SetSize(Vector ''mins'', Vector ''maxs'')</code> | ||
| | Sets the bounding box size. | |||
| |- | |- | ||
| | <code>SetTeam</code> | | <code>SetTeam</code> | ||
| | <code>void  | | <code>void SetTeam(int ''team'')</code> | ||
| | Set the team this entity is on. | |||
| |- | |- | ||
| | <code>SetVelocity</code> | | <code>SetVelocity</code> | ||
| | <code>void  | | <code>void SetVelocity(Vector ''velocity'')</code> | ||
| | Set local velocity. | |||
| |- | |||
| | <code>StopSound</code> | |||
| | <code>void StopSound(string ''soundname'')</code> | |||
| | Stops a sound on this entity. | |||
| |- | |- | ||
| | <code>ValidateScriptScope</code> | | <code>ValidateScriptScope</code> | ||
| | <code>bool  | | <code>bool ValidateScriptScope()</code> | ||
| | Ensure that an entity's script scope has been created | | Ensure that an entity's script scope has been created. | ||
| |- | |- | ||
| |  | |} | ||
| ==== Hooks ==== | |||
| If one of these functions are declared in an Entity Script, the entity will run this function automatically in the appropriate situation.  | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |- | ||
| | <code> | | <code>Input''InputName''</code> | ||
| | <code>bool Input''InputName''()</code> | |||
| | Called when the entity receives an input from the I/O system. The name of the function needs to be <code>Input</code> followed by the name of the input in CamelCase, for example <code>InputFireUser1</code> for the FireUser1 input. The function needs to return a boolean value. Setting it to <code>true</code> allows the entity to process the input, while <code>false</code> cancels it. | |||
| |- | |- | ||
| | <code> | | <code>OnPostSpawn</code> | ||
| | <code>void OnPostSpawn()</code> | |||
| | This is called after the entity has spawned. | |||
| |- | |- | ||
| | <code> | | <code>Precache</code> | ||
| | <code>void Precache()</code> | |||
| | This is called during entity spawning and after restore to allow scripts to precache any resources they need. | |||
| |} | |} | ||
| == CBaseAnimating  | === CBaseAnimating === | ||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| Script handle class for animating entities such as props. | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 207: | Line 329: | ||
| |- | |- | ||
| | <code>GetAttachmentAngles</code> | | <code>GetAttachmentAngles</code> | ||
| | <code>Vector  | | <code>Vector GetAttachmentAngles(int ''id'')</code> | ||
| | Get the attachment  | | Get the attachment ID's angles as a pitch, yaw, roll vector. | ||
| |- | |- | ||
| | <code>GetAttachmentOrigin</code> | | <code>GetAttachmentOrigin</code> | ||
| | <code>Vector  | | <code>Vector GetAttachmentOrigin(int ''id'')</code> | ||
| | Get the attachment  | | Get the attachment ID's origin vector. | ||
| |- | |- | ||
| | <code>IsSequenceFinished</code> | | <code>IsSequenceFinished</code> | ||
| | <code>bool  | | <code>bool IsSequenceFinished()</code> | ||
| | Ask whether the main sequence is done playing | | Ask whether the main sequence is done playing. | ||
| |- | |- | ||
| | <code>LookupAttachment</code> | | <code>LookupAttachment</code> | ||
| | <code>int  | | <code>int LookupAttachment(string ''attachmentName'')</code> | ||
| | Get the named attachment  | | Get the named attachment ID. | ||
| |- | |- | ||
| | <code>SetBodygroup</code> | | <code>SetBodygroup</code> | ||
| | <code>void  | | <code>void SetBodygroup(int ''groupIndex'', int ''value'')</code> | ||
| | Sets  | | Sets the models bodygroup value by index. | ||
| |} | |} | ||
| === CBaseFlex  | |||
| === CBaseFlex === | |||
| Extends [[#CBaseAnimating|CBaseAnimating]] | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 234: | Line 361: | ||
| |- | |- | ||
| | <code>GetCurrentScene</code> | | <code>GetCurrentScene</code> | ||
| | <code>handle  | | <code>handle GetCurrentScene()</code> | ||
| | Returns the instance of the oldest active scene entity (if any). | | Returns the instance of the oldest active scene entity (if any). | ||
| |- | |- | ||
| | <code>GetSceneByIndex</code> | | <code>GetSceneByIndex</code> | ||
| | <code>handle  | | <code>handle GetSceneByIndex(int ''index'')</code> | ||
| | Returns the instance of the scene entity at the specified index. | | Returns the instance of the scene entity at the specified index. | ||
| |} | |} | ||
| === CBasePlayer  | |||
| === CBasePlayer === | |||
| Extends [[#CBaseAnimating|CBaseAnimating]] | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 249: | Line 381: | ||
| |- | |- | ||
| | <code>IsNoclipping</code> | | <code>IsNoclipping</code> | ||
| | <code>bool  | | <code>bool IsNoclipping()</code> | ||
| | Returns true if the player is in noclip mode. | | Returns true if the player is in noclip mode. | ||
| |} | |} | ||
| == CEnvEntityMaker  | === CBaseMultiplayerPlayer === | ||
| Extends [[#CBasePlayer|CBasePlayer]] | |||
| Script handle class for the CS:GO players. No additional methods. | |||
| === CEnvEntityMaker === | |||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| Script handle class for [[env_entity_maker]].  | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 267: | Line 405: | ||
| |- | |- | ||
| | <code>SpawnEntity</code> | | <code>SpawnEntity</code> | ||
| | <code>void  | | <code>void SpawnEntity()</code> | ||
| | Create an entity at the location of the maker | | Create an entity at the location of the maker | ||
| |- | |- | ||
| | <code>SpawnEntityAtEntityOrigin</code> | | <code>SpawnEntityAtEntityOrigin</code> | ||
| | <code>void  | | <code>void SpawnEntityAtEntityOrigin(handle ''entity'')</code> | ||
| | Create an entity at the location of a specified entity instance | | Create an entity at the location of a specified entity instance. | ||
| |- | |- | ||
| | <code>SpawnEntityAtLocation</code> | | <code>SpawnEntityAtLocation</code> | ||
| | <code>void  | | <code>void SpawnEntityAtLocation(Vector ''origin'', Vector ''orientation'')</code> | ||
| | Create an entity at a specified location and  | | Create an entity at a specified location and orientation, orientation is Euler angle in degrees (pitch, yaw, roll). | ||
| |- | |- | ||
| | <code>SpawnEntityAtNamedEntityOrigin</code> | | <code>SpawnEntityAtNamedEntityOrigin</code> | ||
| | <code>void  | | <code>void SpawnEntityAtNamedEntityOrigin(string ''targetname'')</code> | ||
| | Create an entity at the location of a named entity | | Create an entity at the location of a named entity. If multiple entities have the same name, only the one with the lowest entity index will be targeted. | ||
| |} | |} | ||
| === CPointTemplate === | |||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| Script handle class for [[point_template]]. | |||
| ==== Hooks ==== | |||
| ;<code>table PreSpawnInstance(string ''entityClass'', string ''entityName'')</code> | |||
| :If this is defined, it will be called right before the entity is created, and any keyvalues returned will be assigned to the entity. | |||
| <source lang="cpp">function PreSpawnInstance( entityClass, entityName ) | |||
| { | |||
| 	local keyvalues = | |||
| 	{  | |||
|    		rendercolor = "0 255 0", | |||
|    		targetname = "mySpawnedEntity" | |||
| 	} | |||
| 	return keyvalues | |||
| } | |||
| </source> | |||
| ;<code>void PostSpawn(table ''entities'')</code> | |||
| :Called after the entities are spawned. A table with the handles of the spawned entities indexed by name is passed to the function. Could use this to connect outputs or do whatever needs to be done after the entity was created. | |||
| {{note|PostSpawn() will not be called unless the PreSpawnInstance() function is also defined in the script.}} | |||
| <source lang="cpp">function PostSpawn( entities ) | |||
| { | |||
| 	foreach( targetname, handle in entities ) | |||
| 	{ | |||
| 		printl( targetname + ": " + handle ) | |||
| 	} | |||
| } | |||
| </source> | |||
| ===== Example ===== | |||
| Spawned entities can be accessed synchronously in script by using an entity maker. The following generalised example creates a global <code>SpawnMyEntity()</code> function which spawns and returns the templated entity. It can be modified to support multiple templated entities. | |||
| <source lang="cpp"> | |||
| m_hSpawnedEntity <- null; | |||
| m_KeyValues <- null; | |||
| m_hSpawner <- Entities.CreateByClassname( "env_entity_maker" ); | |||
| m_hSpawner.__KeyValueFromString( "EntityTemplate", self.GetName() ); | |||
| function PreSpawnInstance( classname, targetname ) | |||
| { | |||
| 	return m_KeyValues; | |||
| } | |||
| function PostSpawn( entities ) | |||
| { | |||
| 	foreach ( targetname, entity in entities ) | |||
| 	{ | |||
| 		m_hSpawnedEntity = entity; | |||
| 		break; | |||
| 	} | |||
| } | |||
| ::SpawnMyEntity <- function( keyvalues = null ) | |||
| { | |||
| 	m_KeyValues = keyvalues; | |||
| 	m_hSpawner.SpawnEntity(); | |||
| 	return m_hSpawnedEntity; | |||
| }.bindenv(this) | |||
| </source> | |||
| Spawn templated entities from any script. | |||
| <source lang="cpp"> | |||
| local ent = SpawnMyEntity( { | |||
| 	rendercolor = Vector( RandomInt(0, 255), RandomInt(0, 255), RandomInt(0, 255) ) | |||
| } ) | |||
| == CSceneEntity  | printl( ent ) | ||
| </source> | |||
| === CSceneEntity === | |||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 291: | Line 511: | ||
| |- | |- | ||
| | <code>AddBroadcastTeamTarget</code> | | <code>AddBroadcastTeamTarget</code> | ||
| | <code>void  | | <code>void AddBroadcastTeamTarget(int ''index'')</code> | ||
| | Adds a team (by index) to the broadcast list | | Adds a team (by index) to the broadcast list. | ||
| |- | |- | ||
| | <code>EstimateLength</code> | | <code>EstimateLength</code> | ||
| | <code>float  | | <code>float EstimateLength()</code> | ||
| | Returns length of this scene in seconds. | | Returns length of this scene in seconds. | ||
| |- | |- | ||
| | <code>FindNamedEntity</code> | | <code>FindNamedEntity</code> | ||
| | <code>handle  | | <code>handle FindNamedEntity(string ''reference'')</code> | ||
| | given an entity reference, such as !target, get actual entity from scene object | | given an entity reference, such as !target, get actual entity from scene object. | ||
| |- | |- | ||
| | <code>IsPaused</code> | | <code>IsPaused</code> | ||
| | <code>bool  | | <code>bool IsPaused()</code> | ||
| | If this scene is currently paused. | | If this scene is currently paused. | ||
| |- | |- | ||
| | <code>IsPlayingBack</code> | | <code>IsPlayingBack</code> | ||
| | <code>bool  | | <code>bool IsPlayingBack()</code> | ||
| | If this scene is currently playing. | | If this scene is currently playing. | ||
| |- | |- | ||
| | <code>LoadSceneFromString</code> | | <code>LoadSceneFromString</code> | ||
| | <code>bool  | | <code>bool LoadSceneFromString(string ''sceneName'', string ''scene'')</code> | ||
| |  | | Given a dummy scene name and a vcd string, load the scene. | ||
| |- | |- | ||
| | <code>RemoveBroadcastTeamTarget</code> | | <code>RemoveBroadcastTeamTarget</code> | ||
| | <code>void  | | <code>void RemoveBroadcastTeamTarget(int ''index'')</code> | ||
| | Removes a team (by index) from the broadcast list | | Removes a team (by index) from the broadcast list. | ||
| |} | |} | ||
| == CTriggerCamera  | === CTriggerCamera === | ||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 327: | Line 551: | ||
| |- | |- | ||
| | <code>GetFov</code> | | <code>GetFov</code> | ||
| | <code>int  | | <code>int GetFov()</code> | ||
| |  | | Get cameras current Field Of View setting as integer. | ||
| |- | |- | ||
| | <code>SetFov</code> | | <code>SetFov</code> | ||
| | <code>void  | | <code>void SetFov(int ''fov'', float ''rate'')</code> | ||
| |  | | Set cameras current FOV in integer degrees and FOV change rate as float. | ||
| |} | |||
| ==== Hooks ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>ScriptStartCameraShot</code> | |||
| | <code>void ScriptStartCameraShot(string ''shotType'', handle ''sceneEntity'', handle ''actor1'', handle ''actor2'', float ''duration'')</code> | |||
| | ''Called from SceneEntity in response to a CChoreoEvent::CAMERA sent from a VCD.'' {{todo}} | |||
| |} | |} | ||
| === CFuncTrackTrain === | |||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| = CEntities = | ==== Methods ==== | ||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>GetFuturePosition</code> | |||
| | <code>Vector GetFuturePosition(float ''x'', float ''speed'')</code> | |||
| | Get a position on the track x seconds in the future. | |||
| |} | |||
| === CHostage === | |||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>IsBeingCarried</code> | |||
| | <code>bool IsBeingCarried()</code> | |||
| | Get whether the hostage is currently being carried or not.  | |||
| |} | |||
| === CGameCoopMissionManager === | |||
| Extends [[#CBaseEntity|CBaseEntity]] | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>GetWaveNumber</code> | |||
| | <code>int GetWaveNumber()</code> | |||
| | Get the number of waves the players have completed. | |||
| |} | |||
| === CEntities === | |||
| Script instance: <code>Entities</code> | |||
| An interface to find and iterate over the script handles for the entities in play.  | |||
| To iterate over a set of entities, pass <code>null</code> to the ''previous'' argument in the appropriate method to start an iteration, or reference to a previously found entity to continue a search. | |||
| The following are two equivalent examples and iterate over all weapons on the map: | |||
| {| width=100% | |||
| |- style="vertical-align:top;" | |||
| | | |||
| <source lang=cpp> | |||
| local ent = null; | |||
| while ( ent = Entities.FindByClassname(ent, "weapon_*") ) | |||
| { | |||
|   // ... | |||
| } | |||
| </source> | |||
| | | |||
| <source lang=cpp> | |||
| for (local ent; ent = Entities.FindByName(ent, "weapon_*"); ) | |||
| { | |||
|   // ... | |||
| } | |||
| </source> | |||
| |} | |||
| {{Note | | |||
| * The variable name <code>ent</code> is arbitrary. | |||
| * Indeed, we mean "{{=}}" and not "{{=}}{{=}}" in the loop conditions! The loops end if <code>ent</code> becomes <code>null</code>, which happens when no matching entities have an [[entity index]] higher to the one in ''previous'' parameter. | |||
| * Semicolons are optional, except in the header of the <code>for</code> statement. | |||
| * The string parameters of the <code>FindBy...</code> functions support the wildcard star <code>*</code>. In the above example, <code>FindByClassname</code> only returns either a handle of an entity whose classname begins with "<code>weapon_</code>" or it returns <code>null</code>. | |||
| }} | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 345: | Line 662: | ||
| |- | |- | ||
| | <code>CreateByClassname</code> | | <code>CreateByClassname</code> | ||
| | <code>handle  | | <code>handle CreateByClassname(string ''classname'')</code> | ||
| | Creates an entity by classname | | Creates an entity by [[classname]] with the initial origin <code>(0,0,0)</code>. {{note|The classname keyvalue of an entity can be manipulated and does not necessarily reflect its code class. Also, there are entities that have a different classname than the one they are created with.}} | ||
| |- | |- | ||
| | <code>FindByClassname</code> | | <code>FindByClassname</code> | ||
| | <code>handle  | | <code>handle FindByClassname(handle ''previous'', string ''classname'')</code> | ||
| | Find entities by  | | Find entities by the value of their <code>classname</code> keyvalue. | ||
| |- | |- | ||
| | <code>FindByClassnameNearest</code> | | <code>FindByClassnameNearest</code> | ||
| | <code>handle  | | <code>handle FindByClassnameNearest(string ''class'', Vector ''origin'', float ''radius'')</code> | ||
| | Find  | | Find the entity by the value of its <code>classname</code> keyvalue nearest to the specified <code>origin</code>. | ||
| |- | |- | ||
| | <code>FindByClassnameWithin</code> | | <code>FindByClassnameWithin</code> | ||
| | <code>handle  | | <code>handle FindByClassnameWithin(handle ''previous'', string ''classname'', Vector ''origin'', float ''radius'')</code> | ||
| | Find entities by  | | Find entities by the value of their <code>classname</code> keyvalue within a <code>radius</code> around an <code>origin</code>. | ||
| |- | |- | ||
| | <code>FindByModel</code> | | <code>FindByModel</code> | ||
| | <code>handle  | | <code>handle FindByModel(handle ''previous'', string ''modelname'')</code> | ||
| | Find entities by model  | | Find entities by the value of their <code>model</code> keyvalue. {{tip|Useful to distinguish between entities with an identical classname keyvalue, for example {{ent|weapon_mp7}} and {{ent|weapon_mp5sd}}, see [[:Category:Counter-Strike: Global Offensive Weapons#Manipulating Weapons|Category: CS:GO Weapons]].}} | ||
| |- | |- | ||
| | <code>FindByName</code> | | <code>FindByName</code> | ||
| | <code>handle  | | <code>handle FindByName(handle ''previous'', string ''targetname'')</code> | ||
| | Find entities by  | | Find entities by the value of their <code>[[targetname]]</code> keyvalue. | ||
| |- | |- | ||
| | <code>FindByNameNearest</code> | | <code>FindByNameNearest</code> | ||
| | <code>handle  | | <code>handle FindByNameNearest(string ''targetname'', Vector ''origin'', float ''radius'')</code> | ||
| | Find entities by  | | Find entities by the value of their <code>targetname</code> keyvalue nearest to a point. | ||
| |- | |- | ||
| | <code>FindByNameWithin</code> | | <code>FindByNameWithin</code> | ||
| | <code>handle  | | <code>handle FindByNameWithin(handle ''previous'', string ''targetname'', Vector ''origin'', float ''radius'')</code> | ||
| | Find entities by  | | Find entities by the value of their <code>targetname</code> keyvalue within a radius. | ||
| |- | |- | ||
| | <code>FindByTarget</code> | | <code>FindByTarget</code> | ||
| | <code>handle  | | <code>handle FindByTarget(handle ''previous'', string ''target'')</code> | ||
| | Find entities by  | | Find entities by the value of their <code>target</code> keyvalue. | ||
| |- | |- | ||
| | <code>FindInSphere</code> | | <code>FindInSphere</code> | ||
| | <code>handle  | | <code>handle FindInSphere(handle ''previous'', Vector ''origin'', float ''radius'')</code> | ||
| | Find entities within a radius.  | | Find entities within a <code>radius</code> around an <code>origin</code>. | ||
| |- | |- | ||
| | <code>First</code> | | <code>First</code> | ||
| | <code>handle  | | <code>handle First()</code> | ||
| |  | | Returns the first entity, typically ''[[worldspawn]]''. Equivalent to <code>Entities.Next(null)</code> | ||
| |- | |||
| | <code>Next</code> | |||
| | <code>handle Next(handle ''previous'')</code> | |||
| | At the given reference of a previously-found entity, returns the next one after it in the list. | |||
| |- | |- | ||
| | <code>IsValid</code> | | <code>IsValid</code> | ||
| | <code>bool IsValid()</code> | |||
| | Whether the handle belongs to a valid entity. | |||
| | <code> | |||
| |  | |||
| |} | |} | ||
| === CPlayerVoiceListener === | |||
| {{warning|Broken! This class is implemented in CS:GO, but the required <code>PlayerVoiceListener</code> instance is not.}} | |||
| ==== Methods ==== | |||
| =  | |||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 405: | Line 725: | ||
| |- | |- | ||
| | <code>GetPlayerSpeechDuration</code> | | <code>GetPlayerSpeechDuration</code> | ||
| | <code>float  | | <code>float GetPlayerSpeechDuration(int ''playerIndex'')</code> | ||
| | Returns the number of seconds the player has been continuously speaking. | | Returns the number of seconds the player has been continuously speaking. | ||
| |- | |- | ||
| | <code>IsPlayerSpeaking</code> | | <code>IsPlayerSpeaking</code> | ||
| | <code>bool  | | <code>bool IsPlayerSpeaking(int ''playerIndex'')</code> | ||
| | Returns whether the player specified is speaking. | | Returns whether the player specified is speaking. | ||
| |- | |- | ||
| | <code>IsValid</code> | | <code>IsValid</code> | ||
| | <code>bool IsValid()</code> | |||
| | Whether the handle belongs to a valid entity. | |||
| |} | |} | ||
| === CScriptKeyValues === | |||
| Script handle representation of a models [[$keyvalues]] block. | |||
| Sub keys are instances of the same class. | |||
| =  | ==== Methods ==== | ||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 427: | Line 752: | ||
| |- | |- | ||
| | <code>FindKey</code> | | <code>FindKey</code> | ||
| | <code> | | <code>CScriptKeyValues FindKey(string ''key'')</code> | ||
| |  | | Find a sub key by the key name. | ||
| |- | |- | ||
| | <code>GetFirstSubKey</code> | | <code>GetFirstSubKey</code> | ||
| | <code> | | <code>CScriptKeyValues GetFirstSubKey()</code> | ||
| |  | | Return the first sub key object. | ||
| |- | |- | ||
| | <code>GetKeyBool</code> | | <code>GetKeyBool</code> | ||
| | <code>bool  | | <code>bool GetKeyBool(string ''key'')</code> | ||
| |  | | Return the key value as a bool. | ||
| |- | |- | ||
| | <code>GetKeyFloat</code> | | <code>GetKeyFloat</code> | ||
| | <code>float  | | <code>float GetKeyFloat(string ''key'')</code> | ||
| |  | | Return the key value as a float. | ||
| |- | |- | ||
| | <code>GetKeyInt</code> | | <code>GetKeyInt</code> | ||
| | <code>int  | | <code>int GetKeyInt(string ''key'')</code> | ||
| |  | | Return the key value as an integer. | ||
| |- | |- | ||
| | <code>GetKeyString</code> | | <code>GetKeyString</code> | ||
| | <code>string  | | <code>string GetKeyString(string ''key'')</code> | ||
| |  | | Return the key value as a string. | ||
| |- | |- | ||
| | <code>GetNextKey</code> | | <code>GetNextKey</code> | ||
| | <code> | | <code>CScriptKeyValues GetNextKey()</code> | ||
| |  | | Return the next neighbor key object to the one the method is called on. | ||
| |- | |- | ||
| | <code>IsKeyEmpty</code> | | <code>IsKeyEmpty</code> | ||
| | <code>bool  | | <code>bool IsKeyEmpty(string ''key'')</code> | ||
| |  | | Returns true if the named key has no value. | ||
| |- | |- | ||
| | <code>IsValid</code> | | <code>IsValid</code> | ||
| | <code>bool IsValid()</code> | |||
| | Whether the handle belongs to a valid key. | |||
| |- | |- | ||
| | <code>ReleaseKeyValues</code> | | <code>ReleaseKeyValues</code> | ||
| | <code>void  | | <code>void ReleaseKeyValues()</code> | ||
| |  | | Releases the contents of the instance. | ||
| |} | |||
| === CCallChainer === | |||
| '''CCallChainer''' objects collect all functions with a matching prefix in a given scope, then inserts it all into the <code>chains</code> table with the prefix removed. All collected unprefixed functions can then be called in a chain using the class's <code>Call()</code> method, given the method's ''event'' argument matches the functions' name. | |||
| Whenever a '''CCallChainer''' object is created, a function named <code>Dispatch</code> followed by its given prefix will also be created, which  the class binds the environment of its <code>Call()</code> method to. | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>constructor</code> | |||
| | <code>CCallChainer(string ''functionPrefix'', table ''scope'' = null)</code> | |||
| | Creates a CCallChainer object that'll collect functions that have a matching prefix in the given scope. | |||
| |- | |||
| | <code>PostScriptExecute</code> | |||
| | <code>void PostScriptExecute()</code> | |||
| | Search for all non-native functions with matching prefixes, then push them into the <code>chains</code> table. | |||
| |- | |||
| | <code>Call</code> | |||
| | <code>bool Call(string ''event'', any ...)</code> | |||
| | Find an unprefixed function name in the <code>chains</code> table and call it with the given arguments. | |||
| |} | |} | ||
| ==== Members ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Instance | |||
| ! Type | |||
| ! Description | |||
| |- | |||
| | <code>chains</code> | |||
| | <code>table</code> | |||
| | Contains names of unprefixed functions, each with an array of functions to call. | |||
| |- | |||
| | <code>prefix</code> | |||
| | <code>string</code> | |||
| | Prefix that functions should have to be added into the <code>chains</code> table. Set by the constructor. | |||
| |- | |||
| | <code>scope</code> | |||
| | <code>table</code> | |||
| | If set, seek functions in this scope instead. Set by the constructor. | |||
| |} | |||
| === CSimpleCallChainer === | |||
| Intended to be simpler to use than [[#CCallChainer|CCallChainer]], the class '''CSimpleCallChainer''' holds only a single chain of functions inside an array instead of multiple inside a table. As such, its <code>Call()</code> method does not need a function's name. | |||
| This class is also used internally by these [[#CBaseEntity|CBaseEntity]] hooks: <code>Precache()</code> and <code>OnPostSpawn()</code>. | |||
| =  | ==== Methods ==== | ||
| {| class="standard-table" style="width: 100%;" | {| class="standard-table" style="width: 100%;" | ||
| ! Function | ! Function | ||
| Line 474: | Line 846: | ||
| ! Description | ! Description | ||
| |- | |- | ||
| | <code> | | <code>constructor</code> | ||
| | <code> | | <code>CSimpleCallChainer(string ''functionPrefix'', table ''scope'' = null, exactMatch = false)</code> | ||
| |  | | Creates a CSimpleCallChainer object that'll collect functions that have a matching prefix in the given scope, unless it seek for an exact name match. | ||
| |- | |||
| | <code>PostScriptExecute</code> | |||
| | <code>void PostScriptExecute()</code> | |||
| | Begin searching for all non-native functions with matching prefixes, then push them into the <code>chain</code> array. | |||
| |- | |||
| | <code>Call</code> | |||
| | <code>bool Call(any ...)</code> | |||
| | Call all functions inside the <code>chain</code> array with the given arguments. | |||
| |} | |||
| ==== Members ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Instance | |||
| ! Type | |||
| ! Description | |||
| |- | |||
| | <code>chain</code> | |||
| | <code>array</code> | |||
| | All functions to be called by the <code>Call()</code> method. | |||
| |- | |||
| | <code>exactMatch</code> | |||
| | <code>bool</code> | |||
| | If set, names of non-native functions and <code>prefix</code> must be an exact match.  Set by the constructor. | |||
| |- | |||
| | <code>prefix</code> | |||
| | <code>string</code> | |||
| | Prefix that functions should have to be added into the <code>chain</code> array. Set by the constructor. | |||
| |- | |||
| | <code>scope</code> | |||
| | <code>table</code> | |||
| | If set, seek functions in this scope instead. Set by the constructor. | |||
| |} | |||
| === LateBinder === | |||
| Late binding: allows a table to refer to parts of itself, it's children, it's owner, and then have the references fixed up after it's fully parsed. | |||
| <source lang=cpp> | |||
| // Usage: | |||
| lateBinder <- LateBinder(); | |||
| lateBinder.Begin( this ); | |||
| Test1 <- | |||
| {    | |||
|    Foo=1 | |||
| }    | |||
| Test2 <- | |||
| {    | |||
|    FooFoo = "I'm foo foo" | |||
|    BarBar="@Test1.Foo" | |||
|    SubTable = { boo=[bah, "@Test2.FooFoo", "@Test1.Foo"], booboo2={one=bah, two="@Test2.FooFoo", three="@Test1.Foo"} } | |||
|    booboo=[bah, "@Test2.FooFoo", "@Test1.Foo"] | |||
|    booboo2={one=bah, two="@Test2.FooFoo", three="@Test1.Foo"} | |||
|    bah=wha | |||
| }    | |||
| lateBinder.End(); | |||
| delete lateBinder; | |||
| </source> | |||
| When End() is called, all of the unresolved symbols in the tables and arrays will be resolved, any left unresolved will become a string prepended with '~', which later code can deal with. | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>Begin</code> | |||
| |- | |||
| | <code>End</code> | |||
| |- | |||
| | <code>EstablishDelegation</code> | |||
| |- | |||
| | <code>HookRootMetamethod</code> | |||
| |- | |||
| | <code>Log</code> | |||
| |- | |||
| | <code>m_bindNamesStack</code> | |||
| |- | |||
| | <code>m_fixupSet</code> | |||
| |- | |||
| | <code>m_log</code> | |||
| |- | |||
| | <code>m_logIndent</code> | |||
| |- | |||
| | <code>m_targetTable</code> | |||
| |- | |||
| | <code>RemoveDelegation</code> | |||
| |- | |||
| | <code>Resolve</code> | |||
| |- | |||
| | <code>UnhookRootMetamethod</code> | |||
| |} | |||
| === regexp === | |||
| The built-in [http://squirrel-lang.org/doc/sqstdlib2.html#d0e2580 Squirrel class] for regular expressions. | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>constructor</code> | |||
| | <code>regexp()</code> | |||
| |  | |||
| |- | |||
| | <code>capture</code> | |||
| | <code> [table] capture(''str'', [''start''])</code> | |||
| | Returns an array of tables containing two indexes("begin" and "end")of the first match of the regular expression in the string str. An array entry is created for each captured sub expressions. If no match occurs returns null. The search starts from the index start of the string, if start is omitted the search starts from the beginning of the string.  | |||
| |- | |||
| | <code>match</code> | |||
| | <code>bool match(''str'')</code> | |||
| | Returns a true if the regular expression matches the string str, otherwise returns false.  | |||
| |- | |||
| | <code>search</code> | |||
| | <code>table search(''str'', [''start''])</code> | |||
| | Returns a table containing two indexes("begin" and "end") of the first match of the regular expression in the string ''str'', otherwise if no match occurs returns null. The search starts from the index start of the string, if start is omitted the search starts from the beginning of the string.  | |||
| |- | |||
| | <code>subexpcount</code> | |||
| |  | |||
| |  | |||
| |} | |||
| === Vector === | |||
| Squirrel equivalent of the C++ [[Vector]] class. | |||
| Three-dimensional vector. | |||
| Has overloaded operations for the following: | |||
| <code>Vector * number</code> | |||
| <code>Vector + Vector</code> | |||
| <code>Vector - Vector</code> | |||
| ==== Methods ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>constructor</code> | |||
| | <code>Vector(float ''x'' = 0, float ''y'' = 0, float ''z'' = 0)</code> | |||
| | Creates a new vector with the specified Cartesian coordiantes. | |||
| |- | |||
| | <code>Cross</code> | |||
| | <code>float Cross(Vector ''factor'')</code> | |||
| | The [[wiki:Cross product|vector product]] of two vectors. Returns a vector orthogonal to the input vectors. | |||
| |- | |||
| | <code>Dot</code> | |||
| | <code>float Dot(Vector ''factor'')</code> | |||
| | The [[wiki:Dot product|scalar product]] of two vectors.  | |||
| |- | |||
| | <code>Length</code> | |||
| | <code>float Length()</code> | |||
| | Length of the vector. | |||
| |- | |||
| | <code>LengthSqr</code> | |||
| | <code>float LengthSqr()</code> | |||
| | Length of the vector squared. Cheaper than the above method. | |||
| |- | |||
| | <code>Length2D</code> | |||
| | <code>float Length2D()</code> | |||
| | Returns the length of the vector on the x-y plane. | |||
| |- | |||
| | <code>Length2DSqr</code> | |||
| | <code>float Length2DSqr()</code> | |||
| | Returns the square of the length of the vector on the x-y plane. Cheaper than the above method. | |||
| |- | |||
| | <code>Norm</code> | |||
| | <code>float Norm()</code> | |||
| | Normalises the vector, returns the vector length. | |||
| |- | |||
| | <code>ToKVString</code> | |||
| | <code>string ToKVString()</code> | |||
| | Returns a string without separations commas. | |||
| |} | |||
| ==== Members ==== | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Instance | |||
| ! Type | |||
| ! Description | |||
| |- | |||
| | <code>x</code> | |||
| | <code>float</code> | |||
| | Cartesian X axis. | |||
| |- | |||
| | <code>y</code> | |||
| | <code>float</code> | |||
| | Cartesian Y axis. | |||
| |- | |- | ||
| | <code> | | <code>z</code> | ||
| | <code> | | <code>float</code> | ||
| |  | | Cartesian Z axis. | ||
| |} | |||
| == Global functions == | |||
| === Printing and drawing === | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |- | ||
| | <code>DebugDrawBox</code> | | <code>DebugDrawBox</code> | ||
| | <code>void DebugDrawBox(Vector, Vector, Vector, int, int, int, int, float)</code> | | <code>void DebugDrawBox(vector ''origin'', vector ''mins'', vector ''maxs'', int ''r'', int ''g'', int ''b'', int ''alpha'', float ''duration'')</code> | ||
| | Draw a debug overlay box | | Draw a debug overlay box in the specified color for the specified duration with two corners being <code>origin + mins</code> and <code>origin + maxs</code>. The <code>alpha</code> is the fill rate (0-255). Set ''duration'' to 0 if drawn every tick. | ||
| |- | |||
| | <code>DebugDrawBoxAngles</code> | |||
| | <code>void DebugDrawBoxAngles(Vector ''origin'', Vector ''mins'', Vector ''maxs'', Vector ''angles'', int ''r'', int ''g'', int ''b'', int ''alpha'', float ''duration'')</code> | |||
| | Draw a debug overlay box with angles in the specified color for the specified duration with two corners being <code>origin + mins</code> and <code>origin + maxs</code> + <code>angles</code>. The <code>alpha</code> is the fill rate (0-255). Set ''duration'' to 0 if drawn every tick. | |||
| |- | |- | ||
| | <code>DebugDrawLine</code> | | <code>DebugDrawLine</code> | ||
| | <code>void DebugDrawLine(Vector, Vector, int, int, int, bool, float)</code> | | <code>void DebugDrawLine(Vector ''start'', Vector ''end'', int ''r'', int ''g'', int ''b'', bool ''noDepthTest'', float ''duration'')</code> | ||
| | Draw a debug  | | Draw a debug line between the points <code>start</code> and <code>end</code> in the specified color for the specified duration. Set ''duration'' to 0 if drawn every tick. | ||
| |- | |||
| | <code>Msg</code> | |||
| | <code>void Msg(string ''message'')</code> | |||
| | Equivalent to <code>print</code> | |||
| |- | |- | ||
| | <code> | | <code>print</code> | ||
| | <code> | | <code>void print(string ''message'')</code> | ||
| |  | | Prints the given message to the developer console. | ||
| |- | |- | ||
| | <code> | | <code>printl</code> | ||
| | <code> | | <code>void printl(string ''message'')</code> | ||
| |  | | Prints the given message to the developer console with newline. Equivalent to <code>print(message + "\n")</code> | ||
| |- | |- | ||
| | <code> | | <code>ScriptPrintMessageCenterAll</code> | ||
| | <code>void  | | <code>void ScriptPrintMessageCenterAll(string ''message'')</code> | ||
| |  | | Prints an alert message in the center of the screen to all players. | ||
| |- | |- | ||
| | <code> | | <code>ScriptPrintMessageCenterAllWithParams</code> | ||
| | <code> | | <code>void ScriptPrintMessageCenterAllWithParams(string ''message'', string ''param1'', string ''param2'', string ''param3'')</code> | ||
| |  | | Prints an alert message in the center print method to all players. Needs to pass token/message. | ||
| |- | |- | ||
| | <code> | | <code>ScriptPrintMessageCenterTeam</code> | ||
| | <code>int  | | <code>void ScriptPrintMessageCenterTeam(int, string)</code> | ||
| |  | | Prints an alert message in the center of the screen to the specified team. | ||
| * 0 : None | |||
| * 1 : Spectators | |||
| * 2 : Terrorists | |||
| * 3 : Counter-Terrorists | |||
| {{Warning|Game crashes for other team numbers!}} | |||
| |- | |- | ||
| | <code> | | <code>ScriptPrintMessageChatAll</code> | ||
| | <code>string  | | <code>void ScriptPrintMessageChatAll(string ''message'')</code> | ||
| |  | | Prints a message in chat to all players. | ||
| |- | |- | ||
| | <code> | | <code>ScriptPrintMessageChatTeam</code> | ||
| | <code> | | <code>void ScriptPrintMessageChatTeam(int ''team'', string ''message'')</code> | ||
| |  | | Prints a message in chat to the specified team. | ||
| {{Warning|Game crashes for other team numbers than the above!}} | |||
| |- | |- | ||
| | <code> | | <code>ShowMessage</code> | ||
| | <code> | | <code>void ShowMessage(string)</code> | ||
| |  | | Print a hud message on all clients. {{Note|Uses localized strings as found in <code>/scripts/titles.txt</code>}} | ||
| |- | |- | ||
| | <code> | | <code>__DumpScope</code> | ||
| | <code> | | <code>void __DumpScope(int ''indentation'', table ''scope'')</code> | ||
| |  | | Dumps the contents of ''scope''. | ||
| |- | |- | ||
| |  | |} | ||
| |  | |||
| === Training Course === | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |- | ||
| | <code>ScriptGetBestTrainingCourseTime</code> | | <code>ScriptGetBestTrainingCourseTime</code> | ||
| Line 545: | Line 1,145: | ||
| | <code>void ScriptHighlightAmmoCounter()</code> | | <code>void ScriptHighlightAmmoCounter()</code> | ||
| | Sends an event that is just used by the instructor system to show a hint highlighting the ammo counter. | | Sends an event that is just used by the instructor system to show a hint highlighting the ammo counter. | ||
| |- | |- | ||
| | <code>ScriptSetBestTrainingCourseTime</code> | | <code>ScriptSetBestTrainingCourseTime</code> | ||
| | <code>void ScriptSetBestTrainingCourseTime(int)</code> | | <code>void ScriptSetBestTrainingCourseTime(int ''time'')</code> | ||
| | Sets the player's best time for completing the timed course. | | Sets the player's best time for completing the timed course. | ||
| |- | |- | ||
| | <code>ScriptSetMiniScoreHidden</code> | | <code>ScriptSetMiniScoreHidden</code> | ||
| | <code>void ScriptSetMiniScoreHidden(bool)</code> | | <code>void ScriptSetMiniScoreHidden(bool ''hide'')</code> | ||
| | Toggles the visibility of the miniscoreboard hud element. | | Toggles the visibility of the miniscoreboard hud element. | ||
| |- | |- | ||
| | <code>ScriptSetPlayerCompletedTraining</code> | | <code>ScriptSetPlayerCompletedTraining</code> | ||
| | <code>void ScriptSetPlayerCompletedTraining(bool)</code> | | <code>void ScriptSetPlayerCompletedTraining(bool ''completed'')</code> | ||
| | Sets whether the player has completed the initial portion of the training map. | | Sets whether the player has completed the initial portion of the training map. | ||
| |- | |- | ||
| | <code>ScriptSetRadarHidden</code> | | <code>ScriptSetRadarHidden</code> | ||
| | <code>void ScriptSetRadarHidden(bool)</code> | | <code>void ScriptSetRadarHidden(bool ''hide'')</code> | ||
| | Toggles the visibility of the radar hud element. | | Toggles the visibility of the radar hud element. | ||
| |- | |- | ||
| Line 593: | Line 1,173: | ||
| | <code>void ScriptTrainingGivePlayerAmmo()</code> | | <code>void ScriptTrainingGivePlayerAmmo()</code> | ||
| | Refills ammo to max for all weapons the player has (only works in training). | | Refills ammo to max for all weapons the player has (only works in training). | ||
| |- | |||
| |} | |||
| === [[Creating a Co-op Strike Map|Co-op Strike]] === | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>ScriptCoopCollectBonusCoin</code> | |||
| | <code>void ScriptCoopCollectBonusCoin()</code> | |||
| | Marks one of the [[Item coop coin|bonus coins]] as collected. | |||
| |- | |||
| | <code>ScriptCoopGiveC4sToCTs</code> | |||
| | <code>void ScriptCoopGiveC4sToCTs(int)</code> | |||
| | Will give the number of specified [[weapon_c4|C4]]s to all alive CT players. | |||
| |- | |||
| | <code>ScriptCoopMissionGetMissionNumber</code> | |||
| | <code>int ScriptCoopMissionGetMissionNumber()</code> | |||
| | Gets the mission number for the current map - maps can have multiple missions on them. | |||
| |- | |||
| | <code>ScriptCoopMissionRespawnDeadPlayers</code> | |||
| | <code>void ScriptCoopMissionRespawnDeadPlayers()</code> | |||
| | Respawns players only. | |||
| |- | |||
| | <code>ScriptCoopMissionSetDeadPlayerRespawnEnabled</code> | |||
| | <code>void ScriptCoopMissionSetDeadPlayerRespawnEnabled(bool)</code> | |||
| | Controls whether player respawns can happen. | |||
| |- | |||
| | <code>ScriptCoopMissionSetNextRespawnIn</code> | |||
| | <code>void ScriptCoopMissionSetNextRespawnIn(float, bool)</code> | |||
| | Set the next respawn wave to happen in this many seconds. | |||
| |- | |||
| | <code>ScriptCoopMissionSpawnFirstEnemies</code> | |||
| | <code>void ScriptCoopMissionSpawnFirstEnemies(int)</code> | |||
| | Spawns the first wave of enemies in coop. | |||
| |- | |||
| | <code>ScriptCoopMissionSpawnNextWave</code> | |||
| | <code>void ScriptCoopMissionSpawnNextWave(int)</code> | |||
| | Tells the next wave of enemies to spawn in coop.  Also respawns player. | |||
| |- | |||
| | <code>ScriptCoopResetRoundStartTime</code> | |||
| | <code>void ScriptCoopResetRoundStartTime()</code> | |||
| | Resets the round time and starts the mission. | |||
| |- | |||
| | <code>ScriptCoopSetBotQuotaAndRefreshSpawns</code> | |||
| | <code>void ScriptCoopSetBotQuotaAndRefreshSpawns(int)</code> | |||
| | Sets the [[bot quota]] considering the # of players connected and refreshes the spawns. | |||
| |- | |||
| | <code>ScriptCoopExtendRoundDurationTime</code> | |||
| | <code>void ScriptCoopExtendRoundDurationTime(float)</code> | |||
| | Extends the round time after checkpoint during the mission. | |||
| |- | |||
| | <code>ScriptCoopToggleEntityOutlineHighlights</code> | |||
| | <code>void ScriptCoopToggleEntityOutlineHighlights(bool)</code> | |||
| | Highlights all dropped weapons for players, or removes all highlights. | |||
| |- | |||
| | <code>ScriptMissionResetDangerZones</code> | |||
| | <code>void ScriptMissionResetDangerZones()</code> | |||
| | Resets all danger zone entities. | |||
| |- | |||
| | <code>ScriptMissionCreateAndDetonateDangerZone</code> | |||
| | <code>void ScriptMissionCreateAndDetonateDangerZone(Vector, Vector)</code> | |||
| | Creates and detonates a danger zone at the given location moving towards target location. | |||
| |- | |||
| |} | |||
| === Premier Mode === | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>ScriptLobbyMapVetoFinished</code> | |||
| | <code>void ScriptLobbyMapVetoFinished(string mapname, bool, bool, string)</code> | |||
| | Switch to the selected map after lobby map veto finished. | |||
| |- | |||
| |} | |||
| === Math === | |||
| The built-in [http://www.squirrel-lang.org/mainsite/doc/sqstdlib2.html#d0e1519 Squirrel math library]. | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>abs</code> | |||
| | <code> int abs(float ''x'')</code> | |||
| | Returns the absolute value of <code>x</code> as an integer. | |||
| |- | |||
| | <code>acos</code> | |||
| | <code> float acos(float ''x'')</code> | |||
| | Returns the arccosine of <code>x</code>. | |||
| |- | |||
| | <code>asin</code> | |||
| | <code> float asin(float ''x'')</code> | |||
| | Returns the arcsine of <code>x</code>. | |||
| |- | |||
| | <code>atan</code> | |||
| | <code> float atan(float ''x'')</code> | |||
| | Returns the arctangent of <code>x</code>. | |||
| |- | |||
| | <code>atan2</code> | |||
| | <code> float atan2(float ''x'', float ''y'')</code> | |||
| | Returns the arctangent of <code>x/y</code>. | |||
| |- | |||
| | <code>ceil</code> | |||
| | <code> float ceil(float ''x'')</code> | |||
| | Returns a float value representing the smallest integer that is greater than or equal to <code>x</code>. | |||
| |- | |||
| | <code>cos</code> | |||
| | <code> float cos(float ''x'')</code> | |||
| | Returns the cosine of <code>x</code>. | |||
| |- | |||
| | <code>exp</code> | |||
| | <code> float exp(float ''x'')</code> | |||
| | Returns the exponential value (<code>e^x</code>) of the float parameter <code>x</code>. | |||
| |- | |||
| | <code>fabs</code> | |||
| | <code> float fabs(float ''x'')</code> | |||
| | Returns the absolute value of <code>x</code> as a float. | |||
| |- | |||
| | <code>floor</code> | |||
| | <code> float floor(float ''x'')</code> | |||
| | Returns a float value representing the largest integer that is less than or equal to <code>x</code>. | |||
| |- | |||
| | <code>log</code> | |||
| | <code> float log(float ''x'')</code> | |||
| | Returns the natural logarithm of <code>x</code>. | |||
| |- | |||
| | <code>log10</code> | |||
| | <code> float log10(float ''x'')</code> | |||
| | Returns the logarithm base-10 of <code>x</code>. | |||
| |- | |||
| | <code>pow</code> | |||
| | <code> float pow(float ''x'', float ''y'')</code> | |||
| | Returns <code>x</code> raised to the power of <code>y</code>. | |||
| |- | |||
| | <code>rand</code> | |||
| | <code> int rand()</code> | |||
| | Returns a pseudorandom integer in the range 0 to <code>RAND_MAX</code>. | |||
| |- | |||
| | <code>sin</code> | |||
| | <code> float sin(float ''x'')</code> | |||
| | Returns the sine of <code>x</code>. | |||
| |- | |||
| | <code>sqrt</code> | |||
| | <code> float sqrt(float ''x'')</code> | |||
| | Returns the square root of <code>x</code>. | |||
| |- | |||
| | <code>srand</code> | |||
| | <code> void srand(float ''seed'')</code> | |||
| | Sets the starting point for generating a series of pseudorandom integers. | |||
| |- | |||
| | <code>tan</code> | |||
| | <code> float tan(float ''x'')</code> | |||
| | Returns the tangent of <code>x</code>. | |||
| |} | |||
| === Other === | |||
| {| class="standard-table" style="width: 100%;" | |||
| ! Function | |||
| ! Signature | |||
| ! Description | |||
| |- | |||
| | <code>Assert</code> | |||
| | <code>void Assert(''exp'', string ''message'' = null)</code> | |||
| | Throws an exception if ''exp'' equates to false, optionally with message. | |||
| |- | |||
| | <code>CreateProp</code> | |||
| | <code>handle CreateProp(string ''classname'', Vector ''origin'', string ''model'', int ''animation'')</code> | |||
| | Create a prop with the specified class and model. Both [[prop_physics]], [[prop_dynamic]] as well as some other entity classes with models work. Does not precache the model. | |||
| |- | |||
| | <code>CreateSceneEntity</code> | |||
| | <code>CSceneEntity CreateSceneEntity(string ''scene'')</code> | |||
| | Create a scene entity to play the specified scene [[VCD|.vcd file]]. | |||
| |- | |||
| | <code>DispatchParticleEffect</code> | |||
| | <code>void DispatchParticleEffect(string ''particle'', Vector ''position'', Vector ''orientation'')</code> | |||
| | Dispatches a one-off particle system. See [[List of CS:GO Particles]]. Does not work if the particle is not precached.{{how}} {{note|Looped animations will stay until the round is reset.}} | |||
| |- | |||
| | <code>DoIncludeScript</code> | |||
| | <code>bool DoIncludeScript(string ''filename'', table ''scope'')</code> | |||
| | Execute the script file <code>"csgo/scripts/vscripts/" + filename</code> in the scope of <code>scope</code>. The extension <code>.nut</code> can be omitted. Returns true if the script was found and executed, otherwise false. | |||
| |- | |||
| | <code>IncludeScript</code> | |||
| | <code>bool IncludeScript(string ''filename'', table ''scope'' = null)</code> | |||
| | Execute the script file <code>"csgo/scripts/vscripts/" + filename</code> in the scope of <code>scope</code>, <code>this</code> by default. The extension <code>.nut</code> can be omitted. Returns true if the script was found and executed, otherwise false. | |||
| |- | |||
| | <code>DoEntFire</code> | |||
| | <code>void DoEntFire(string ''target'', string ''action'', string ''value'', float ''delay'', handle ''activator'', handle ''caller'')</code> | |||
| | Generate an entity [[I/O]] event. | |||
| |- | |||
| | <code>EntFire</code> | |||
| | <code>void EntFire(string ''target'', string ''action'', string ''value'' = "", float ''delay'' = 0.0, handle ''activator'' = null)</code> | |||
| | Generate an entity I/O event. | |||
| |- | |||
| | <code>EntFireByHandle</code> | |||
| | <code>void EntFireByHandle(handle ''target'', string ''action'', string ''value'', float ''delay'', handle ''activator'', handle ''caller'')</code> | |||
| | Generate an entity I/O event. | |||
| |- | |||
| | <code>FrameTime</code> | |||
| | <code>float FrameTime()</code> | |||
| | Get the time spent on the server in the last frame. | |||
| |- | |||
| | <code>GetDeveloperLevel</code> | |||
| | <code>int GetDeveloperLevel()</code> | |||
| | Gets the level of the ''developer'' mode. Equivalent to <code>developer()</code>. | |||
| |- | |||
| | <code>GetMapName</code> | |||
| | <code>string GetMapName()</code> | |||
| | Get the name of the map, e.g. <code>"de_dust2"</code>. | |||
| |- | |||
| | <code>LoopSinglePlayerMaps</code> | |||
| | <code>bool LoopSinglePlayerMaps()</code> | |||
| | Returns the boolean value of the ConVar <code>loopsingleplayermaps</code>, i.e. whether the single player maps are run in a continuous loop. | |||
| |- | |||
| | <code>PrintHelp</code> | |||
| | <code>void PrintHelp(string ''string'' = "*", bool ''exact'' = false)</code> | |||
| | Output help for script functions, optionally with a search string. | |||
| |- | |||
| | <code>RandomFloat</code> | |||
| | <code>float RandomFloat(float ''min'', float ''max'')</code> | |||
| | Generate a random floating point number within a range, inclusive. | |||
| |- | |||
| | <code>RandomInt</code> | |||
| | <code>int RandomInt(int ''min'', int ''max'')</code> | |||
| | Generate a random integer within a range, inclusive. | |||
| |- | |||
| | <code>RecordAchievementEvent</code> | |||
| | <code>void RecordAchievementEvent(string, int)</code> | |||
| | Records achievement event or progress. | |||
| |- | |||
| | <code>RetrieveNativeSignature</code> | |||
| | <code>void RetrieveNativeSignature(string ''nativeFunction'')</code> | |||
| | {{todo}} | |||
| |- | |||
| | <code>ScriptGetGameMode</code> | |||
| | <code>int ScriptGetGameMode()</code> | |||
| | Gets the current [[game mode]]. | |||
| |- | |||
| | <code>ScriptGetGameType</code> | |||
| | <code>int ScriptGetGameType()</code> | |||
| | Gets the current [[game type]]. | |||
| |- | |||
| | <code>ScriptGetRoundsPlayed</code> | |||
| | <code>int ScriptGetRoundsPlayed()</code> | |||
| | Get the number of rounds that any team has won so far. {{Warning | Drawn rounds are not counted, except they were ended using a [[game_round_end]] entity.}} | |||
| |- | |||
| | <code>ScriptIsLocalPlayerUsingController</code> | |||
| | <code>bool ScriptIsLocalPlayerUsingController()</code> | |||
| | Returns whether the player is playing with a controller or not. | |||
| |- | |||
| | <code>ScriptIsWarmupPeriod</code> | |||
| | <code>bool ScriptIsWarmupPeriod()</code> | |||
| | Is it warmup or not. | |||
| |- | |- | ||
| | <code>SendToConsole</code> | | <code>SendToConsole</code> | ||
| | <code>void SendToConsole(string)</code> | | <code>void SendToConsole(string ''command'')</code> | ||
| | Send a string to the console as a command | | Send a string to the console as a client command. The command is executed through the local player or listen server host. If no player is found, this function will only print the developer message <code>Cannot execute "''<command>''", no player</code> in the console. | ||
| |- | |- | ||
| | <code>SendToConsoleServer</code> | | <code>SendToConsoleServer</code> | ||
| | <code>void SendToConsoleServer(string)</code> | | <code>void SendToConsoleServer(string ''command'')</code> | ||
| | Send a string that gets executed on the server as a ServerCommand | | Send a string that gets executed on the server as a ServerCommand using [[whitelistcmd]]. Commands or ConVars that are not whitelisted are not executed or changed. | ||
| |- | |- | ||
| | <code>Time</code> | | <code>Time</code> | ||
| | <code>float Time()</code> | | <code>float Time()</code> | ||
| | Get the current server time | | Get the current server time in seconds. | ||
| |- | |- | ||
| | <code>TraceLine</code> | | <code>TraceLine</code> | ||
| | <code>float TraceLine(Vector, Vector, handle)</code> | | <code>float TraceLine(Vector ''start'', Vector ''end'', handle ''ignore'')</code> | ||
| |  | | Given 2 points and an entity to ignore, returns fraction along line that only hits world. | ||
| |- | |||
| | <code>TraceLinePlayersIncluded</code> | |||
| | <code>float TraceLinePlayersIncluded(Vector ''start'', Vector ''end'', handle ''ignore'')</code> | |||
| | Given 2 points and entity to ignore, returns fraction along line that hits world, models, players and NPCs. {{Note| Blocking entities are not limited to [[player]], almost everything will block it.}} | |||
| |- | |- | ||
| | <code>UniqueString</code> | | <code>UniqueString</code> | ||
| | <code> | | <code>string UniqueString(string ''suffix'' = "")</code> | ||
| | Generate a string guaranteed to be unique across the life of the script VM, with an optional root string. Useful for adding data to tables when not sure what keys are already in use in that table. Equivalent to <code>DoUniqueString(suffix)</code>. | |||
| |- | |||
| | <code>DoUniqueString</code> | |||
| | <code>string DoUniqueString(string ''suffix'')</code> | |||
| | Generate a string guaranteed to be unique across the life of the script VM, with an optional root string. Useful for adding data to tables when not sure what keys are already in use in that table. | | Generate a string guaranteed to be unique across the life of the script VM, with an optional root string. Useful for adding data to tables when not sure what keys are already in use in that table. | ||
| |- | |||
| | <code>__ReplaceClosures</code> | |||
| | <code>void __ReplaceClosures(function ''script'', table ''scope'')</code> | |||
| | Internal function called in <code>script_reload_</code> server commands. | |||
| |} | |} | ||
| == See also == | |||
| * [[VScript]] | |||
| * [[VScript Fundamentals]] | |||
| * [[Listening to game events in CS:GO|Listening to game events]] | |||
| * {{sq}} [[Squirrel]] | |||
| * {{csgo}} [[CS:GO VScript Examples|VScript Examples]] | |||
| * {{l4d2}} [[Left 4 Dead 2/Script Functions]] | |||
| * {{portal2}} [[List of Portal 2 Script Functions]] | |||
| * {{tf2}} [[Team Fortress 2/Scripting/Script Functions|List of Team Fortress 2 Script Functions]] | |||
| {{csgo-navbox}} | |||
| {{csgo topicon}} | |||
| [[Category:VScript functions]] | |||
| [[Category:Scripting]] | |||
Latest revision as of 08:30, 27 February 2025

 Counter-Strike: Global Offensive, that is no longer available for purchase or download digitally.
 Counter-Strike: Global Offensive, that is no longer available for purchase or download digitally.It is covered here for historical and technical reference.
 This list contains the engine-related Squirrel classes, functions and variables available for VScript in
 This list contains the engine-related Squirrel classes, functions and variables available for VScript in  Counter-Strike: Global Offensive. The official documentation can be printed in the console by setting
 Counter-Strike: Global Offensive. The official documentation can be printed in the console by setting developer to non-zero, loading a map, and executing script_help.
Variables
| Instance | Type | Description | 
|---|---|---|
| Entities | CEntities | Provides access to spawned entities in the server. | 
Constants
| Instance | Type | Value | 
|---|---|---|
| _charsize_ | integer | 1 | 
| _floatsize_ | integer | 4 | 
| _intsize_ | integer | 4 | 
| _version_ | string | "Squirrel 2.2.3 stable" | 
| RAND_MAX | integer | 32767 | 
| PI | float | 3.14159 | 
 Note:These are simply global variables, namely table slots in the root table. They can be changed at will, for example
Note:These are simply global variables, namely table slots in the root table. They can be changed at will, for example ::PI = 3.Classes
CBaseEntity
This is a script handle class for entities. All entities spawned have a script handle using this or one of its subclasses.
All script handles in-game are accessible from Entities. Entity scripts can use self to access their own script handle. activator and caller variables can be accessed on function calls.
Methods
| Function | Signature | Description | 
|---|---|---|
| __KeyValueFromInt | bool __KeyValueFromInt(string key, int value) | Sets entity keyvalue from an integer. | 
| __KeyValueFromFloat | bool __KeyValueFromFloat(string key, float value) | Sets entity keyvalue from a float. | 
| __KeyValueFromString | bool __KeyValueFromString(string key, string value) | Sets entity keyvalue from a string. | 
| __KeyValueFromVector | bool __KeyValueFromVector(string key, Vector value) | Sets entity keyvalue from a Vector. | 
| ConnectOutput | void ConnectOutput(string output, string function) | Adds an I/O connection that will call the named function when the specified output fires. | 
| DisconnectOutput | void DisconnectOutput(string output, string function) | Removes a connected script function from an I/O event. | 
| Destroy | void Destroy() | Kills the entity. | 
| EmitSound | void EmitSound(string soundname) | Plays a sound from this entity. | 
| entindex | int entindex() | Returns the entity index. | 
| EyePosition | Vector EyePosition() | Get vector to the eye position - absolute coordinates. | 
| FirstMoveChild | handle FirstMoveChild() | If in hierarchy, get the first move child. | 
| GetAngles | Vector GetAngles() | Get the entity local angles (pitch, yaw, roll) as a Vector object. | 
| GetAngularVelocity | Vector GetAngularVelocity() | Get the local angular velocity - returns a Vector of pitch, yaw, roll. | 
| GetBoundingMaxs | Vector GetBoundingMaxs() | Get a vector containing max bounds in local space. | 
| GetBoundingMaxsOriented | Vector GetBoundingMaxsOriented() | Get a vector containing max bounds, centered on object, taking the object's orientation into account. | 
| GetBoundingMins | Vector GetBoundingMins() | Get a vector containing min bounds in local space. | 
| GetBoundingMinsOriented | Vector GetBoundingMinsOriented() | Get a vector containing min bounds, centered on object, taking the object's orientation into account. | 
| GetCenter | Vector GetCenter() | Get vector to center of object in world space. | 
| GetClassname | string GetClassname() | Get entity classname. | 
| GetForwardVector | Vector GetForwardVector() | Get the forward vector of the entity in world space. | 
| GetHealth | int GetHealth() | Returns the current health. | 
| GetLeftVector | Vector GetLeftVector() | Get the right vector of the entity in world space. | 
| GetMaxHealth | int GetMaxHealth() | Returns the maximum health. | 
| GetModelKeyValues | CScriptKeyValues GetModelKeyValues() | Returns the $keyvalues block of the entity's model as a #CScriptKeyValues object. Note that this is not the keyvalues of the entity itself. | 
| GetModelName | string GetModelName() | Returns the value of the entity's modelkeyvalue or"". | 
| GetMoveParent | handle GetMoveParent() | If in hierarchy, retrieves the entity's parent. | 
| GetName | string GetName() | Returns the targetname of the entity. | 
| GetOrigin | Vector GetOrigin() | Returns this entity's local origin. | 
| GetOwner | handle GetOwner() | Gets this entity's owner. | 
| GetPreTemplateName | string GetPreTemplateName() | Get the entity name stripped of template unique decoration. This is the &048suffix added by templates that do not preserve the entity name. | 
| GetRootMoveParent | handle GetRootMoveParent() | If in hierarchy, walks up the hierarchy to find the root parent. | 
| GetScriptId | string GetScriptId() | Returns the thinkfunction keyvalue of the entity. | 
| GetScriptScope | handle GetScriptScope() | Retrieve the table storing the Entity Script data associated with this entity. | 
| GetSoundDuration | float GetSoundDuration(string soundname, string actormodel) | Returns float duration of the sound. Todo: Does this work correctly only with .wav files? | 
| GetTeam | int GetTeam() | Get the team this entity is on. | 
| GetUpVector | Vector GetUpVector() | Get the up vector of the entity in world space. | 
| GetVelocity | Vector GetVelocity() | Get the velocity of the entity. | 
| IsValid | bool IsValid() | Whether the handle belongs to a valid entity. | 
| NextMovePeer | handle NextMovePeer() | Return the next entity in the same movement hierarchy. | 
| PrecacheModel | void PrecacheModel(string modelname) | Precache a model. Expensive. | 
| PrecacheScriptSound | void PrecacheScriptSound(string soundname) | Precache a sound. Expensive. | 
| PrecacheSoundScript | void PrecacheSoundScript(string soundscript) | Precache a sound for later playing. Expensive. | 
| SetAbsOrigin | void SetAbsOrigin(Vector position) | Set absolute origin. | 
| SetAngles | void SetAngles(float pitch, float yaw, float roll) | Set entity local angles (pitch, yaw, roll). | 
| SetAngularVelocity | void SetAngularVelocity(float pitch, float yaw, float roll) | Set the local angular velocity - takes float pitch, yaw, roll velocities. | 
| SetForwardVector | void SetForwardVector(Vector forwardvec) | Sets entity forward vector in local space. | 
| SetHealth | void SetHealth(int health) | Sets the current health. | 
| SetMaxHealth | void SetMaxHealth(int health) | Sets the maximum health. | 
| SetModel | void SetModel(string modelname) | Changes the model of the entity. Does not precache the model. | 
| SetOrigin | void SetOrigin(Vector position) | Set local origin. "Teleports" the entity. | 
| SetOwner | void SetOwner(handle owner) | Sets this entity's owner. | 
| SetSize | void SetSize(Vector mins, Vector maxs) | Sets the bounding box size. | 
| SetTeam | void SetTeam(int team) | Set the team this entity is on. | 
| SetVelocity | void SetVelocity(Vector velocity) | Set local velocity. | 
| StopSound | void StopSound(string soundname) | Stops a sound on this entity. | 
| ValidateScriptScope | bool ValidateScriptScope() | Ensure that an entity's script scope has been created. | 
Hooks
If one of these functions are declared in an Entity Script, the entity will run this function automatically in the appropriate situation.
| Function | Signature | Description | 
|---|---|---|
| InputInputName | bool InputInputName() | Called when the entity receives an input from the I/O system. The name of the function needs to be Inputfollowed by the name of the input in CamelCase, for exampleInputFireUser1for the FireUser1 input. The function needs to return a boolean value. Setting it totrueallows the entity to process the input, whilefalsecancels it. | 
| OnPostSpawn | void OnPostSpawn() | This is called after the entity has spawned. | 
| Precache | void Precache() | This is called during entity spawning and after restore to allow scripts to precache any resources they need. | 
CBaseAnimating
Extends CBaseEntity
Script handle class for animating entities such as props.
Methods
| Function | Signature | Description | 
|---|---|---|
| GetAttachmentAngles | Vector GetAttachmentAngles(int id) | Get the attachment ID's angles as a pitch, yaw, roll vector. | 
| GetAttachmentOrigin | Vector GetAttachmentOrigin(int id) | Get the attachment ID's origin vector. | 
| IsSequenceFinished | bool IsSequenceFinished() | Ask whether the main sequence is done playing. | 
| LookupAttachment | int LookupAttachment(string attachmentName) | Get the named attachment ID. | 
| SetBodygroup | void SetBodygroup(int groupIndex, int value) | Sets the models bodygroup value by index. | 
CBaseFlex
Extends CBaseAnimating
Methods
| Function | Signature | Description | 
|---|---|---|
| GetCurrentScene | handle GetCurrentScene() | Returns the instance of the oldest active scene entity (if any). | 
| GetSceneByIndex | handle GetSceneByIndex(int index) | Returns the instance of the scene entity at the specified index. | 
CBasePlayer
Extends CBaseAnimating
Methods
| Function | Signature | Description | 
|---|---|---|
| IsNoclipping | bool IsNoclipping() | Returns true if the player is in noclip mode. | 
CBaseMultiplayerPlayer
Extends CBasePlayer
Script handle class for the CS:GO players. No additional methods.
CEnvEntityMaker
Extends CBaseEntity
Script handle class for env_entity_maker.
Methods
| Function | Signature | Description | 
|---|---|---|
| SpawnEntity | void SpawnEntity() | Create an entity at the location of the maker | 
| SpawnEntityAtEntityOrigin | void SpawnEntityAtEntityOrigin(handle entity) | Create an entity at the location of a specified entity instance. | 
| SpawnEntityAtLocation | void SpawnEntityAtLocation(Vector origin, Vector orientation) | Create an entity at a specified location and orientation, orientation is Euler angle in degrees (pitch, yaw, roll). | 
| SpawnEntityAtNamedEntityOrigin | void SpawnEntityAtNamedEntityOrigin(string targetname) | Create an entity at the location of a named entity. If multiple entities have the same name, only the one with the lowest entity index will be targeted. | 
CPointTemplate
Extends CBaseEntity
Script handle class for point_template.
Hooks
- table PreSpawnInstance(string entityClass, string entityName)
- If this is defined, it will be called right before the entity is created, and any keyvalues returned will be assigned to the entity.
function PreSpawnInstance( entityClass, entityName )
{
	local keyvalues =
	{ 
   		rendercolor = "0 255 0",
   		targetname = "mySpawnedEntity"
	}
	return keyvalues
}
- void PostSpawn(table entities)
- Called after the entities are spawned. A table with the handles of the spawned entities indexed by name is passed to the function. Could use this to connect outputs or do whatever needs to be done after the entity was created.
 Note:PostSpawn() will not be called unless the PreSpawnInstance() function is also defined in the script.
Note:PostSpawn() will not be called unless the PreSpawnInstance() function is also defined in the script.function PostSpawn( entities )
{
	foreach( targetname, handle in entities )
	{
		printl( targetname + ": " + handle )
	}
}
Example
Spawned entities can be accessed synchronously in script by using an entity maker. The following generalised example creates a global SpawnMyEntity() function which spawns and returns the templated entity. It can be modified to support multiple templated entities.
m_hSpawnedEntity <- null;
m_KeyValues <- null;
m_hSpawner <- Entities.CreateByClassname( "env_entity_maker" );
m_hSpawner.__KeyValueFromString( "EntityTemplate", self.GetName() );
function PreSpawnInstance( classname, targetname )
{
	return m_KeyValues;
}
function PostSpawn( entities )
{
	foreach ( targetname, entity in entities )
	{
		m_hSpawnedEntity = entity;
		break;
	}
}
::SpawnMyEntity <- function( keyvalues = null )
{
	m_KeyValues = keyvalues;
	m_hSpawner.SpawnEntity();
	return m_hSpawnedEntity;
}.bindenv(this)
Spawn templated entities from any script.
local ent = SpawnMyEntity( {
	rendercolor = Vector( RandomInt(0, 255), RandomInt(0, 255), RandomInt(0, 255) )
} )
printl( ent )
CSceneEntity
Extends CBaseEntity
Methods
| Function | Signature | Description | 
|---|---|---|
| AddBroadcastTeamTarget | void AddBroadcastTeamTarget(int index) | Adds a team (by index) to the broadcast list. | 
| EstimateLength | float EstimateLength() | Returns length of this scene in seconds. | 
| FindNamedEntity | handle FindNamedEntity(string reference) | given an entity reference, such as !target, get actual entity from scene object. | 
| IsPaused | bool IsPaused() | If this scene is currently paused. | 
| IsPlayingBack | bool IsPlayingBack() | If this scene is currently playing. | 
| LoadSceneFromString | bool LoadSceneFromString(string sceneName, string scene) | Given a dummy scene name and a vcd string, load the scene. | 
| RemoveBroadcastTeamTarget | void RemoveBroadcastTeamTarget(int index) | Removes a team (by index) from the broadcast list. | 
CTriggerCamera
Extends CBaseEntity
Methods
| Function | Signature | Description | 
|---|---|---|
| GetFov | int GetFov() | Get cameras current Field Of View setting as integer. | 
| SetFov | void SetFov(int fov, float rate) | Set cameras current FOV in integer degrees and FOV change rate as float. | 
Hooks
| Function | Signature | Description | 
|---|---|---|
| ScriptStartCameraShot | void ScriptStartCameraShot(string shotType, handle sceneEntity, handle actor1, handle actor2, float duration) | Called from SceneEntity in response to a CChoreoEvent::CAMERA sent from a VCD. [Todo] | 
CFuncTrackTrain
Extends CBaseEntity
Methods
| Function | Signature | Description | 
|---|---|---|
| GetFuturePosition | Vector GetFuturePosition(float x, float speed) | Get a position on the track x seconds in the future. | 
CHostage
Extends CBaseEntity
Methods
| Function | Signature | Description | 
|---|---|---|
| IsBeingCarried | bool IsBeingCarried() | Get whether the hostage is currently being carried or not. | 
CGameCoopMissionManager
Extends CBaseEntity
Methods
| Function | Signature | Description | 
|---|---|---|
| GetWaveNumber | int GetWaveNumber() | Get the number of waves the players have completed. | 
CEntities
Script instance: Entities
An interface to find and iterate over the script handles for the entities in play.
To iterate over a set of entities, pass null to the previous argument in the appropriate method to start an iteration, or reference to a previously found entity to continue a search.
The following are two equivalent examples and iterate over all weapons on the map:
| local ent = null;
while ( ent = Entities.FindByClassname(ent, "weapon_*") )
{
  // ...
}
 | for (local ent; ent = Entities.FindByName(ent, "weapon_*"); )
{
  // ...
}
 | 
 Note:
Note:
- The variable name entis arbitrary.
- Indeed, we mean "=" and not "==" in the loop conditions! The loops end if entbecomesnull, which happens when no matching entities have an entity index higher to the one in previous parameter.
- Semicolons are optional, except in the header of the forstatement.
- The string parameters of the FindBy...functions support the wildcard star*. In the above example,FindByClassnameonly returns either a handle of an entity whose classname begins with "weapon_" or it returnsnull.
Methods
| Function | Signature | Description | 
|---|---|---|
| CreateByClassname | handle CreateByClassname(string classname) | Creates an entity by classname with the initial origin (0,0,0). Note:The classname keyvalue of an entity can be manipulated and does not necessarily reflect its code class. Also, there are entities that have a different classname than the one they are created with. | 
| FindByClassname | handle FindByClassname(handle previous, string classname) | Find entities by the value of their classnamekeyvalue. | 
| FindByClassnameNearest | handle FindByClassnameNearest(string class, Vector origin, float radius) | Find the entity by the value of its classnamekeyvalue nearest to the specifiedorigin. | 
| FindByClassnameWithin | handle FindByClassnameWithin(handle previous, string classname, Vector origin, float radius) | Find entities by the value of their classnamekeyvalue within aradiusaround anorigin. | 
| FindByModel | handle FindByModel(handle previous, string modelname) | Find entities by the value of their modelkeyvalue. Tip:Useful to distinguish between entities with an identical classname keyvalue, for example weapon_mp7 and weapon_mp5sd, see Category: CS:GO Weapons. | 
| FindByName | handle FindByName(handle previous, string targetname) | Find entities by the value of their targetnamekeyvalue. | 
| FindByNameNearest | handle FindByNameNearest(string targetname, Vector origin, float radius) | Find entities by the value of their targetnamekeyvalue nearest to a point. | 
| FindByNameWithin | handle FindByNameWithin(handle previous, string targetname, Vector origin, float radius) | Find entities by the value of their targetnamekeyvalue within a radius. | 
| FindByTarget | handle FindByTarget(handle previous, string target) | Find entities by the value of their targetkeyvalue. | 
| FindInSphere | handle FindInSphere(handle previous, Vector origin, float radius) | Find entities within a radiusaround anorigin. | 
| First | handle First() | Returns the first entity, typically worldspawn. Equivalent to Entities.Next(null) | 
| Next | handle Next(handle previous) | At the given reference of a previously-found entity, returns the next one after it in the list. | 
| IsValid | bool IsValid() | Whether the handle belongs to a valid entity. | 
CPlayerVoiceListener
 Warning:Broken! This class is implemented in CS:GO, but the required
Warning:Broken! This class is implemented in CS:GO, but the required PlayerVoiceListener instance is not.
Methods
| Function | Signature | Description | 
|---|---|---|
| GetPlayerSpeechDuration | float GetPlayerSpeechDuration(int playerIndex) | Returns the number of seconds the player has been continuously speaking. | 
| IsPlayerSpeaking | bool IsPlayerSpeaking(int playerIndex) | Returns whether the player specified is speaking. | 
| IsValid | bool IsValid() | Whether the handle belongs to a valid entity. | 
CScriptKeyValues
Script handle representation of a models $keyvalues block. Sub keys are instances of the same class.
Methods
| Function | Signature | Description | 
|---|---|---|
| constructor | ||
| FindKey | CScriptKeyValues FindKey(string key) | Find a sub key by the key name. | 
| GetFirstSubKey | CScriptKeyValues GetFirstSubKey() | Return the first sub key object. | 
| GetKeyBool | bool GetKeyBool(string key) | Return the key value as a bool. | 
| GetKeyFloat | float GetKeyFloat(string key) | Return the key value as a float. | 
| GetKeyInt | int GetKeyInt(string key) | Return the key value as an integer. | 
| GetKeyString | string GetKeyString(string key) | Return the key value as a string. | 
| GetNextKey | CScriptKeyValues GetNextKey() | Return the next neighbor key object to the one the method is called on. | 
| IsKeyEmpty | bool IsKeyEmpty(string key) | Returns true if the named key has no value. | 
| IsValid | bool IsValid() | Whether the handle belongs to a valid key. | 
| ReleaseKeyValues | void ReleaseKeyValues() | Releases the contents of the instance. | 
CCallChainer
CCallChainer objects collect all functions with a matching prefix in a given scope, then inserts it all into the chains table with the prefix removed. All collected unprefixed functions can then be called in a chain using the class's Call() method, given the method's event argument matches the functions' name.
Whenever a CCallChainer object is created, a function named Dispatch followed by its given prefix will also be created, which  the class binds the environment of its Call() method to.
Methods
| Function | Signature | Description | 
|---|---|---|
| constructor | CCallChainer(string functionPrefix, table scope = null) | Creates a CCallChainer object that'll collect functions that have a matching prefix in the given scope. | 
| PostScriptExecute | void PostScriptExecute() | Search for all non-native functions with matching prefixes, then push them into the chainstable. | 
| Call | bool Call(string event, any ...) | Find an unprefixed function name in the chainstable and call it with the given arguments. | 
Members
| Instance | Type | Description | 
|---|---|---|
| chains | table | Contains names of unprefixed functions, each with an array of functions to call. | 
| prefix | string | Prefix that functions should have to be added into the chainstable. Set by the constructor. | 
| scope | table | If set, seek functions in this scope instead. Set by the constructor. | 
CSimpleCallChainer
Intended to be simpler to use than CCallChainer, the class CSimpleCallChainer holds only a single chain of functions inside an array instead of multiple inside a table. As such, its Call() method does not need a function's name.
This class is also used internally by these CBaseEntity hooks: Precache() and OnPostSpawn().
Methods
| Function | Signature | Description | 
|---|---|---|
| constructor | CSimpleCallChainer(string functionPrefix, table scope = null, exactMatch = false) | Creates a CSimpleCallChainer object that'll collect functions that have a matching prefix in the given scope, unless it seek for an exact name match. | 
| PostScriptExecute | void PostScriptExecute() | Begin searching for all non-native functions with matching prefixes, then push them into the chainarray. | 
| Call | bool Call(any ...) | Call all functions inside the chainarray with the given arguments. | 
Members
| Instance | Type | Description | 
|---|---|---|
| chain | array | All functions to be called by the Call()method. | 
| exactMatch | bool | If set, names of non-native functions and prefixmust be an exact match.  Set by the constructor. | 
| prefix | string | Prefix that functions should have to be added into the chainarray. Set by the constructor. | 
| scope | table | If set, seek functions in this scope instead. Set by the constructor. | 
LateBinder
Late binding: allows a table to refer to parts of itself, it's children, it's owner, and then have the references fixed up after it's fully parsed.
// Usage:
lateBinder <- LateBinder();
lateBinder.Begin( this );
Test1 <-
{   
   Foo=1
}   
Test2 <-
{   
   FooFoo = "I'm foo foo"
   BarBar="@Test1.Foo"
   SubTable = { boo=[bah, "@Test2.FooFoo", "@Test1.Foo"], booboo2={one=bah, two="@Test2.FooFoo", three="@Test1.Foo"} }
   booboo=[bah, "@Test2.FooFoo", "@Test1.Foo"]
   booboo2={one=bah, two="@Test2.FooFoo", three="@Test1.Foo"}
   bah=wha
}   
lateBinder.End();
delete lateBinder;
When End() is called, all of the unresolved symbols in the tables and arrays will be resolved, any left unresolved will become a string prepended with '~', which later code can deal with.
Methods
| Function | Signature | Description | 
|---|---|---|
| Begin | ||
| End | ||
| EstablishDelegation | ||
| HookRootMetamethod | ||
| Log | ||
| m_bindNamesStack | ||
| m_fixupSet | ||
| m_log | ||
| m_logIndent | ||
| m_targetTable | ||
| RemoveDelegation | ||
| Resolve | ||
| UnhookRootMetamethod | 
regexp
The built-in Squirrel class for regular expressions.
Methods
| Function | Signature | Description | 
|---|---|---|
| constructor | regexp() | |
| capture |  [table] capture(str, [start]) | Returns an array of tables containing two indexes("begin" and "end")of the first match of the regular expression in the string str. An array entry is created for each captured sub expressions. If no match occurs returns null. The search starts from the index start of the string, if start is omitted the search starts from the beginning of the string. | 
| match | bool match(str) | Returns a true if the regular expression matches the string str, otherwise returns false. | 
| search | table search(str, [start]) | Returns a table containing two indexes("begin" and "end") of the first match of the regular expression in the string str, otherwise if no match occurs returns null. The search starts from the index start of the string, if start is omitted the search starts from the beginning of the string. | 
| subexpcount | 
Vector
Squirrel equivalent of the C++ Vector class.
Three-dimensional vector.
Has overloaded operations for the following:
Vector * number
Vector + Vector
Vector - Vector
Methods
| Function | Signature | Description | 
|---|---|---|
| constructor | Vector(float x = 0, float y = 0, float z = 0) | Creates a new vector with the specified Cartesian coordiantes. | 
| Cross | float Cross(Vector factor) | The vector product of two vectors. Returns a vector orthogonal to the input vectors. | 
| Dot | float Dot(Vector factor) | The scalar product of two vectors. | 
| Length | float Length() | Length of the vector. | 
| LengthSqr | float LengthSqr() | Length of the vector squared. Cheaper than the above method. | 
| Length2D | float Length2D() | Returns the length of the vector on the x-y plane. | 
| Length2DSqr | float Length2DSqr() | Returns the square of the length of the vector on the x-y plane. Cheaper than the above method. | 
| Norm | float Norm() | Normalises the vector, returns the vector length. | 
| ToKVString | string ToKVString() | Returns a string without separations commas. | 
Members
| Instance | Type | Description | 
|---|---|---|
| x | float | Cartesian X axis. | 
| y | float | Cartesian Y axis. | 
| z | float | Cartesian Z axis. | 
Global functions
Printing and drawing
| Function | Signature | Description | 
|---|---|---|
| DebugDrawBox | void DebugDrawBox(vector origin, vector mins, vector maxs, int r, int g, int b, int alpha, float duration) | Draw a debug overlay box in the specified color for the specified duration with two corners being origin + minsandorigin + maxs. Thealphais the fill rate (0-255). Set duration to 0 if drawn every tick. | 
| DebugDrawBoxAngles | void DebugDrawBoxAngles(Vector origin, Vector mins, Vector maxs, Vector angles, int r, int g, int b, int alpha, float duration) | Draw a debug overlay box with angles in the specified color for the specified duration with two corners being origin + minsandorigin + maxs+angles. Thealphais the fill rate (0-255). Set duration to 0 if drawn every tick. | 
| DebugDrawLine | void DebugDrawLine(Vector start, Vector end, int r, int g, int b, bool noDepthTest, float duration) | Draw a debug line between the points startandendin the specified color for the specified duration. Set duration to 0 if drawn every tick. | 
| Msg | void Msg(string message) | Equivalent to print | 
| print | void print(string message) | Prints the given message to the developer console. | 
| printl | void printl(string message) | Prints the given message to the developer console with newline. Equivalent to print(message + "\n") | 
| ScriptPrintMessageCenterAll | void ScriptPrintMessageCenterAll(string message) | Prints an alert message in the center of the screen to all players. | 
| ScriptPrintMessageCenterAllWithParams | void ScriptPrintMessageCenterAllWithParams(string message, string param1, string param2, string param3) | Prints an alert message in the center print method to all players. Needs to pass token/message. | 
| ScriptPrintMessageCenterTeam | void ScriptPrintMessageCenterTeam(int, string) | Prints an alert message in the center of the screen to the specified team. 
  Warning:Game crashes for other team numbers! | 
| ScriptPrintMessageChatAll | void ScriptPrintMessageChatAll(string message) | Prints a message in chat to all players. | 
| ScriptPrintMessageChatTeam | void ScriptPrintMessageChatTeam(int team, string message) | Prints a message in chat to the specified team.  Warning:Game crashes for other team numbers than the above! | 
| ShowMessage | void ShowMessage(string) | Print a hud message on all clients.  Note:Uses localized strings as found in /scripts/titles.txt | 
| __DumpScope | void __DumpScope(int indentation, table scope) | Dumps the contents of scope. | 
Training Course
| Function | Signature | Description | 
|---|---|---|
| ScriptGetBestTrainingCourseTime | int ScriptGetBestTrainingCourseTime() | Gets the player's best time for completing the timed course. | 
| ScriptGetPlayerCompletedTraining | bool ScriptGetPlayerCompletedTraining() | Returns true if the player has completed the initial portion of the training map. | 
| ScriptGetValveTrainingCourseTime | int ScriptGetValveTrainingCourseTime() | Gets Valve's best time for completing the timed course. | 
| ScriptHighlightAmmoCounter | void ScriptHighlightAmmoCounter() | Sends an event that is just used by the instructor system to show a hint highlighting the ammo counter. | 
| ScriptSetBestTrainingCourseTime | void ScriptSetBestTrainingCourseTime(int time) | Sets the player's best time for completing the timed course. | 
| ScriptSetMiniScoreHidden | void ScriptSetMiniScoreHidden(bool hide) | Toggles the visibility of the miniscoreboard hud element. | 
| ScriptSetPlayerCompletedTraining | void ScriptSetPlayerCompletedTraining(bool completed) | Sets whether the player has completed the initial portion of the training map. | 
| ScriptSetRadarHidden | void ScriptSetRadarHidden(bool hide) | Toggles the visibility of the radar hud element. | 
| ScriptShowExitDoorMsg | void ScriptShowExitDoorMsg() | Shows a message box in trainign when the player exits through the exit door | 
| ScriptShowFinishMsgBox | void ScriptShowFinishMsgBox() | Shows a message box to let players know what to do next after finishing the training course. | 
| ScriptTrainingGivePlayerAmmo | void ScriptTrainingGivePlayerAmmo() | Refills ammo to max for all weapons the player has (only works in training). | 
Co-op Strike
| Function | Signature | Description | 
|---|---|---|
| ScriptCoopCollectBonusCoin | void ScriptCoopCollectBonusCoin() | Marks one of the bonus coins as collected. | 
| ScriptCoopGiveC4sToCTs | void ScriptCoopGiveC4sToCTs(int) | Will give the number of specified C4s to all alive CT players. | 
| ScriptCoopMissionGetMissionNumber | int ScriptCoopMissionGetMissionNumber() | Gets the mission number for the current map - maps can have multiple missions on them. | 
| ScriptCoopMissionRespawnDeadPlayers | void ScriptCoopMissionRespawnDeadPlayers() | Respawns players only. | 
| ScriptCoopMissionSetDeadPlayerRespawnEnabled | void ScriptCoopMissionSetDeadPlayerRespawnEnabled(bool) | Controls whether player respawns can happen. | 
| ScriptCoopMissionSetNextRespawnIn | void ScriptCoopMissionSetNextRespawnIn(float, bool) | Set the next respawn wave to happen in this many seconds. | 
| ScriptCoopMissionSpawnFirstEnemies | void ScriptCoopMissionSpawnFirstEnemies(int) | Spawns the first wave of enemies in coop. | 
| ScriptCoopMissionSpawnNextWave | void ScriptCoopMissionSpawnNextWave(int) | Tells the next wave of enemies to spawn in coop. Also respawns player. | 
| ScriptCoopResetRoundStartTime | void ScriptCoopResetRoundStartTime() | Resets the round time and starts the mission. | 
| ScriptCoopSetBotQuotaAndRefreshSpawns | void ScriptCoopSetBotQuotaAndRefreshSpawns(int) | Sets the bot quota considering the # of players connected and refreshes the spawns. | 
| ScriptCoopExtendRoundDurationTime | void ScriptCoopExtendRoundDurationTime(float) | Extends the round time after checkpoint during the mission. | 
| ScriptCoopToggleEntityOutlineHighlights | void ScriptCoopToggleEntityOutlineHighlights(bool) | Highlights all dropped weapons for players, or removes all highlights. | 
| ScriptMissionResetDangerZones | void ScriptMissionResetDangerZones() | Resets all danger zone entities. | 
| ScriptMissionCreateAndDetonateDangerZone | void ScriptMissionCreateAndDetonateDangerZone(Vector, Vector) | Creates and detonates a danger zone at the given location moving towards target location. | 
Premier Mode
| Function | Signature | Description | 
|---|---|---|
| ScriptLobbyMapVetoFinished | void ScriptLobbyMapVetoFinished(string mapname, bool, bool, string) | Switch to the selected map after lobby map veto finished. | 
Math
The built-in Squirrel math library.
| Function | Signature | Description | 
|---|---|---|
| abs |  int abs(float x) | Returns the absolute value of xas an integer. | 
| acos |  float acos(float x) | Returns the arccosine of x. | 
| asin |  float asin(float x) | Returns the arcsine of x. | 
| atan |  float atan(float x) | Returns the arctangent of x. | 
| atan2 |  float atan2(float x, float y) | Returns the arctangent of x/y. | 
| ceil |  float ceil(float x) | Returns a float value representing the smallest integer that is greater than or equal to x. | 
| cos |  float cos(float x) | Returns the cosine of x. | 
| exp |  float exp(float x) | Returns the exponential value ( e^x) of the float parameterx. | 
| fabs |  float fabs(float x) | Returns the absolute value of xas a float. | 
| floor |  float floor(float x) | Returns a float value representing the largest integer that is less than or equal to x. | 
| log |  float log(float x) | Returns the natural logarithm of x. | 
| log10 |  float log10(float x) | Returns the logarithm base-10 of x. | 
| pow |  float pow(float x, float y) | Returns xraised to the power ofy. | 
| rand |  int rand() | Returns a pseudorandom integer in the range 0 to RAND_MAX. | 
| sin |  float sin(float x) | Returns the sine of x. | 
| sqrt |  float sqrt(float x) | Returns the square root of x. | 
| srand |  void srand(float seed) | Sets the starting point for generating a series of pseudorandom integers. | 
| tan |  float tan(float x) | Returns the tangent of x. | 
Other
| Function | Signature | Description | 
|---|---|---|
| Assert | void Assert(exp, string message = null) | Throws an exception if exp equates to false, optionally with message. | 
| CreateProp | handle CreateProp(string classname, Vector origin, string model, int animation) | Create a prop with the specified class and model. Both prop_physics, prop_dynamic as well as some other entity classes with models work. Does not precache the model. | 
| CreateSceneEntity | CSceneEntity CreateSceneEntity(string scene) | Create a scene entity to play the specified scene .vcd file. | 
| DispatchParticleEffect | void DispatchParticleEffect(string particle, Vector position, Vector orientation) | Dispatches a one-off particle system. See List of CS:GO Particles. Does not work if the particle is not precached.[How?]  Note:Looped animations will stay until the round is reset. | 
| DoIncludeScript | bool DoIncludeScript(string filename, table scope) | Execute the script file "csgo/scripts/vscripts/" + filenamein the scope ofscope. The extension.nutcan be omitted. Returns true if the script was found and executed, otherwise false. | 
| IncludeScript | bool IncludeScript(string filename, table scope = null) | Execute the script file "csgo/scripts/vscripts/" + filenamein the scope ofscope,thisby default. The extension.nutcan be omitted. Returns true if the script was found and executed, otherwise false. | 
| DoEntFire | void DoEntFire(string target, string action, string value, float delay, handle activator, handle caller) | Generate an entity I/O event. | 
| EntFire | void EntFire(string target, string action, string value = "", float delay = 0.0, handle activator = null) | Generate an entity I/O event. | 
| EntFireByHandle | void EntFireByHandle(handle target, string action, string value, float delay, handle activator, handle caller) | Generate an entity I/O event. | 
| FrameTime | float FrameTime() | Get the time spent on the server in the last frame. | 
| GetDeveloperLevel | int GetDeveloperLevel() | Gets the level of the developer mode. Equivalent to developer(). | 
| GetMapName | string GetMapName() | Get the name of the map, e.g. "de_dust2". | 
| LoopSinglePlayerMaps | bool LoopSinglePlayerMaps() | Returns the boolean value of the ConVar loopsingleplayermaps, i.e. whether the single player maps are run in a continuous loop. | 
| PrintHelp | void PrintHelp(string string = "*", bool exact = false) | Output help for script functions, optionally with a search string. | 
| RandomFloat | float RandomFloat(float min, float max) | Generate a random floating point number within a range, inclusive. | 
| RandomInt | int RandomInt(int min, int max) | Generate a random integer within a range, inclusive. | 
| RecordAchievementEvent | void RecordAchievementEvent(string, int) | Records achievement event or progress. | 
| RetrieveNativeSignature | void RetrieveNativeSignature(string nativeFunction) | [Todo] | 
| ScriptGetGameMode | int ScriptGetGameMode() | Gets the current game mode. | 
| ScriptGetGameType | int ScriptGetGameType() | Gets the current game type. | 
| ScriptGetRoundsPlayed | int ScriptGetRoundsPlayed() | Get the number of rounds that any team has won so far.  Warning: Drawn rounds are not counted, except they were ended using a game_round_end entity. | 
| ScriptIsLocalPlayerUsingController | bool ScriptIsLocalPlayerUsingController() | Returns whether the player is playing with a controller or not. | 
| ScriptIsWarmupPeriod | bool ScriptIsWarmupPeriod() | Is it warmup or not. | 
| SendToConsole | void SendToConsole(string command) | Send a string to the console as a client command. The command is executed through the local player or listen server host. If no player is found, this function will only print the developer message Cannot execute "<command>", no playerin the console. | 
| SendToConsoleServer | void SendToConsoleServer(string command) | Send a string that gets executed on the server as a ServerCommand using whitelistcmd. Commands or ConVars that are not whitelisted are not executed or changed. | 
| Time | float Time() | Get the current server time in seconds. | 
| TraceLine | float TraceLine(Vector start, Vector end, handle ignore) | Given 2 points and an entity to ignore, returns fraction along line that only hits world. | 
| TraceLinePlayersIncluded | float TraceLinePlayersIncluded(Vector start, Vector end, handle ignore) | Given 2 points and entity to ignore, returns fraction along line that hits world, models, players and NPCs.  Note: Blocking entities are not limited to player, almost everything will block it. | 
| UniqueString | string UniqueString(string suffix = "") | Generate a string guaranteed to be unique across the life of the script VM, with an optional root string. Useful for adding data to tables when not sure what keys are already in use in that table. Equivalent to DoUniqueString(suffix). | 
| DoUniqueString | string DoUniqueString(string suffix) | Generate a string guaranteed to be unique across the life of the script VM, with an optional root string. Useful for adding data to tables when not sure what keys are already in use in that table. | 
| __ReplaceClosures | void __ReplaceClosures(function script, table scope) | Internal function called in script_reload_server commands. | 
See also
- VScript
- VScript Fundamentals
- Listening to game events
 Squirrel Squirrel
 VScript Examples VScript Examples
 Left 4 Dead 2/Script Functions Left 4 Dead 2/Script Functions
 List of Portal 2 Script Functions List of Portal 2 Script Functions
 List of Team Fortress 2 Script Functions List of Team Fortress 2 Script Functions
| 
 | ||||||||||||||||






























