Staredit Network > Forums > SC1 Mapping Tools > Topic: LIT - Lua Interpreted Triggers
LIT - Lua Interpreted Triggers
May 21 2014, 7:14 am
By: CecilSunkure  

Oct 31 2015, 3:07 am CecilSunkure Post #21



To add onto my previous post:

Lets say next we want to add a greet message whenever we go in the direction of location A to location B that looks like this:





To do so we can add a parameter to the ConnectRooms function. It's a good time to make use of a trick in Lua for optional parameters, this lets us add in a greet message from A to B, from B to A, or neither. Here's an example:

Code
ConnectRooms( "link's house a", "link's house b", "<13><1C>:: <4>Link's House <1C>::" )


The above line will generate triggers that displays a greet only going from A to B. We can add in another parameter for a message going from B to A (maybe saying that we are back in Hyrule):


Code
ConnectRooms( "link's house a", "link's house b", "<13><1C>:: <4>Link's House <1C>::", "<13><1C>:: <4>Hyrule <1C>::" )


It is easy to see the greet messages that I am using have some redundant text formatting. I can hide the text formatting inside of the ConnectRooms function, so long as I want the formatting to be the same for all greets (which I do):

Code
ConnectRooms( "link's house a", "link's house b", "Link's House", "Hyrule" )


The finished ConnectRooms function looks like:

Code
-- create the deathcounter variable with LIT
local roomDC = Deaths( )
roomDC:SetUnit( "Terran Physics Lab" )
roomDC:SetPlayer( 8 )

-- function that generates triggers to connect two locations
-- together to act as a doorway for a "hero unit" called LINK
function ConnectRooms( a, b, greetA, greetB )
   -- move from a to b
   p8:Conditions( )
   roomDC:SetCount( 0 )
   roomDC:Exactly( )
   BringExactly( 1, LINK, a, 1 )
   p8:Actions( )
   roomDC:SetCount( 1 )
   roomDC:SetTo( )
   MoveUnit( 1, LINK, 1, a, b )
   if greetA then Text( "<13><1C>:: <4>" .. greetA .. " <1C>::" ) end
   Preserve( )
   
   -- move from b to a
   p8:Conditions( )
   roomDC:SetCount( 0 )
   roomDC:Exactly( )
   BringExactly( 1, LINK, b, 1 )
   p8:Actions( )
   roomDC:SetCount( 1 )
   roomDC:SetTo( )
   MoveUnit( 1, LINK, 1, b, a )
   if greetB then Text( "<13><1C>:: <4>" .. greetB .. " <1C>::" ) end
   Preserve( )
   
   -- turn off the DC when not present at a or b
   p8:Conditions( )
   BringExactly( 1, LINK, a, 0 )
   BringExactly( 1, LINK, b, 0 )
   roomDC:SetCount( 1 )
   roomDC:Exactly( )
   p8:Actions( )
   roomDC:SetCount( 1 )
   roomDC:SetTo( )
   Preserve( )
end




None.

Nov 9 2015, 9:53 am CecilSunkure Post #22



v1.10 released (link in OP)

Features:
-Automated allocation of death counters/switches
-More fully featured "shorthand notation" functions
-Made a docs pdf (in OP)
-Updated command line slightly to let users place their source wherever they like
-#if #then #end for nesting triggers together in arbitrary #if control structures
-better error reporting (stack trace)
-WINDOWS ONLY: triggers copied to clipboard upon completion
-Integrated to chkdraft (still need to send jj this latest version)



None.

Jan 9 2018, 3:30 am jjf28 Post #23

Cartography Artisan

Converting the memory condition to use memory addresses as the first parameter by default, Chkdraft users will have the option to change a setting to use playerId in the memory condition/actions, let me know if LIT should have it set to use playerId by default or if you want to update LIT or what not.



Rs_yes-im4real - Clan Aura - jjf28.net84.net

Reached the top of StarCraft theory crafting 2:12 AM CST, August 2nd, 2014.

Sep 8 2018, 7:31 pm goobie Post #24



First off, this is fantastic!

I would request that death counters are allocated for units that cannot be killed first, such as "Goliath Turret" or "Nuclear Missile". After the list of unkillable units is exhausted, then LIT could generate a warning when it's finished compiling.

As it stands the first death counter allocated is "Protoss Gateway", and the first several at least are units that can be killed during play, depending on the map. I'll probably implement this change to a local copy of LIT for a map I'm working on, if you want the changes.

Thanks!

P.S. Also, allowing allocation of death counters by playergroup! So each player in the playergroup gets a dc, and when a playergroup dc is used in a trigger, it generates triggers for players using their specific death counter. Kind of like "Current Player" behaves.

Post has been edited 1 time(s), last time on Sep 8 2018, 7:36 pm by goobie.



There's got to be something more to life than being really, really, ridiculously good looking...

Sep 9 2018, 4:53 am goobie Post #25



Ok, I've looked at Lock.lua pretty closely. I did find a couple issues. First, it seems that some unit names available for death counters include several spaces in a row, such as "Duke Turret type 1". It seems whatever you used to pull the strings killed the extra spaces, so Lock.lua has "Duke Turret type 1", which won't compile in trigedit.

The good news is, this always happens after the string "type", so a find-replace should fix all instances. The bad news is, some valid units with this space typo look like they've been removed to make the triggers compile. I have a modified Lock.lua with the complete unit list, with both problems fixed if you'd like it.

Finally, I don't believe we want to allocate death counters for "Any unit", "Buildings", "Factories", or "Men", which appear at the end of the list in Lock.lua

Cheers!

Edit: I made the changes to Lock.lua, let me know if you'd like the file!

Post has been edited 4 time(s), last time on Sep 23 2018, 7:38 pm by goobie.



There's got to be something more to life than being really, really, ridiculously good looking...

Options
  Back to forum
Please log in to reply to this topic or to report it.
Members in this topic: None.
[04:25 pm]
trgk -- sen should use letsencrypt
[09:14 am]
Generalpie -- I was disappointed in a lot of sites that had like a year and a half to reissue
[09:14 am]
Generalpie -- Speaking of which, the Symantec cutoff was last night
[09:13 am]
Generalpie -- zsnakezz
zsnakezz shouted: chrome says this site is not secure.
That's generally what happens for sites that don't use SSL
[2018-11-16. : 8:33 pm]
jjf28 -- Suicidal Insanity
Suicidal Insanity shouted: Are you really sure about that? ' --TRUNCATE *
that's a paddlin'
[2018-11-15. : 10:04 pm]
jjf28 -- a wild DavidJCobb appeared!
[2018-11-15. : 7:48 pm]
Suicidal Insanity -- Are you really sure about that? ' --TRUNCATE *
[2018-11-15. : 3:58 pm]
Dem0n -- I don't think the site is that bad
[2018-11-15. : 3:58 pm]
Dem0n -- lmao
[2018-11-15. : 3:55 pm]
trgk -- Not bad
Please log in to shout.


Members Online: Roy, vmofk1, Excalibur