Struct Issues

Naga'sShadow

Ultra Cool Member
Reaction score
49
I'm very new to structs, so my issue may just be one of a basic error on my part.

JASS:
scope Meld initializer Init

globals
    private integer SpellID = 'A0AU' //Spells Rawcode
    private integer AbilID = 'A0AV' //Ability Rawcode
    private constant string SFX = "Abilities\\Spells\\Orc\\EtherealForm\\SpiritWalkerChange.mdl" //SFX
endglobals

struct meld
    unit u
    real X
    real Y
endstruct

private function Meld_Conditions takes nothing returns boolean
    return GetSpellAbilityId() == SpellID
endfunction

private function Meld_Loop takes nothing returns boolean
    local meld Data = meld.create()
    local unit cast = Data.u
    local real castX = Data.X
    local real castY = Data.Y
    
    return GetUnitCurrentOrder(GetTriggerUnit()) != String2OrderIdBJ("channel")
endfunction

private function Meld_Actions takes nothing returns nothing
    local unit cast = GetTriggerUnit()
    local real castX = GetLocationX(GetUnitLoc(cast))
    local real castY = GetLocationY(GetUnitLoc(cast))
    local meld Data = meld.create()
    
    set Data.u = cast
    set Data.X = castX
    set Data.Y = castY
    call AddSpecialEffect( SFX, castX, castY)
    call UnitAddAbility(cast, AbilID)
    loop
        exitwhen( Meld_Loop())
        call TriggerSleepAction(RMaxBJ(bj_WAIT_FOR_COND_MIN_INTERVAL, 0.50))
    endloop
    
    call UnitRemoveAbility(cast, AbilID)
    set cast = null
endfunction

//===========================================================================
function Init takes nothing returns nothing
    local trigger trg = CreateTrigger( )
    call TriggerRegisterAnyUnitEventBJ( trg, EVENT_PLAYER_UNIT_SPELL_EFFECT)
    call TriggerAddCondition( trg, Condition(function Meld_Conditions))
    call TriggerAddAction( trg, function Meld_Actions )
    set trg = null
endfunction

endscope


In this trigger the unit gets an ability, ghost, as long as it casts channel. I wanted to have it check if the unit has moved as well as if it has changed orders. But currently I'm not able to pass the data between functions via structs. A debug message already informed me the "cast" in Meld_Loop was staying null. I've worked around it using GetTriggerUnit() but that won't give me the X and the Y of the unit to compare with the X and the Y on cast.

1.) Can anyone point out how I would fix that?
2.) Is there a simpler way of setting this type of trigger up?

Thanks.
 
It's not working because you're creating a new struct instance in here:
JASS:
private function Meld_Loop takes nothing returns boolean
    local meld Data = meld.create() // New struct instance
    local unit cast = Data.u
    local real castX = Data.X
    local real castY = Data.Y
    
    return GetUnitCurrentOrder(GetTriggerUnit()) != String2OrderIdBJ("channel")
endfunction


You could make MeldLoop either take "meld" as an argument:
JASS:
private function Meld_Loop takes meld Data returns boolean
    local unit cast = Data.u
    local real castX = Data.X
    local real castY = Data.Y
    
    return GetUnitCurrentOrder(GetTriggerUnit()) != String2OrderIdBJ("channel")
endfunction


or make it a method inside the struct.
 
General chit-chat
Help Users
  • No one is chatting at the moment.
  • The Helper The Helper:
    News portal has been retired. Main page of site goes to Headline News forum now
  • The Helper The Helper:
    I am working on getting access to the old news portal under a different URL for those that would rather use that for news before we get a different news view.
  • Ghan Ghan:
    Easily done
    +1
  • The Helper The Helper:
    https://www.thehelper.net/pages/news/ is a link to the old news portal - i will integrate it into the interface somewhere when i figure it out
  • Ghan Ghan:
    Need to try something
  • Ghan Ghan:
    Hopefully this won't cause problems.
  • Ghan Ghan:
    Hmm
  • Ghan Ghan:
    I have converted the Headline News forum to an Article type forum. It will now show the top 20 threads with more detail of each thread.
  • Ghan Ghan:
    See how we like that.
  • The Helper The Helper:
    I do not see a way to go past the 1st page of posts on the forum though
  • The Helper The Helper:
    It is OK though for the main page to open up on the forum in the view it was before. As long as the portal has its own URL so it can be viewed that way I do want to try it as a regular forum view for a while
  • Ghan Ghan:
    Yeah I'm not sure what the deal is with the pagination.
  • Ghan Ghan:
    It SHOULD be there so I think it might just be an artifact of having an older style.
  • Ghan Ghan:
    I switched it to a "Standard" article forum. This will show the thread list like normal, but the threads themselves will have the first post set up above the rest of the "comments"
  • The Helper The Helper:
    I don't really get that article forum but I think it is because I have never really seen it used on a multi post thread
  • Ghan Ghan:
    RpNation makes more use of it right now as an example: https://www.rpnation.com/news/
  • The Helper The Helper:
  • The Helper The Helper:
    What do you think Tom?
  • tom_mai78101 tom_mai78101:
    I will have to get used to this.
  • tom_mai78101 tom_mai78101:
    The latest news feed looks good
  • The Helper The Helper:
    I would like to see it again like Ghan had it the first time with pagination though - without the pagination that view will not work but with pagination it just might...
  • The Helper The Helper:
    This drink recipe I have had more than a few times back in the day! Mind Eraser https://www.thehelper.net/threads/cocktail-mind-eraser.194720/

      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