BSL:Tutorial/Scratch: Difference between revisions

removing syntax section that was inaccurate and is now addressed by BSL:Manual; correcting wiki markup
m (cat added)
(removing syntax section that was inaccurate and is now addressed by BSL:Manual; correcting wiki markup)
Line 1: Line 1:
This page is a short tutorial on how to get started on simple scripts for those who have had no experience with scripting before.
This page is a short tutorial on how to get started on simple scripts for those who have had no experience with scripting before. It will teach you, step by step, how to write a simple script. By the end of this tutorial, you will be able to move on to more advanced scripts.
It will teach you, step by step, how to write a simple script. By the end of this tutorial, you will be able to move on to more advanced scripts.
{{TOClimit|2}}
 
==Starting off==
 
----
 
== Part 1 : Knowing your formats ==
 
The game will accept 2 types of syntax for scripts, and they are based on different styles of writing. Choose the one that suits you best.
 
The types are :
 
'''Shell-Style''':
This is compiled much like some System-Shells. It is written in a "one-function-call-a-line" format, and is the easiest to begin with if you have had no coding experience, as the code is neatly displayed line after line. The downside of this it, that once you get into more complex scripts or scripts with many function calls, the file becomes very hard to read and very large. Also, an great tool, passing information through a command, cannot be done using Shell-Style.
 
Example:
 
func p2
{
ai2_doalarm muro1 11
fork follow
ai2_spawn tarmac_striker_3
ai2_spawn cruel_striker1
ai2_spawn Hangar1_A_Striker_3
ai2_spawn Start_Striker_5
ai2_spawn Roof2_Striker_1
ai2_spawn Hangar1_B_Striker_5
chr_teleport tarmac_striker_3 199
chr_teleport cruel_striker1 200
chr_teleport Hangar1_A_Striker_3 108
chr_teleport Start_Striker_5 109
chr_teleport Roof2_Striker_1 110
chr_teleport Hangar1_B_Striker_5 117
ai2_attack tarmac_striker_3 muro1
ai2_attack cruel_striker1 muro1
ai2_attack Hangar1_A_Striker_3 muro1
ai2_attack Start_Striker_5 muro1
ai2_attack Roof2_Striker_1 0
ai2_attack Hangar1_B_Striker_5 0
}
 
'''C-Style''':
This is compiled much like the popular coding style C. The syntax can be placed into multiple-function lines and functions are divided by a ''';''' . In advanced scripts, this style will allow you to condense your script and the parts will be easier to read/debug. It also allows you to utilize some of the more advanced features easily. The problem with this is, that starting off, it is harder to write if you have had no previous experience with coding.
 
Example:
func void AddNeutralTeam(void) {
AddPlayer(Neutral, lobby_victim, "[o.Citizen Snips]"); sleep 150;
AddPlayer(Neutral, a_v4, "[y.Citizen Jones]"); sleep 150;
AddPlayer(Neutral, a_v1, "[b.Citizen Jane]"); sleep 150;
dmsg("[r.SHINATAMA'S] team complete");
}
 
'''Hybrid Style''':
This is a combination between C-Style and Shell-Stlye. It keeps the easy-to-read format of Shell-Style, yet allows you to use the more advanced techniques of C-Style.
 
For the purpose of this article, we will use Shell-Style syntax for simplicity.
 
 
----
 
== Part 2: Starting Off ==
 
Now, I suggest reading the original script files to get a basic idea for how scripts are laid out. This will allow us to jump-start a bit.
 
Open up your IGMD and look for the following folder: EnvWarehouse.
Open up your IGMD and look for the following folder: EnvWarehouse.
Open it up, and we'll take a look at how it it laid out. There should be several files in here. Open using NOTEPAD, the one titled '''warehouse_main.bsl'''. It should look like this:
Open it up, and we'll take a look at how it it laid out. There should be several files in here. Open using NOTEPAD, the one titled '''warehouse_main.bsl'''. It should look like this:
Line 84: Line 23:
Close the file, and rename the folder "EnvWarehouse" "EnvWarehouse_original". Then, create a folder called "EnvWarehouse" and create a script file inside and name it "Tutorial". We will be using this file to show various examples of scripts and finally, write a small script of your own.
Close the file, and rename the folder "EnvWarehouse" "EnvWarehouse_original". Then, create a folder called "EnvWarehouse" and create a script file inside and name it "Tutorial". We will be using this file to show various examples of scripts and finally, write a small script of your own.


Each command in this tutorial should have a link behind it the first time it's used in some sample BSL. Click that link to learn more about the command, or for a complete list of commands, see [[BSL:Reference]].


----
==First script==
 
== Part 3: Basic Commands ==
 
This is just a small section explaining the commands that will be used in this tutorial. For a complete list of commands, see [http://ssg.oni2.net/commands.htm ssg's site] for more information.
 
ai2_spawn (name) - creates and starts an AI from a character object<br>
chr_teleport (name) (flag) - teleports a character to a flag<br>
chr_givepowerup (name) (powerup) (amount) - gives a character a powerup<br>
.
.
.
 
 
----
 
== Part 4: First Script ==
 
This section will teach you how to write a very basic script (fighting script). It will start you off in the Final Training Room, where you practiced firing weapons in the original game. With this script, the room will appear very empty.
This section will teach you how to write a very basic script (fighting script). It will start you off in the Final Training Room, where you practiced firing weapons in the original game. With this script, the room will appear very empty.


Line 117: Line 40:
It should look like this:
It should look like this:


<tt>func void main(void)<br>
func void main(void)
{<br>
{
chr_teleport 0 7010<br>
    [[chr_teleport]] 0 7010
}</tt>
}
 


Save the file, load up Oni, and click "New Game". You should be standing in the center of the final combat training room.
Save the file, load up Oni, and click "New Game". You should be standing in the center of the final combat training room.
Line 127: Line 49:
You are now on your way!
You are now on your way!


 
==Adding NPCs (AIs)==
----
 
== Part 5: Adding NPCs (AI) ==
 
Before we begin, notice that there are two types of AI. AI created from character objects, and AI created from memory. AI created from character objects are created by the function call <tt>ai2_spawn (name)</tt>, where (name) is the name of the AI. AI created from memory are created by the function call <tt>chr_create (ai_number) start,</tt>. These AI do not have combat logic, and thus will not attack you physically but can still use weapons.
Before we begin, notice that there are two types of AI. AI created from character objects, and AI created from memory. AI created from character objects are created by the function call <tt>ai2_spawn (name)</tt>, where (name) is the name of the AI. AI created from memory are created by the function call <tt>chr_create (ai_number) start,</tt>. These AI do not have combat logic, and thus will not attack you physically but can still use weapons.


Now, we are going to add 2 enemy AI to our script that we wrote in the last section. Open it up, and lets add some enemies for Konoko to fight.
Now, we are going to add 2 enemy AI to our script that we wrote in the last section. Open it up, and lets add some enemies for Konoko to fight.


To recap, it should look like this :
To recap, it should look like this:
  func void main(void){
  func void main(void)
{
     chr_teleport 0 7010
     chr_teleport 0 7010
  }
  }
After the function call <tt>chr_teleport 0 7010</tt>, add the following 2 commands on separate lines: <tt>ai2_spawn Top_Striker_1</tt> and <tt>ai2_spawn Top_Comguy_1</tt>. These two commands tell the game to create 2 characters: '''Top_Striker_1''', and '''Top_Comguy_1'''.
After the function call <tt>chr_teleport 0 7010</tt>, add the following 2 commands on separate lines: <tt>ai2_spawn Top_Striker_1</tt> and <tt>ai2_spawn Top_Comguy_1</tt>. These two commands tell the game to create 2 characters: '''Top_Striker_1''', and '''Top_Comguy_1'''.


Since that these characters do not spawn in the room, they must be teleported there. Using the <tt>chr_teleport</tt> command used earlier to teleport yourself, modify it to teleport the 2 AI using their names instead of "0". Teleport them to the flags "7008" and "7009" respectively. Refer to the example above or the list of function calls above to write this in.
Since that these characters do not spawn in the room, they must be teleported there. Using the <tt>chr_teleport</tt> command used earlier to teleport yourself, modify it to teleport the 2 AI using their names instead of "0". Teleport them to the flags "7008" and "7009" respectively. Refer to the example above or the list of function calls above to write this in.


It should now look like this :
It should now look like this:
  func void main(void) {
 
    chr_teleport 0 7010
  func void main(void)
    ai2_spawn Top_Striker_1
{
    ai2_spawn Top_Comguy_1
    chr_teleport 0 7010
    chr_teleport Top_Striker_1 7008
    [[ai2_spawn]] Top_Striker_1
    chr_teleport Top_Comguy_1 7009
    ai2_spawn Top_Comguy_1
    chr_teleport Top_Striker_1 7008
    chr_teleport Top_Comguy_1 7009
  }
  }
This script will now teleport you into the final training room and face you off against 2 Strikers.
This script will now teleport you into the final training room and face you off against 2 Strikers.


This fight too easy? In the next section, we will learn how to spice up the fight, and let you develop your own script.
This fight too easy? In the next section, we will learn how to spice up the fight, and let you develop your own script.


==Customization==
Here, you will be able to split off and customize your script. Each subsection will represent a way to customize the above script.


----
===Weapons and powerups===
 
These are the easiest things to add into a battle. Weapons can be spawned on the ground or given to characters.
== Part 6: Customization==
 
Here, you will be able to split off and customize your script.
Each subsection will represent a way to customize the above script.
 
===Weapons and Powerups===
These are the easiest things to add into a battle.
 
Weapons can be spawned on the ground or given to characters.
 
====Giving Characters Weapons====


====Giving characters weapons====
Giving characters weapons is very easy. Simply use the command <tt>chr_giveweapon</tt> to give a character a weapon.
Giving characters weapons is very easy. Simply use the command <tt>chr_giveweapon</tt> to give a character a weapon.


Line 177: Line 92:
Add the commands <tt>chr_giveweapon Top_Striker w3_phr</tt> and <tt>chr_giveweapon Top_Comguy w3_phr</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute.
Add the commands <tt>chr_giveweapon Top_Striker w3_phr</tt> and <tt>chr_giveweapon Top_Comguy w3_phr</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute.


====Spawning Weapons on the ground====
====Spawning weapons on the ground====
 
Spawning weapons is simple. Use the command <tt>weapon_spawn</tt> to spawn a weapon.
Spawning weapons is simple. Use the command <tt>weapon_spawn</tt> to spawn a weapon.


Add the commands <tt>weapon_spawn w3_phr 7008</tt> and <tt>weapon_spawn w3_phr 7009</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute. This command will spawn 2 plasma rifles, one under each striker's feet. AI will automatically pick up weapons with ammo or empty weapons they have ammo for.
Add the commands <tt>weapon_spawn w3_phr 7008</tt> and <tt>weapon_spawn w3_phr 7009</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute. This command will spawn 2 plasma rifles, one under each striker's feet. AI will automatically pick up weapons with ammo or empty weapons they have ammo for.


====Giving Characters Powerups====
====Giving characters powerups====
 
Giving characters powerups is much like giving characters weapons. Use the command <tt>chr_givepowerup</tt> to give a character a powerup.
Giving characters powerups is much like giving characters weapons. Use the command <tt>chr_givepowerup</tt> to give a character a powerup.


Line 197: Line 110:
Add the commands <tt>chr_givepowerup Top_Striker invis -1</tt> and <tt>chr_givepowerup Top_Comguy invis -1</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute. This command will make the strikers permanently invisible. To make then visible after 30 seconds, erase "-1".
Add the commands <tt>chr_givepowerup Top_Striker invis -1</tt> and <tt>chr_givepowerup Top_Comguy invis -1</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute. This command will make the strikers permanently invisible. To make then visible after 30 seconds, erase "-1".


====Spawning Powerups on the Ground====
====Spawning powerups on the ground====
 
Spawning powerups are simple. Use the command <tt>powerup_spawn</tt> to spawn a powerup.
Spawning powerups are simple. Use the command <tt>powerup_spawn</tt> to spawn a powerup.


Add the commands <tt>powerup_spawn invis 7008</tt> and <tt>powerup_spawn invis 7009</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute. This command will spawn 2 phase cloaks beneath the striker's feet. Since AI  will not pick up powerups, this is for you only.
Add the commands <tt>powerup_spawn invis 7008</tt> and <tt>powerup_spawn invis 7009</tt> on separate lines beneath what you have already. Be sure to add it ''BEFORE'' the '''}''' or it will not execute. This command will spawn 2 phase cloaks beneath the striker's feet. Since AI  will not pick up powerups, this is for you only.


===Extra Characters===
===Extra characters===
 
Adding extra characters to the script is easy. Just follow the steps for adding the first AI and follow the procedure, look for AI names [[BSL:AI names|here]].
Adding extra characters to the script is easy. Just follow the steps for adding the first AI and follow the procedure, look for AI names [[BSL:AI names|here]].
(Wiki page not here yet. Use [http://ssg.oni2.net/subfold/charas/charas.htm ssg's tables] instead.)  
(Wiki page not here yet. Use [http://ssg.oni2.net/subfold/charas/charas.htm ssg's tables] instead.)  


====Adding Enemies====
====Adding enemies====
 
Look at the chart for what teams the AI are on. Most of the time, adding enemies simply involve spawning and teleporting the AI. As long as the team in "Syndicate", it will be an enemy. If you want to add an emeny from an allied team, use the <tt>chr_changeteam</tt> command to changet their team to "Syndicate" like this:
Look at the chart for what teams the AI are on. Most of the time, adding enemies simply involve spawning and teleporting the AI. As long as the team in "Syndicate", it will be an enemy. If you want to add an emeny from an allied team, use the <tt>chr_changeteam</tt> command to changet their team to "Syndicate" like this:


<tt>chr_changeteam griffin Syndicate</tt>
[[chr_changeteam]] griffin Syndicate
 
====Adding Allies====


====Adding allies====
Look at the chart for what teams the AI are on. As long as the team is "TCTF" or "Konoko", it will be an ally for you in this script. If you want to add an ally from the enemy team, use the <tt>chr_changeteam</tt> command to changet their team to "TCTF" or "Konoko" like this:
Look at the chart for what teams the AI are on. As long as the team is "TCTF" or "Konoko", it will be an ally for you in this script. If you want to add an ally from the enemy team, use the <tt>chr_changeteam</tt> command to changet their team to "TCTF" or "Konoko" like this:


<tt>chr_changeteam WH_Striker_D TCTF</tt>
chr_changeteam WH_Striker_D TCTF


===Overpower===
===Overpower===
Use the <tt>chr_set_health</tt> command to set a character's health. Note that each character has a base health that may not be the same. For example, konoko's base health is 200, while a brown striker's is only 50. Keep this in mind when setting character's health. Setting it over their base health will send them into overpower - like using a hypo at full health. The health will drain at 1 point per tick (1/60 of a second), even for AIs. This example sets Konoko's health to 400 - overpower.


Use the <tt>chr_set_health</tt> command to set a character's health. Note that each character has a base health that may not be the same. For example, konoko's base health is 200, while a brown striker's is only 50. Keep this in mind when setting character's health. Setting it over their base health will send them into overpower - like using a hypo at full health. The health will drain at 1 every second even for AI.
  [[chr_set_health]] 0 400
*Attention! Attention! If ''that'' was true, Konoko's overpower would last 200 seconds : over 3 minutes. Which it doesn't.
*Then is it 1 point per frame = 200 frames ?
This example sets konoko's health to 400 - overpower.
  chr_set_health 0 400
 


This following example shows everything listed above added.
This following example shows everything listed above added.
  func void main(void) {
  func void main(void)
{
     chr_teleport 0 7010
     chr_teleport 0 7010
     powerup_spawn hypo 7010
     powerup_spawn hypo 7010
Line 240: Line 146:
     chr_teleport Top_Comguy_1 7009
     chr_teleport Top_Comguy_1 7009
   
   
     chr_givepowerup Top_Striker_1 invis -1
     [[chr_givepowerup]] Top_Striker_1 invis -1
     chr_givepowerup Top_Comguy_1 invis -1
     chr_givepowerup Top_Comguy_1 invis -1
     powerup_spawn invis 7007
     [[powerup_spawn]] invis 7007
     powerup_spawn invis 7009
     powerup_spawn invis 7009
   
   
     chr_giveweapon Top_Striker_1 w7_scc
     [[chr_giveweapon]] Top_Striker_1 w7_scc
     chr_giveweapon Top_Comguy_1 w3_phr
     chr_giveweapon Top_Comguy_1 w3_phr
     chr_givepowerup Top_Striker_1 ammo 15
     chr_givepowerup Top_Striker_1 ammo 15
     chr_givepowerup Top_Comguy_1 cell 30
     chr_givepowerup Top_Comguy_1 cell 30
   
   
     weapon_spawn w2_sap 7045
     [[weapon_spawn]] w2_sap 7045
     powerup_spawn ammo 7008
     powerup_spawn ammo 7008
   
   
Line 269: Line 175:
  }
  }


==Delay==
To wait for some time before executing a command, use <tt>sleep</tt>. To wait for approximately 5 seconds before spawning an extra drone:


----
[[sleep]] 300
ai2_spawn dum_train_block
chr_teleport dum_train_block 7010


== Part 7: Delay ==
To wait for a Striker to die and then spawn some drones:


<tt>sleep</tt><br>
[[chr_wait_health]] Top_Striker 0
<tt>chr_wait_health</tt>
ai2_spawn dum_train_block
chr_teleport dum_train_block 7010


To wait for some time before executing a command, use <tt>sleep</tt>. To wait for approx 5 seconds before spawning an extra drone, go like this:
==Forking and separate functions==
This is the part where we start moving commands out of "main". Create a new function called "logic" like this : type "func logic" two lines below the '''}''' of "main". Type '''{''' and copy out everything inside "main" into "logic". Type <tt>fork logic</tt> in main. It should look like this:


<tt>sleep 300<br>
func void main(void)
ai2_spawn dum_train_block<br>
{
chr_teleport dum_train_block 7010<br>
    [[fork]] logic
</tt>
}
func logic
{
    ...
}


To wait for a striker to die and then spawn some drones, go like this:
with "..." being whatever you had in "main" before. Add <tt>chr_wait_health griffin 0</tt> at the end of "logic", then type <tt>fork logic2</tt>. Create the function "logic2". In "logic2" you can write whatever you want that you have learned before. For the purpose of this example, '''...''' will represent whatever you had, '''..''' will represent whatever you want, and the typed text will represent the thing that must be included.


<tt>chr_wait_health Top_Striker 0<br>
func void main(void)
ai2_spawn dum_train_block<br>
{
chr_teleport dum_train_block 7010<br></tt>
    fork logic
}
func logic
{
    ...
    chr_wait_health griffin 0
    fork logic2
}
func logic2
{
    ..
}


===Extra: multiple forking===
More than one function can be forked in the same function. Look at ths example:


== Part 8: Forking and Separate Functions==
func void main(void)
 
{
This is the part where we start moving commands out of "main". Create a new function called "logic" like this : type "func logic" two lines below the '''}''' of "main". Type '''{''' and copy out everything inside "main" into "logic". Type <tt>fork logic</tt> in main. It should look like this :
    fork logicA
 
    fork logicB
<tt>func void main(void)<br>
}
{<br>
fork logic<br>
func logicA
}<br>
{
<br>
    ..
func logic<br>
}
{<br>
...<br>
func logicB
}</tt>
{
 
    ..
... being whatever you had in "main" before. Add <tt>chr_wait_health griffin 0</tt> at the end of "logic", then type <tt>fork logic2</tt>. Create the function "logic2". In "logic2" you can write whatever you want that you have learned before. For the purpose of this example, '''...''' will represent whatever you had, '''..''' will represent whatever you want, and typed text will represent thing that must be included.
}
 
<tt>func void main(void)<br>
{<br>
fork logic<br>
}<br>
<br>
func logic<br>
{<br>
...<br>
chr_wait_health griffin 0<br>
fork logic2<br>
}<br>
<br>
func logic2 {<br>
..<br>
}</tt>
 
===Extra: Multiple Forking===
 
More than one function can be forked in the same function. Look at ths example :
 
<tt>func void main(void)<br>
{<br>
fork logicA<br>
fork logicB<br>
}<br>
 
func logicA {<br>
..<br>
}<br>
 
func logicB {<br>
..<br>}</tt>


Both "logicA" and "logicB" are executed at the same time. If <tt>chr_wait_health griffin 0</tt> were to be removed, likewise, both "logic" and "logic2" are executed at the same time.
Both "logicA" and "logicB" are executed at the same time. If <tt>chr_wait_health griffin 0</tt> were to be removed, likewise, both "logic" and "logic2" are executed at the same time.


== Part 9: Variables and Save Points ==
==Variables and save points==
 
Ever wondered why there is no folder for the Training level? The truth is that it is actually part of the Warehouse level and is kept separate using save points.
Ever wondered why there is no folder for basic training? The truth is, it is actually part of the Warehouse level and is managed by save points.


This is the beginning of the "level_start" which is forked from "main" in the original level scripts.
This is the beginning of the "level_start" which is forked from "main" in the original level scripts.


<tt>func void level_start(string ai_name)<br>
func void level_start(string ai_name)
{<br>
{
<br>
     if (save_point eq 0)
<br>
     {
     if (save_point eq 0)<br>
      ...
     {   <br>
     }
        ...<br>
     }<br>
     if (save_point eq 1)
<br>
     {
     if (save_point eq 1)<br>
      ...
     {<br>
     }
        ...<br>
}
     }<br>
<br>
}</tt>


Using forking, you can link save points to functions. Like so :
Using forking, you can link save points to functions. Like so:


<tt>func void main(void)<br>
func void main(void)
{<br>
{
<br>
     if (save_point eq 0)
     if (save_point eq 0)<br>
     {     
     {    <br>
      fork logic
        fork logic<br>
     }
     }<br>
<br>
     if (save_point eq 1)
     if (save_point eq 1)<br>
     {
     {<br>
      fork logic2
        fork logic2<br>
     }
     }<br>
}
<br>
}</tt>


When save point 0 is loaded (TCTF Training), the function "logic" is executed. If save point 1 is loaded (Syndicate Warehouse), "logic2" is executed. Note that in Warehouse, the save point number in the script is one higher than in the level load list, because "TCTF Training" is SP0.
When save point 0 is loaded (TCTF Training), the function "logic" is executed. If save point 1 is loaded (Syndicate Warehouse), "logic2" is executed. Note that in Warehouse, the save point number in the script is one higher than in the level load list, because "TCTF Training" is SP0.


                                                              - Your_Mom
[[Category:Modding tutorials]]
[[Category:Modding tutorials]]