Table of Contents

  1. Learning the Basics
    1. Data Types
    2. Variables
    3. Functions
      1. Passing Data Types
    4. Logical Operations
      1. Logical Operators
      2. Logical Tips
    5. Arrays
    6. Loops
      1. Loop Manipulation
      2. Notify, Endon
    7. Conclusion

Learning the Basics

Data Types

Term Definition Example
Int aka Integer An int is exactly what it is in math, a whole number. 1, 52, 97, 4
Float A float is another number, but unlike an int it has decimals 5.17549435, 6.57549836
String A string is a set or single character that you can make up a word "this is a string", "321 String", "strings are cool :)"
Boolean A boolean is a true (same as 1) or false (same as 0) 1, false, 0
Array An array isn't really a data type but it belongs in this section anyway. An array is a collection of a data type. Arrays are a bit confusing to understand and will have a dedicated section. They are essential!
Comments A comment definitely isn't a data type but it belongs in this section anyway. Comments are lines in code starting with // that are not read by the compiler. Use these to make notes to yourself in script. // this is a comment

Using Data Types to Make Variables

Defining variables correctly is very simple, but in order to define variables correctly you must understand how code executes. I will break down varibles into 2 types:

Term Definition Example
Local Variable a variable that can only be referenced in a function aka locally(more about functions in a second) teddys_to_shoot = 3;
Global Variable a variable that can be called anywhere in a script or even other scripts level.teddys_to_shoot = 3;

Note the difference between a local and a global variable. Notice the local variable does not have a 'level.' in front of it. Defining a variable on the "level" allows for it to be referenced anywhere in script. Also note that variable definitions end with a ';'. A ';' tells the compiler to stop reading and start reading again. This is the most common mistake of new programmers. If you ever get an error like "unexpected paranthesis" or "unexpected ." this is a tell tale sign of a missing ';'.

IMPORTANT: some variables may be considered an "ent" or "entity". You need to understand the idea of an entity early or you will run into a "g_spawn" error. An ent is a spawned script_model or a script_model placed in radiant. Any type of animated model or manipulated model in script is an ent. ALWAYS delete an ent after you are done using it with the syntax: ent delete(); where ent is the entity variable.

NOTE: In WaW triggers also act as entities, but this is no longer the case for Bo3. Triggers will be covered in a new wiki section on level manipulation. You should always treat a trigger as an ent regardless of the game you are coding.

Using Variables to Make Functions

Now that we understand how data types make up variables, it is time to make up a function out of variables but first lets learn some more terms.

Term Definition Example
function a function can be defined as 2 things, an identifier used in a function definition or a set of repeatable instructions function example_function()
arguments data types that can be passed into a function. Know that the only way data types can be transfered into a function are through the use of self and function arguments. This will be explained in the next section. function example_function( argument1, argument2 )
engine function these are predefined functions written in gsc code. A list of engine functions and their functionality is listed in the provided documents for the mod tools. iprintlnbold( "This message will be shown on screen!" );
brace these are braces { }. any function statement or logical statement needs braces to enclose its set of operations. Logical statements will be covered in another section.

Here is a simple example of a function (This function would work in BO3 but not in WaW. I will explain further in a minute.)

In the above example we first define a function by writing 'function' in front of the function name. Then we name our function example_function(). This function has no arguments that need to be passed into it. Then we utilize an engine function to print text to a screen; then we define our local variable; and then we conclude the function with an additional engine function and a closing brace

Open bo3_scriptapifunctions.htm (located in the steamapps\common\Call of Duty Black Ops III\docs_modtools folder) in your web browser to read what each function does. Here is a copy and paste example of "iprintlnbold" used in the above example:

Using Functions to Their Fullest Potential: Passing Data Types and self

Early I mentioned passing data types and information to a function through the use of self and arguments. In order to utilize a function to its fullest potential we need to understand how to pass information and data to a function, and it is important to interpret the data we are sharing and receiving. Check out these terms so they can be further understood in an example.

Term Definition Example
function definition this is how a function is defined. A function definition will contain the word "function" then the function name, followed by ( ) containing arguments seperated by commas. Function definitions are specific to Bo3. function example_function()
return this is an operator that does exactly what it sounds like it does; it returns a data type. Returns can be manipulated or used in a few ways and will be discussed in another section

Now that we understand some more terms let's take a look at another example:

This is an example we can all relate to, so this shouldn't be too hard to understand. When scripting there is always a "main" function, and in some languages the "main" function has to actually be named "main" for the code to work. So in this main function we are accomplishing some averaging of your 3 exam grades. We use arguments and pass them to the function "take_an_average_of_3". If we look at said function, we see in its function definition that it wants 3 arguments: num1, num2, and num3. It then takes those arguments and adds them together; then divides by 3. Then we return the average. Notice that you can return a data type to a string using the +variable_name after you right the string in iprintlnbold. This is very useful to know!

Now lets take a look at a similar example but with a new concept: the idea of self. Notice how the function is different!

This example is the heart of 'object oriented' programming. Let's explain what happened differently here than in the previous example.

In this example we used an engine function to get the host of the game. Then we called the function "take_an_average_of_3" on the host player (I know we don't take exams in COD, but let's pretend haha). Now the host player is running the function "take_an_average_of_3". Because the host is running the function, the host is *self* inside the function. Remember when we defined a global variable "level.teddys_to_shoot" at the beginning of the wiki? Now we are defining a variable on the player entity (the host player). "self.average_of_nums" is a new variable stored under the host player just like we did on the level. As long as the host player exists, aka is defined, you can always reference this variable. Take a Second to Think: This is why a level.variable is considered "global" because the level is always defined.

That might seem like a lot to take in, but re-read that above paragraph. It is REALLY important to understand.

Logical Statements and Logical Operators: if, else if, else

Logical statements are the most crucial part of interpretting data in functions. It is never enough to just have variables in a function and that's it. If you find yourself saying, "I want this to happen if this is true" then you need logical statements. We can use logical operators to further narrow down and interpret our data from the game. Before we start learning let's learn some more terms again.

Term Definition
if an if statement checks "if" the statement inside the ( ) is either true or false
else if this is always used after an if or an else if. This checks another statement if the previous if or else if is not true
else I like to think of an else statement as "if all else is false then do this". Like the else if and else needs to be after an if or an else if statement

Let's look at the exam average example again with some more tweaks:

Like before we are getting the hosts average exam grades, but now we are checking if the host has passed. We check the hosts average exam grade against a score of 70. If it is greater than or equal to 70 we print to screen that the host has passed. else if it is less than 70 we print that the host has failed. Note that only one of those logical operations will run on the host: whichever one is true first.

Knowing How Logical Statements are Evaluated: logical operators ( &&, ||, <, >, ==, ! )

Logical statements check for a boolean which we defined earlier as a true or 1, false or 0. Logical Statements can also run functions inside them to check for a boolean. Logical statements are manipulated and evaluated by several logical operators. The main ones are listed below:

Operator Description
&& this is an "and" operator. This will link two conditions that need to *both* be true in order to execute logical code
|| this is an "or" operator. This will link 2 conditions, and if either of them are true, the logical code will execute
== this is the "is equal to" operator.
< and > less than and greater than, alternatively could be <= or >= for less than or equal to and vice versa
++, --, += value This is the increment by 1, decremennt by 1, increment by value. This is used mostly in for loops which will be discussed later.
! the "not" operator. I use this one A LOT. Some also call it an "invert operator". What it does is inverts the evaluated statement or inverts the operator.

Check out the following embedded code with its comments to see examples of each logical operator

Some Pro-Tips for Speed with Logical Statements

You will notice scripters are lazy. We don't like to type. Hell typing this wiki is killing me haha, but to get to the point there is a faster way to check if something is true or false. Take a look at the code below:

Notice that there are a few interesting things about the above code: a) the lack of braces after the logical statement and b) that there are is no == operator. I am returning the value of true_variable and false_variable in the logical statement and checking if that value is 1 or 0 aka true or false. Also braces are not needed in a logical statement if the code below it is only 1 line. To help you understand further the code is rewritten below to do the same exact thing:

You can see the first block of code was much faster and cleaner to write. Chances are you are not getting paid to code, so use whichever code you find easiest to remember or understand.

Note: This is a friendly reminder to use comments (// comments). Your code might make sense to your today but maybe not tomorrow!

Arrays: The fastest way to store a family of Data Types

Sometimes you will find that you are making a family of variables that are very similar. This would be a tell tale sign to use arrays. Arrays are used A LOT by me and 3arc. Most people shy away from them at first because they seem scary, but trust me they are your best friend. We will take a look at the all too familiar shootable teddy bear for a song example.


Lets start slow and talk about an array's index. An index can be an integer or a string. The advantage of a string index is that it can be directly referred. I use string indices when I make buildables because I may want to call a specific part from the array. The advantage of integer indices is that they are easily looped through in a for loop. Strings can also be looped through but it is a bit more complex. Lets show examples of an integer index VS a string index:

Notice that for an integer indexed array, that the array starts are the integer 0. So the 8th element would be index 7. It is confusing at first, but it is the way things are done in almost every scripting language.

Now let's look at a string index. I will use an example that is not exact to Treyarch code, but is familiar.

The code above is doing nothing really but it helps you understand that the array "powerups" is made up of 2 elements: "full_ammo" which is equal to the string "Max ammo", and "nuke" which is equal to the string "Nuke".

When it comes down to it, you are going to have to study arrays. When I first learned to script I spent a lot of time reading 3arc scripts with limited guidance. This section well help you understand what an array is and what an index is, but the fine details you will need to study and practice. Take a look at the engine function GetArrayKeys to further understand how to loop through a string index as if it were an integer index.

Loops: Probably the most important part of coding

Loops are used to do the same operation (aka execute the same code) several times. You can do something forever, do something until something is true or false, or do something for a few times. If you don't wrap your head around loops and how to use them, you probably wont be able to code very much of anything so be sure to listen up. These are the most common loops:

Loop Type Description
for This loop will execute a set number of times. It is best used when working with arrays.
while This loop executes as long as the logical statement inside it is either true or 1. This is best used with logical statements

Now lets take a closer look at these loops.

The 'for' Loop

The foor loop needs 3 inputs to work: a definition, a check, and an operation. Take a look at this example and I will explain:

The above code defines the variable i as equal to 0, then the code contained by the braces of the for loop will execute, then we increment i by 1, then we check if i is less than 10, and if it is we do the same thing again. Note that this code will execute 10 times. For each time through I will list the values of i: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9. Notice i never equals 10 because the index starts at 0.

The 'while' Loop

The while loop happens as long as the statement inside the ( ) is true. Note that in GSC you need to have a wait statement or you will ruin your script. In COD WaW you will get a lag spike if you forgot the wait statement. In bo3 you will get "Connection Interupted". Check out the example below:

In the above example the code inside the ( ) of the while is always true, therefore it will go on forever unless we break out or endon a notify, which I will discuss later. Note that the code above is printing how many times the loop executed to screen, and each execution takes 0.05 seconds. The user will never be able to read this, but this is just so you understand how while loop works. Lets do another while loop example:

In the above example the we are checking if the host player is on a slide. If he is we are spamming the screen with a message saying that the player is sliding.

Loop Manipulation: notify, endon, continue, break, and return

I think I struggled understanding this the most when I first learned to code, so don't feel bad if you revisit this section a few times to understand yourself. I will briefly explain how each of the statements/instructions can help you manipulate a loop:

Instruction Description
continue This term may appear a counter intuitive statement. You would think continue means move forward but it actually means "skip". A continue statement inside a loop ( either for or while ) will shoot you the execution back to the top of the loop. If it is a for loop it will increment the i variable and start the next iteration.
return Returns are interesting because they have two functions a) they can return a value and b) they can stop a function from running any further. Functions stop and return a value when a return is read in code.
break A break statement will only ever break a loop. Note that this is different than a return because a return breaks the loop and the function. Breaks are often useful if you just want a certain piece of information from a function or if you want to break out of the function to do something more important.
notify Notifies are another way to break a loop by pairing it with an endon. These are so useful that I will talk about them in the next section.

To further understand this statement/instructions check out the following examples:

Notify and Its Dependents: Endon & Waittill

Notifies are exactly as they sound; they are a notification. So imagine your phone notifying you that a message has been received. This would happen with a beep and a visual on your phone, but in script a notify is sent by a string.

How Do You Use a Notify?

Engine Notfies

Some notifies are automatically scripted into the game. Some of these notifies include: "death", "intermission", "all_players_connected", "trigger", and "projectile_impact". If I ever manage to get a list of engine notifies I will include them in a seperate section of the Wiki. It is also worth noting that some notifies can also pass variables. An example is notfiy( "death", attacker );

Custom Notifies

You will often times want to make your own notifications through script. Notifies are passed onto either the level or an ent.

How to Take Advantage of a Notification

As usual we are going to learn some terms before we continue

Term Description
endon this kills a function on the line of execution. You will often be running multiple functions at once, but one function may be dependent on the execution of the other. Passing a notify to an ent and using and endon can kill the dependent function
waittill this does exactly as it sounds. A waittill waits until it receives the exact string notification you place in it. Waittills can also pass through variables as I stated earlier when I said notifies can pass variables.

The best way to understand how to use a notify is through example, so lets take a look at an example of a situation where you might want to use a notify on a player to get blood splatter to show on screen:

Lets take a look at a few things here. Note how this is an infinite loop. Whenever you have an infinite loop it is best practice to have something that can end that loop, whether it be a break, return, or endon. So notice this function will quit running when the player ( *self* in this example ) dies. Also note that the player ent is always waiting for a notification to splatter blood on screen.

Important: remember that every while loop needs some sort of wait statement. In this example it is a waittill statement.


This concludes the very basic scripting syntaxes you will come across in GSC. I recommend that at this point you try reading some of the provided scripts in BO3. Pick a script that you can remember how it works in games, such as the dog round script, and read through it. You should be able to make sense of what is happening at this point. If it is still confusing refer back to this wiki or pop in chat to ask some more experienced modders. In order to understand you must study the work of others. Best of luck studying. Keep a lookout for additional sections of the wiki on this site.