Any Leaks in this trigger?

ianu74

New Member
Reaction score
8
I've made a trigger for a boomerang-like skill, dragging units towards you. However, after using it for some time, the game becomes quite laggy.
Can anyone see if there are any leaks in the trigger?

Trigger:
  • Boomerang
    • Events
      • Unit - A unit Starts the effect of an ability
    • Conditions
      • (Ability being cast) Equal to Boomerang Pull (Neutral Hostile)
    • Actions
      • Set Temp_point = (Position of (Triggering unit))
      • Set BoomerangNo = (BoomerangNo + 1)
      • Unit - Create 1 Boomerang for (Owner of (Triggering unit)) at Temp_point facing (Angle from (Position of (Triggering unit)) to (Target point of ability being cast)) degrees
      • Unit - Add a 2.00 second Generic expiration timer to (Last created unit)
      • Custom script: call RemoveLocation(udg_Temp_point)
      • Set Boomerang[BoomerangNo] = (Last created unit)
      • Set BoomerangThrower[BoomerangNo] = (Triggering unit)
      • If (All Conditions are True) then do (Then Actions) else do (Else Actions)
        • If - Conditions
          • BoomerangNo Greater than 3
        • Then - Actions
          • Set BoomerangNo = 0
        • Else - Actions

Trigger:
  • Boomerang Movement
    • Events
      • Time - Every 0.02 seconds of game time
    • Conditions
    • Actions
      • For each (Integer A) from 1 to 4, do (Actions)
        • Loop - Actions
          • If (All Conditions are True) then do (Then Actions) else do (Else Actions)
            • If - Conditions
              • (Boomerang[(Integer A)] is alive) Equal to True
            • Then - Actions
              • Set BoomerangPulledGroup[(Integer A)] = (Units within 360.00 of (Position of Boomerang[(Integer A)]) matching ((((Matching unit) belongs to an enemy of (Owner of Boomerang[(Integer A)])) Equal to True) and (((Matching unit) is A Hero) Equal to False)))
              • Unit Group - Pick every unit in BoomerangPulledGroup[(Integer A)] and do (Actions)
                • Loop - Actions
                  • Set Temp_point = (Position of (Picked unit))
                  • Set Temp_point2 = (Temp_point offset by 30.00 towards (Facing of Boomerang[(Integer A)]) degrees)
                  • Unit - Move (Picked unit) instantly to Temp_point2
                  • Custom script: call RemoveLocation(udg_Temp_point2)
                  • Custom script: call RemoveLocation(udg_Temp_point)
              • Custom script: call DestroyGroup(udg_BoomerangPulledGroup[1])
              • Custom script: call DestroyGroup(udg_BoomerangPulledGroup[2])
              • Custom script: call DestroyGroup(udg_BoomerangPulledGroup[3])
              • Custom script: call DestroyGroup(udg_BoomerangPulledGroup[4])
              • Unit - Set the custom value of Boomerang[(Integer A)] to ((Custom value of Boomerang[(Integer A)]) + 1)
              • Set Temp_point2 = (Position of Boomerang[(Integer A)])
              • Set Temp_point = (Temp_point2 offset by 30.00 towards (Facing of Boomerang[(Integer A)]) degrees)
              • Unit - Move Boomerang[(Integer A)] instantly to Temp_point
              • Custom script: call RemoveLocation(udg_Temp_point)
              • Custom script: call RemoveLocation(udg_Temp_point2)
              • If (All Conditions are True) then do (Then Actions) else do (Else Actions)
                • If - Conditions
                  • (Custom value of Boomerang[(Integer A)]) Greater than 35
                • Then - Actions
                  • Unit - Make Boomerang[(Integer A)] face BoomerangThrower[(Integer A)] over 0.00 seconds
                • Else - Actions
            • Else - Actions
 

Nenad

~Choco Coronet~ Omnomnom
Reaction score
137
I don't see any leaks...make sure you set the dummy units to Can't raise, does not decay, otherwise you may have a pile of corpses picking up ^^
 

ianu74

New Member
Reaction score
8
It still lags over time... Is it because that the movement trigger is on permanently?
 

Nenad

~Choco Coronet~ Omnomnom
Reaction score
137
I would expect you to experience lag throughout the map then, and not after a while, maybe try to eliminate the movement trigger somehow, it would help, you're making 200 unit groups per second and removing them, that's quite a lot...
 

vypur85

Hibernate
Reaction score
803
The bolded ones are the ones that require attention:

Code:
Boomerang
    Events
        Unit - A unit Starts the effect of an ability
    Conditions
        (Ability being cast) Equal to Boomerang Pull (Neutral Hostile)
    Actions
        Set Temp_point = (Position of (Triggering unit))
        Set BoomerangNo = (BoomerangNo + 1)
        Unit - Create 1 Boomerang for (Owner of (Triggering unit)) at Temp_point facing (Angle from [B](Position of (Triggering unit)[/B]) to [B](Target point of ability being cast)[/B]) degrees
        Unit - Add a 2.00 second Generic expiration timer to (Last created unit)
        Custom script:   call RemoveLocation(udg_Temp_point)
        Set Boomerang[BoomerangNo] = (Last created unit)
        Set BoomerangThrower[BoomerangNo] = (Triggering unit)
        If (All Conditions are True) then do (Then Actions) else do (Else Actions)
            If - Conditions
                BoomerangNo Greater than 3
            Then - Actions
                Set BoomerangNo = 0
            Else - Actions


Code:
Boomerang Movement
    Events
        Time - Every 0.02 seconds of game time
    Conditions
    Actions
        For each (Integer A) from 1 to 4, do (Actions)
            Loop - Actions
                If (All Conditions are True) then do (Then Actions) else do (Else Actions)
                    If - Conditions
                        (Boomerang[(Integer A)] is alive) Equal to True
                    Then - Actions
                        Set BoomerangPulledGroup[(Integer A)] = (Units within 360.00 of [B](Position of Boomerang[(Integer A)])[/B] matching ((((Matching unit) belongs to an enemy of (Owner of Boomerang[(Integer A)])) Equal to True) and (((Matching unit) is A Hero) Equal to False)))
                        Unit Group - Pick every unit in BoomerangPulledGroup[(Integer A)] and do (Actions)
                            Loop - Actions
                                Set Temp_point = (Position of (Picked unit))
                                Set Temp_point2 = (Temp_point offset by 30.00 towards (Facing of Boomerang[(Integer A)]) degrees)
                                Unit - Move (Picked unit) instantly to Temp_point2
                                Custom script:   call RemoveLocation(udg_Temp_point2)
                                Custom script:   call RemoveLocation(udg_Temp_point)
                        Custom script:   call DestroyGroup(udg_BoomerangPulledGroup[[B]bj_forLoopAIndex[/B]])
                        [del]Custom script:   call DestroyGroup(udg_BoomerangPulledGroup[2])[/del]
                        [del]Custom script:   call DestroyGroup(udg_BoomerangPulledGroup[3])[/del]
                        [del]Custom script:   call DestroyGroup(udg_BoomerangPulledGroup[4])[/del]
                        Unit - Set the custom value of Boomerang[(Integer A)] to ((Custom value of Boomerang[(Integer A)]) + 1)
                        Set Temp_point2 = (Position of Boomerang[(Integer A)])
                        Set Temp_point = (Temp_point2 offset by 30.00 towards (Facing of Boomerang[(Integer A)]) degrees)
                        Unit - Move Boomerang[(Integer A)] instantly to Temp_point
                        Custom script:   call RemoveLocation(udg_Temp_point)
                        Custom script:   call RemoveLocation(udg_Temp_point2)
                        If (All Conditions are True) then do (Then Actions) else do (Else Actions)
                            If - Conditions
                                (Custom value of Boomerang[(Integer A)]) Greater than 35
                            Then - Actions
                                Unit - Make Boomerang[(Integer A)] face BoomerangThrower[(Integer A)] over 0.00 seconds
                            Else - Actions
                    Else - Actions

That's all that I can find for now.
 

ianu74

New Member
Reaction score
8
Nenad - It lags over time when i use it. When i don't, it doesn't lag.
And I turned it off when there are no more "boomerangs" in the map.

vypur85 - I followed you idea and made adjustments to those in bold, using variables and removing them. It still lags over time.

Thanks for the help though guys.

Any more ideas why it might be leaking?

Btw, the lag only began when i made this trigger.
 

ianu74

New Member
Reaction score
8
avalya - Tried, it helps by a bit, but it still lags after continuous usage of the spell.
 

ianu74

New Member
Reaction score
8
All except the unit variables. The units are removed after 1 round. Does that remove unit variables?
 

Nenad

~Choco Coronet~ Omnomnom
Reaction score
137
Can you post the new edited trigger? Please also change the triggering units to their respective fields (casting unit, unit of ability being cast) etc.. Confusing to look at atm ^^
 

ianu74

New Member
Reaction score
8
Trigger:
  • Boomerang
    • Events
      • Unit - A unit Starts the effect of an ability
    • Conditions
      • (Ability being cast) Equal to Boomerang Pull (Neutral Hostile)
    • Actions
      • Set BoomerangNo = (BoomerangNo + 1)
      • Set Temp_point = (Position of (Casting unit))
      • Set BoomerangThrower[BoomerangNo] = (Casting unit)
      • Set Temp_point2 = (Target point of ability being cast)
      • Unit - Create 1 Boomerang for (Owner of (Casting unit)) at Temp_point facing (Angle from Temp_point to Temp_point2) degrees
      • Set Boomerang[BoomerangNo] = (Last created unit)
      • Unit - Add a 2.00 second Generic expiration timer to (Last created unit)
      • Custom script: call RemoveLocation(udg_Temp_point)
      • Custom script: call RemoveLocation(udg_Temp_point2)
      • Trigger - Turn on Boomerang Movement <gen>
      • If (All Conditions are True) then do (Then Actions) else do (Else Actions)
        • If - Conditions
          • BoomerangNo Greater than 3
        • Then - Actions
          • Set BoomerangNo = 0
        • Else - Actions


Trigger:
  • Boomerang Movement
    • Events
      • Time - Every 0.02 seconds of game time
    • Conditions
    • Actions
      • If (All Conditions are True) then do (Then Actions) else do (Else Actions)
        • If - Conditions
          • Or - Any (Conditions) are true
            • Conditions
              • (Boomerang[1] is alive) Equal to True
              • (Boomerang[3] is alive) Equal to True
              • (Boomerang[2] is alive) Equal to True
              • (Boomerang[4] is alive) Equal to True
        • Then - Actions
          • For each (Integer A) from 1 to 4, do (Actions)
            • Loop - Actions
              • Set BoomerangPoint = (Position of Boomerang[(Integer A)])
              • Set BoomerangPulledGroup[(Integer A)] = (Units within 260.00 of BoomerangPoint matching ((((Matching unit) belongs to an enemy of (Owner of Boomerang[(Integer A)])) Equal to True) and (((Matching unit) is A Hero) Equal to False)))
              • Unit - Set the custom value of Boomerang[(Integer A)] to ((Custom value of Boomerang[(Integer A)]) + 1)
              • Set Temp_point = (BoomerangPoint offset by 30.00 towards (Facing of Boomerang[(Integer A)]) degrees)
              • Unit - Move Boomerang[(Integer A)] instantly to Temp_point
              • Custom script: call RemoveLocation(udg_Temp_point)
              • Unit Group - Pick every unit in BoomerangPulledGroup[(Integer A)] and do (Actions)
                • Loop - Actions
                  • Set Temp_point = (Position of (Picked unit))
                  • Set Temp_point2 = (Temp_point offset by 30.00 towards (Facing of Boomerang[(Integer A)]) degrees)
                  • Unit - Move (Picked unit) instantly to Temp_point2
                  • Custom script: call RemoveLocation(udg_Temp_point2)
                  • Custom script: call RemoveLocation(udg_Temp_point)
              • Custom script: call RemoveLocation(udg_BoomerangPoint)
              • Custom script: call DestroyGroup(udg_BoomerangPulledGroup[bj_forLoopAIndex])
              • If (All Conditions are True) then do (Then Actions) else do (Else Actions)
                • If - Conditions
                  • (Custom value of Boomerang[(Integer A)]) Greater than 35
                • Then - Actions
                  • Unit - Make Boomerang[(Integer A)] face BoomerangThrower[(Integer A)] over 0.00 seconds
                • Else - Actions
        • Else - Actions
          • Trigger - Turn off (This trigger)
 

Nenad

~Choco Coronet~ Omnomnom
Reaction score
137
Trigger:
  • Set BoomerangPulledGroup[(Integer A)] = (Units within 260.00 of BoomerangPoint matching ((((Matching unit) belongs to an enemy of (Owner of Boomerang[(Integer A)])) Equal to True) and (((Matching unit) is A Hero) Equal to False)))


Can you try adding another condition to it saying (Matching Unit) is alive equal to true?

It may be picking up needless corpses around the unit, although that's really a far shot, i'm unsure, maybe the mechanics of wc3 can't handle your spell xD
 

ianu74

New Member
Reaction score
8
It checks to see if the Boomerangs are present. If not, the trigger turns itself off.
 

Komaqtion

You can change this now in User CP.
Reaction score
469
Trigger:
  • Set BoomerangPulledGroup[(Integer A)] = (Units within 260.00 of BoomerangPoint matching ((((Matching unit) belongs to an enemy of (Owner of Boomerang[(Integer A)])) Equal to True) and (((Matching unit) is A Hero) Equal to False)))


You don't need that as an array, as you're destroying it before another use...

I'd also say that you do the Ineger A loop first, and inside it use an If to check if Boomerang[Integer A] is alive...
That way you don't have to loop through the ones that have a dead unit ;)
 

LearningCode

New Member
Reaction score
24
Quick scan through.
Haven't you guys noticed the leaks?

First trigger leaks, like, 2 units and a location
Second trigger leaks, like, 4units and a location

I think
 
General chit-chat
Help Users
  • No one is chatting at the moment.
  • Ghan Ghan:
    Howdy
  • Ghan Ghan:
    Still lurking
    +3
  • The Helper The Helper:
    I am great and it is fantastic to see you my friend!
    +1
  • The Helper The Helper:
    If you are new to the site please check out the Recipe and Food Forum https://www.thehelper.net/forums/recipes-and-food.220/
  • Monovertex Monovertex:
    How come you're so into recipes lately? Never saw this much interest in this topic in the old days of TH.net
  • Monovertex Monovertex:
    Hmm, how do I change my signature?
  • tom_mai78101 tom_mai78101:
    Signatures can be edit in your account profile. As for the old stuffs, I'm thinking it's because Blizzard is now under Microsoft, and because of Microsoft Xbox going the way it is, it's dreadful.
  • The Helper The Helper:
    I am not big on the recipes I am just promoting them - I use the site as a practice place promoting stuff
    +2
  • Monovertex Monovertex:
    @tom_mai78101 I must be blind. If I go on my profile I don't see any area to edit the signature; If I go to account details (settings) I don't see any signature area either.
  • The Helper The Helper:
    You can get there if you click the bell icon (alerts) and choose preferences from the bottom, signature will be in the menu on the left there https://www.thehelper.net/account/preferences
  • The Helper The Helper:
    I think I need to split the Sci/Tech news forum into 2 one for Science and one for Tech but I am hating all the moving of posts I would have to do
  • The Helper The Helper:
    What is up Old Mountain Shadow?
  • The Helper The Helper:
    Happy Thursday!
    +1
  • Varine Varine:
    Crazy how much 3d printing has come in the last few years. Sad that it's not as easily modifiable though
  • Varine Varine:
    I bought an Ender 3 during the pandemic and tinkered with it all the time. Just bought a Sovol, not as easy. I'm trying to make it use a different nozzle because I have a fuck ton of Volcanos, and they use what is basically a modified volcano that is just a smidge longer, and almost every part on this thing needs to be redone to make it work
  • Varine Varine:
    Luckily I have a 3d printer for that, I guess. But it's ridiculous. The regular volcanos are 21mm, these Sovol versions are about 23.5mm
  • Varine Varine:
    So, 2.5mm longer. But the thing that measures the bed is about 1.5mm above the nozzle, so if I swap it with a volcano then I'm 1mm behind it. So cool, new bracket to swap that, but THEN the fan shroud to direct air at the part is ALSO going to be .5mm to low, and so I need to redo that, but by doing that it is a little bit off where it should be blowing and it's throwing it at the heating block instead of the part, and fuck man
  • Varine Varine:
    I didn't realize they designed this entire thing to NOT be modded. I would have just got a fucking Bambu if I knew that, the whole point was I could fuck with this. And no one else makes shit for Sovol so I have to go through them, and they have... interesting pricing models. So I have a new extruder altogether that I'm taking apart and going to just design a whole new one to use my nozzles. Dumb design.
  • Varine Varine:
    Can't just buy a new heatblock, you need to get a whole hotend - so block, heater cartridge, thermistor, heatbreak, and nozzle. And they put this fucking paste in there so I can't take the thermistor or cartridge out with any ease, that's 30 dollars. Or you can get the whole extrudor with the direct driver AND that heatblock for like 50, but you still can't get any of it to come apart
  • Varine Varine:
    Partsbuilt has individual parts I found but they're expensive. I think I can get bits swapped around and make this work with generic shit though
  • Ghan Ghan:
    Heard Houston got hit pretty bad by storms last night. Hope all is well with TH.
  • The Helper The Helper:
    Power back on finally - all is good here no damage
    +1
  • V-SNES V-SNES:
    Happy Friday!
    +1

      The Helper Discord

      Members online

      No members online now.

      Affiliates

      Hive Workshop NUON Dome World Editor Tutorials

      Network Sponsors

      Apex Steel Pipe - Buys and sells Steel Pipe.
      Top