#
Condition
Another important aspect of creating story branches is Conditions. When writing a story, you often need a story section to be played only in specific states.
Conditions allow you to check if a specific statement or section should be played or ignored by running an expression evaluation first. If the evaluation returns on (true), the condition is successful, and the line is played. If the condition fails, the line is ignored.
- A condition statement can optionally start with a ? (Question Mark)
- A condition statement is named after its functionality
- If: Check an initial condition
- elseif: Check as many secondary conditions as needed
- else: This section plays if all if and elseif conditions fail
- A conditions statement sequence must always end with an endif marker
$ quest_completed = off
- Father Morgan
Back so soon?
? if: {quest_completed} == on
- Matt
The job is done.
- Father Morgan
I'm pleased to hear this.
Here, take this as a token of gratitude.
$ AddItem PriestRobes
? endif
- Matt
See you later, father.
In the example above, the script section from line 6 to line 17 is played only if the condition on line 6 is evaluated as true.
Using elseif and else conditions are completely optional. You can use as many elseif as required.
$ price = 100
$ barter = 5
- You
Can you give me a discount?
if: {barter} > 8
- Shopkeeper
Ok, you can keep it for half price.
- You
That is awesome!
$ gold = {&} - ( {price} * 0.5 )
elseif: {barter} >= 4 AND {barter} <= 8
- Shopkeeper
Best I can do is 10%.
- You
Deal!
$ gold = {&} - ( {price} * 0.9 )
else:
- Shopkeeper
You're kidding me! Right?
- You
Hmmm! No?!
- Shopkeeper
Get out of my shop!
$ reputation = {&} - 2
endif
- .
Time to leave.
You can nest if conditions inside each other, just remember to close each individual "if's collection of statements" with an endif statement, as shown above.
#
Expression
A condition is always an expression, the same method used to assign value to a variable. Therefore, conditions can use the same operators and syntax used by command expressions and be as complex as required.
- Bob | ? {x} + {y} > (10 ^ ({x} / 2)) OR ({x} == 5 AND {y} / 2 > 3)
Hello!
- Alice | ? {name} != Bob OR {switch} == on
Hello!
#
Condition as Instruction
You can use a condition instruction within any other statement to check if that single statement can be played or should be ignored.
- A condition instruction starts with a ? (Question Mark) followed by an expression.
$ End | ? {var} == off
A condition instruction is successful when its expression is evaluated as on and fails in any other case.
$ charisma = 10
- Shopkeeper | ? {charisma} >= 5
All right, it's a deal, you can keep the horse.
- Shopkeeper | ? {charisma} < 5
Get out of my shop.
In the first dialogue, the interpreter checks if a previously created Quillscript variable has a value bigger or equal to 5. The second dialogue covers the remaining option, that is, if charisma is smaller than 5.
You can add as many conditions as needed to a single statement.
#
In Dialogue, Router, and Command
If any condition instruction fails, the statement is ignored, and the script flow proceeds to the following statement.
#
In Option
Conditions are pre-evaluated and passed to the Play event of the Selection Box widget as a Boolean parameter called Valid. This parameter does nothing by itself; it’s delegated to the Selection Box widget to decide what to do with this information. In most cases, the widget hides, gray out, or lock invalid options.
* Kiss her | ? {charisma} > 4 | -> Kiss
* Bye! | -> Leave
#
In Label
The label and its content are ignored if any condition instruction fails, and the script flow proceeds to the following label statement.
@ Leave | ? {charisma} > 4
This section is ignored if charisma <= 4