2023-12-04 16:02:58 +01:00
|
|
|
scriptname defaultSetStageTrigSCRIPT extends objectReference
|
|
|
|
{ this is a generic script for one-shot quest stage updates}
|
|
|
|
|
|
|
|
import game
|
|
|
|
import debug
|
|
|
|
|
|
|
|
quest property myQuest auto
|
|
|
|
{ quest to call SetStage on}
|
|
|
|
|
|
|
|
int property stage auto
|
|
|
|
{ stage to set}
|
|
|
|
|
|
|
|
bool property doOnce = True auto
|
|
|
|
{Set the stage only once.}
|
|
|
|
|
|
|
|
int property prereqStageOPT = -1 auto
|
|
|
|
{ OPTIONAL: stage that must be set for this trigger to fire }
|
|
|
|
|
|
|
|
bool property disableWhenDone = true auto
|
|
|
|
{ disable myself after I've been triggered. Defaults to true }
|
|
|
|
|
|
|
|
|
|
|
|
auto STATE waitingForPlayer
|
|
|
|
EVENT onTriggerEnter(objectReference triggerRef)
|
|
|
|
if triggerRef == getPlayer() as actor
|
|
|
|
; check to see if a pre-req stage was specificed and if it's been met
|
2024-01-10 15:08:24 +01:00
|
|
|
if prereqStageOPT == -1 || MyQuest.IsStageDone(prereqStageOPT) == 1
|
2023-12-04 16:02:58 +01:00
|
|
|
; Start the quest just in case it isn't already running.
|
|
|
|
if myQuest.isRunning() == FALSE
|
|
|
|
bool check = myQuest.start()
|
|
|
|
; do a quick check in case the quest could not be started
|
|
|
|
if !check
|
|
|
|
; debug.trace("ERROR: "+myQuest+" not started by "+self)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
; do the actual business of setting the stage we want
|
2024-01-10 15:08:24 +01:00
|
|
|
myQuest.SetCurrentStageID(stage)
|
2023-12-04 16:02:58 +01:00
|
|
|
if doOnce
|
|
|
|
gotoState("hasBeenTriggered")
|
|
|
|
endif
|
|
|
|
if disableWhenDone
|
|
|
|
Disable()
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endEVENT
|
|
|
|
endSTATE
|
|
|
|
|
|
|
|
STATE hasBeenTriggered
|
|
|
|
; this is an empty state.
|
|
|
|
endSTATE
|