Questions by Michael Callaghan
This extension allows us to suspend normal parser input to enable questions to be asked and the answers to be processed.
Chapter: About questions
Section: Introduction
During the normal course of a game, the parser responds to commands given by the player. If we type look, the parser interprets the command and displays a description of the current room; if we type N, the player heads North (if that exit is available, and so on.
Occasionally, we may want to ask specific questions and process the answers. Examples may be asking the player's name or age or displaying a menu of options from which the player selects a choice. Answers to these types of questions fall outside the range of the normal parser functions. Therefore we need to intercept the player's answers to these types of questions and respond to them separately.
This extension provides a framework that can be used to ask different types of questions. The mechanics are hidden behind the scenes to allow us to concentrate on asking and responding to a question without having to implement the framework ourselves.
Section: What's new?
Version 1
The first public release of Questions.
Version 2
- Punctuation removal in text questions is now optional.
- Questions can now be used in conjunction with the Fixed Point Maths extension to allow questions that requires a real number to be asked.
- To decide phrase added to determine if we are asking a question.
Many thanks are due to Erik Temple for suggesting the changes implemented in version 2.
Version 3
The variable "current menu" has been changed to "current question menu" to avoid a namespace clash with Emily Short's Menu extension.
Version 4
Deprecated phases have been removed from the extension and the examples.
Version 5
- Updated for version 6L02 and above. - Links to fixed point maths removed. - Real numbers are questions are supported. - Requires Glulx.
Chapter: Types of questions
Section: Overview
The extension allow us to ask questions that require different types of answers. The following questions types are allowed:
- Questions that require a number as an answer.
- Questions that require a real number as an answer.
- Questions that require an item from a menu to be chosen.
- Questions that require a Yes or No answer.
- Questions that require a gender selection (Male, Female or Neuter).
- Questions that require a text answer.
Section: Open and closed questions
The extension makes a distinction between "open" and "closed" questions. The difference between the two is that closed questions will not allow the game to proceed unless and until we specify that a correct answer has been given to a question. With open questions, if an 'incorrect 'reply is given, the game proceeds and tries to parse the player's command using the normal parser rules. For example, if we ask the question "How old are you?" expecting a number answer, the extension will deal with replies differently depending on whether we ask an open or a closed question.
Open questions:
If player answered "inv" to a number question, the extension will exit question mode and proceed to parse the answer normally. In this case, the player's inventory will be displayed. If the player answered 12, we determine whether this is an acceptable answer. If the answer is acceptable, the extension exits question mode and the play resumes. If the answer is unacceptable, for example the player enters 234 when asked his or her age, we can specify whether the question needs to asked again or whether play should proceed without an answer.
Closed questions:
If the player answered "inv", the answer will be rejected and the player will need to answer the question again. If the player answered 12, we determine whether this is an acceptable answer. If the answer is acceptable, the game exits question mode and proceeds as normal. If the answer is unacceptable, for example the player enters 234, the player will need to answer the question again.
Section: Flag for open or closed questions
To test if a question is an open or a closed question, we can use the 'closed question mode' flag:
if closed question mode is true:
do this.
if closed question mode is false:
do that.
Chapter: Asking questions
Section: Setting the current question
To ask a question, we first set the text for the question. The form is:
now the current question is "How old are you?"
Section: Setting items for menu questions
Before we ask a question that requires an answer from a menu of options, we need to set the menu items to be displayed. We do this by setting the variable "current question menu" to the list of options that we require.
now current question is "What is your favourite colour? >";
now current question menu is { "Red", "Blue", "Green", "Yellow" };
ask a closed question, in menu mode.
Section: Asking the question in closed question mode
To ask the question in closed mode, we use the following forms for closed questions:
ask a closed question, in number mode;
ask a closed question, in real number mode;
ask a closed question, in menu mode;
ask a closed question, in yes/no mode;
ask a closed question, in gender mode;
ask a closed question, in text mode;
Section: Asking the question in open question mode
To ask the question in open mode, we use the following forms for open questions:
ask an open question, in number mode;
ask an open question, in real number mode;
ask an open question, in menu mode;
ask an open question, in yes/no mode;
ask an open question, in gender mode;
ask an open question, in text mode;
Chapter: Setting the command prompt for questions
Section: Overview
When a question is asked, we can change the command prompt to indicate to the player that a question is being asked. By default, the extension sets a series of default prompts. These are specific to the type of question being asked; they are:
Closed number prompt: "Please enter a whole number >".
Open number prompt: ">".
Closed real number prompt: "Please enter a number >".
Open real number prompt: ">".
Closed menu prompt: "Please select a number between 1 and [number of entries in current question menu] >".
Open menu prompt is ">".
Closed yes/no prompt: "Please enter Y or N (Yes or No) >".
Open yes/no prompt: ">".
Closed gender prompt: "Please enter M, F or N (Male or Female or Neuter) >".
Open gender prompt: ">".
Closed text prompt: "Please enter your answer >".
Open text prompt ">".
Section: Changing the question prompt
To change the question prompt, we set the variable "current prompt" to the text that we want:
Now current question is "How old are you?";
Now the current prompt is "Enter a number between 5 and 111: >"
Ask a closed question, in number mode.
If we set the current prompt to "", the relevant default prompt outlined above will be used.
Section: Combining the question and prompt
We can combine the question and the prompt. To do so, we set the current question to a blank string and the question prompt to the question that we want to ask:
now current question is "";
now current prompt is "What is your name? >";
ask a closed question, in text mode.
Chapter: Responding to the answers given
Section: Player input
The player can answer a question by typing the number, menu number, yes / no response, gender response or text. The player can also answer a question by using the form 'say X' where X is the answer given.
Section: Rulebooks
When we answer a question, the answer is processed by a rulebook. By adding our own rules in the game, we can tailor the Questions extension to provide the functionality that we require.
Each type of question has its own rulebook. These are:
Number questions: The number question rules.
Real number questions: The real number question rules.
Menu questions: The menu question rules.
Yes/No questions: The yes/no question rules.
Gender questions: The gender questions rules.
Text questions: The text question rules.
Section: Rulebook outcomes
Each rulebook has three named outcomes that we can use to control how the game proceeds. The outcomes are:
Exit: The answer to the question is discarded and the game proceeds as normal. Usually, we will have used the answer to set other conditions in the game before we use exit. The exit outcome automatically advances the game by one turn.
Retry: The answer to the question is discarded but we remain in question mode awaiting another answer. Usually, this will be because the answer to the question is not a valid answer.
Parse: The answer to the question is not disregarded and the question mode ends leaving the answer to be parsed as normal. Usually, we use this where there is an open question.
Section: Default rules
Each rulebook has default rules. If we do not create our own rules, the default rules control how answers are processed. The default rules are set out below.
Section: Adding our own rules
We can add our own rules in the game. For example:
A number question rule (this is the set age rating rule):
if the current question is "How old are you?":
if the number understood is less than 5:
say "It seems unlikely that a person of such tender years would be playing this game.";
retry;
if the number understood is greater than 111:
say "I find it hard to believe that this is your real age. Please be more realistic.";
retry;
if the number understood is less than 21:
say "Setting the game mode to mild!";
now gamemode is mild;
otherwise:
say "Setting the game mode to crude!";
now gamemode is crude;
exit.
A menu question rule (this is the channel rule):
if the current question is "Which channel would you like to watch on the telly?":
if the number understood is 1:
say "Raucous music blasts out from the local music TV station.";
if the number understood is 2:
say "The film that comes on is so raunchy that even a hard-bitten army sergeant would blush with shame";
if the number understood is 3:
say "The latest trend in reality TV assails you - celebrity navel transplants!";
if the number understood is 4:
say "You stomach turns with disgust - the collected speeches of George Bush begin to play.";
exit.
Section: Rules for number questions
We test the answer to a number question using the phrase 'the number understood'.
There are two default rules for processing answers to number questions.
The first rule, called 'the invalid number reply rule', operates where the player enters an answer to a number question that is not a number. If the question is a closed number question, the outcome is retry. If the question is an open question, the outcome is parse.
The last rule, called 'the default number question rule', has the outcome exit.
Section: Rules for real number questions
We test the answer to a real number question using the phrase 'the number understood'.
There are two default rules for processing answers to real number questions.
The first rule, called 'the invalid real number reply rule', operates where the player enters an answer to a real number question that is not a real number. If the question is a closed number question, the outcome is retry. If the question is an open question, the outcome is parse.
The last rule, called 'the default real number question rule', has the outcome exit.
Section: Rules for menu questions
We test the answer to menu questions using the phrase 'the number understood'. The value should be between 1 and the number of items in the menu.
There are two default rules for processing answers to menu questions.
The first rule, called the 'invalid menu reply rule' first tests whether the player has entered a number. If the player has entered an answer that is not a number, the outcome is retry if the question was a closed menu question or parse if the question was an open menu question. If a numbered was entered that falls outside the range 1 to the number of items in the menu, the outcome is retry for both open and closed menu questions.
The last rule, called the 'default menu rule', has the outcome exit.
Section: Rules for Yes/No questions
We test the answer to yes/no questions using the phrase 'the decision understood'. The decision understood takes one of two values, 'Yes' or 'No'. 'Y' and 'N' are understood as Yes and No when the player types their response.
There are two default rules for processing the answers to yes/no questions.
The first rule, called the 'invalid yes/no reply rule' tests whether the player has entered Yes or No. If the player has not so responded, the outcome is retry if the question is a closed yes/no question or parse if the question is a closed menu question.
The last rule, called the 'default yes/no rule', has the outcome exit.
Section: Rules for gender questions
The test the answer to gender questions using the phrase 'the gender understood'. The gender understood takes one of three values, 'Masculine', 'Feminine' or 'Neutral'. 'M', 'F' and 'N' are understood as Masculine, Feminine and Neutral when the player types their response. Neutral is used instead of Neuter as Neuter is defined as an adjective in I7.
There are two default rules for processing the answers to gender questions.
The first rule, called the 'invalid gender reply rule' tests whether the player has entered a valid gender. If the player has not entered a valid gender, the outcome is retry if the question is a closed gender question or parse if the question is an open gender question.
The last rule, called the 'default gender rule', has the outcome exit.
Section: Rules for text questions
We test the answer to text questions using the variable "current answer". The current answer is set to the player's answer. If the answer was given in the form "say answer", the word "say" and the following space is also removed.
There are two default rules for text questions.
The first rule, called the 'remove punctuation from text questions rule' determines whether or not punctuation is removed from the player's answer before it is processed. We can control punctuation removal by setting the truth state 'punctuation removal'.
now punctuation removal is true;
now punctuation removal is false;
The last rule is called the 'default text rule'. If the question was a closed text question, the outcome is retry. If the question was an open text question, the outcome is parse.
Chapter: Determining whether or not we are asking a question
If we need to determine whether or not we are currently asking a question, for example as a test in another rulebook, we can do so by using the phrase 'If we are asking a question'. This will decide Yes if an open or closed question is being asked.
Example: * Open Sesame - A short example to show the question rules with an initial open text question followed by an interview section to gather information about the player.
"Open Sesame" by Michael Callaghan
Include questions by Michael Callaghan.
Canyon is a room. "You are at the far end of a canyon. A recent rock fall behind you prevents all further hopes of escape. A large boulder to the east emits a faint green light."
A large boulder is a door. The large boulder is locked and closed.
The large boulder is scenery. The description is "Inscribed in runic letters on the face of the boulder are the words 'Solve Oriel[']s Myth to find your way forward.'"
Instead of doing anything other than examining with the large boulder:
say "There is an aura of magic about the large boulder that prevents you doing this."
Small cave is a room. "A flight of steps leads down into the darkness."
The large boulder is east of the canyon and west of the small cave.
Introduction is a scene.
Introduction begins when play begins.
Introduction ends when the large boulder is open.
When introduction begins:
follow the set open sesame rule.
Every turn when introduction is happening (this is the set open sesame rule):
now current question is "";
now current prompt is ">";
now punctuation removal is true;
ask an open question, in text mode.
A text question rule (this is the open sesame rule):
if introduction is happening:
if the current answer is "emily short":
say "With an eerie screech, the boulder rolls to one side.";
now the large boulder is open;
now the large boulder is unopenable;
exit;
otherwise:
parse.
Room of requirements is a room. Room of requirements is down from the small cave. The description is "The room smells musty.[If unvisited] An alien presence invades your mind and deep in your bones you hear a voice echo 'Welcome brave soul. You have passed the first hurdle. Before you proceed, you must answer the following questions.'"
Instead of doing anything when gathering is happening and stage is not complete:
say "You are under a strange compulsion and unable to move."
Data is a kind of value. The data are name, age, sex, character, finalise, seed and complete.
Gathering is a scene. Gathering begins when the location is the room of requirements.
Gathering ends when stage is complete.
Stage is data that varies.
When Gathering begins:
now stage is name.
Every turn during Gathering:
if stage is name:
now current question is "What is your name?";
now current prompt is "Enter your name >";
now punctuation removal is false;
ask a closed question, in text mode;
if stage is age:
now current question is "How old are you?";
ask a closed question, in number mode;
if stage is sex:
now current question is "Do you want to play as a male, female or neutral character";
ask a closed question, in gender mode;
if stage is character:
now current question is "Which of the following is your preferred character type:";
now current question menu is { "Wizard", "Warrior", "Sage", "Healer" };
ask a closed question, in menu mode;
if stage is finalise:
say "You have chosen:[line break]Name: [player's name][line break]Age: [Player's age][line break]Sex: [Player's sex][line break]Character: [Player's character][paragraph break]";
now current question is "Are you happy with your responses?";
ask a closed question, in yes/no mode;
if stage is seed:
now current question is "Enter a seed number between 0 and 1:";
ask a closed question, in real number mode.
The player's name is indexed text that varies.
The player's age is a number that varies.
The player's sex is a gender that varies.
The player's character is text that varies.
The player's strength is a number that varies.
A text question rule (this is the gather name rule):
if gathering is happening and stage is name:
if the number of words in the current answer is greater than 1:
say "I think we will simply refer to you as [word number 1 in the current answer][line break]";
now the player's name is word number 1 in the current answer;
otherwise:
now the player's name is the current answer;
say "Welcome to this venture, [player's name][line break]";
now stage is age;
exit.
A number question rule (this is the gather age rule):
if gathering is happening and stage is age:
if the number understood is less than 5:
say "It seems improbable that one of such tender years would be venturing so far.[line break]";
retry;
if the number understood is greater than 111:
say "Let's try to be realistic about this.";
retry;
now the player's age is the number understood;
say "Thank you: You are [the player's age] for the remainder of your venture into the unknown[line break]";
now stage is sex;
exit.
A gender question rule (this is the gather gender rule):
if gathering is happening and stage is sex:
now the player's sex is the gender understood;
say "Thank you. You are [the player's sex] gender[line break]";
now stage is character;
exit.
A menu question rule (this is the gather character rule):
if gathering is happening and stage is character:
let temp be the number understood;
now the player's character is entry temp in the current question menu;
say "Thank you, you are playing as a [player's character][line break]";
now stage is finalise;
exit.
A yes/no question rule (this is the confirm answers rule):
if gathering is happening and stage is finalise:
if the decision understood is Yes:
say "Thank you.";
now stage is seed;
exit;
otherwise:
say "OK. Let's start again, shall we[line break]";
now stage is name;
exit.
A real number question rule (this is the seed rule):
if gathering is happening and stage is seed:
if the real number understood is 0.0:
say "The number must be more than 0";
retry;
if the real number understood < 0.0:
say "The number must be more than 0";
retry;
if the real number understood is 1.0:
say "The number must be less than 1.";
retry;
if the real number understood > 1.0:
say "The number must be less than 1.";
retry;
let seed be the real number understood;
repeat with counter running from 1 to a random number from 5 to 10:
now seed is seed times 997;
now seed is seed minus floor of seed;
now seed is seed times 100;
now seed is floor of seed;
now player's strength is seed to the nearest whole number;
say "Your strength has been set to [player's strength].";
now stage is complete;
say "Venture into the unknown brave [player's character].";
exit.
Test me with "x boulder / push boulder/ say Emily Short / e / d / Peter / 34 / M / 3 / Y / 0.23448".
Example: * Quiz Night - A short example to show creating a multiple choice quiz.
"Quiz Night" by Michael Callaghan
Include questions by Michael Callaghan.
The pub is a room. "The pub is crowded for the weekly quiz night. The barman is ready to call out the questions. Get one wrong and you will be barred from the pub for life."
After looking for the first time:
follow the pub rule.
Table of quiz questions
Qn Options Correct "In which year was the Battle of Hastings" { "1256", "1066", "1589", "1790" } 2 "What type of animal is Basil Brush" { "Cat", "Dog", "Rabbit", "Fox" } 4 "What is the square root of 126736?" { "356", "289", "421", "321" } 1 "How many books are there in the Old Testament" { "23", "39", "37", "41" } 2 "What is a Cantaloupe?" { "Animal", "Star", "Fruit", "Vegetable" } 3
The expected answer is a number that varies.
Every turn when the location is the pub (this is the pub rule):
choose a random row in the table of quiz questions;
now current question is the Qn entry;
now current question menu is the Options entry;
now expected answer is the correct entry;
blank out the whole row;
ask a closed question, in menu mode.
A menu question rule (this is the pub answer rule):
if the number understood is the expected answer:
if the table of quiz questions is not empty:
say "Well done. You have survived to the next round.";
otherwise:
end the story finally saying "Congratulations you have won!";
otherwise:
end the story finally saying "You have been barred from the pub for getting a question wrong.".