Actionclass
Basic Action class. An Action is the language-independent definition of the abstract action of a command.
Modified in
en_us.t[8119]:
Language-specific Action modifications.
class
Action
:
BasicProd
Superclass Tree (in declaration order)
Action
BasicProd
` object`
Subclass Tree
Action
CommandActorAction
EventAction
IAction
AgainAction
predicate(Again)
ConvIAction
GoodbyeAction
predicate(Goodbye)
HelloAction
predicate(Hello)
NoAction
predicate(No)
YesAction
predicate(Yes)
DebugAction
ExitsAction
predicate(Exits)
GetOutAction
predicate(GetOut)
GoBackAction
predicate(GoBack)
InventoryAction
predicate(Inventory)
InventoryTallAction
predicate(InventoryTall)
InventoryWideAction
predicate(InventoryWide)
JumpAction
predicate(Jump)
JumpOffIAction
predicate(JumpOffI)
LieAction
predicate(Lie)
LiteralAction
OopsAction
predicate(Oops)
SpecialTopicAction
predicate(SpecialTopic)
LookAction
predicate(Look)
NoteDarknessAction
OopsIAction
predicate(OopsOnly)
predicate(EmptySpecialTopic)
SenseImplicitAction
ListenImplicitAction
predicate(ListenImplicit)
SmellImplicitAction
predicate(SmellImplicit)
SitAction
predicate(Sit)
SleepAction
predicate(Sleep)
StandAction
predicate(Stand)
SystemAction
AboutAction
predicate(About)
CreditsAction
predicate(Credits)
ExitsModeAction
predicate(ExitsMode)
FileOpAction
RecordAction
predicate(Record)
RecordEventsAction
predicate(RecordEvents)
RecordStringAction
predicate(RecordString)
RecordEventsStringAction
predicate(RecordEventsString)
ReplayAction
ReplayStringAction
predicate(ReplayQuiet)
predicate(ReplayString)
SaveAction
predicate(Save)
SaveStringAction
predicate(SaveString)
ScriptAction
predicate(Script)
ScriptStringAction
predicate(ScriptString)
FootnoteAction
predicate(Footnote)
FootnotesAction
FootnotesFullAction
predicate(FootnotesFull)
FootnotesMediumAction
predicate(FootnotesMedium)
FootnotesOffAction
predicate(FootnotesOff)
FootnotesStatusAction
predicate(FootnotesStatus)
FullScoreAction
predicate(FullScore)
HintAction
predicate(Hint)
HintsOffAction
predicate(HintsOff)
InstructionsAction
predicate(instructions)
NotifyAction
predicate(Notify)
NotifyOffAction
predicate(NotifyOff)
NotifyOnAction
predicate(NotifyOn)
PauseAction
predicate(Pause)
QuitAction
predicate(Quit)
RecordOffAction
predicate(RecordOff)
RestartAction
predicate(Restart)
RestoreAction
predicate(Restore)
RestoreStringAction
predicate(RestoreString)
RestoreDefaultsAction
predicate(RestoreDefaults)
SaveDefaultsAction
predicate(SaveDefaults)
ScoreAction
predicate(Score)
ScriptOffAction
predicate(ScriptOff)
TerseAction
predicate(Terse)
TipModeAction
predicate(TipsOff)
predicate(TipsOn)
TopicsAction
predicate(Topics)
UndoAction
predicate(Undo)
VerboseAction
predicate(Verbose)
VersionAction
predicate(Version)
TopicAction
TravelAction
AftAction
DownAction
EastAction
ForeAction
InAction
predicate(In)
NorthAction
NortheastAction
NorthwestAction
OutAction
predicate(Out)
PortAction
predicate(Port)
predicate(Travel)
SouthAction
SoutheastAction
SouthwestAction
StarboardAction
predicate(Starboard)
TravelDirAction
UpAction
WestAction
VagueTravelAction
predicate(VagueTravel)
WaitAction
predicate(Wait)
YellAction
predicate(Yell)
TAction
AttackAction
predicate(Attack)
BoardAction
predicate(Board)
BreakAction
predicate(Break)
BurnAction
predicate(Burn)
CleanAction
predicate(Clean)
ClimbAction
predicate(Climb)
ClimbDownAction
predicate(ClimbDown)
predicate(ClimbDownWhat)
ClimbUpAction
predicate(ClimbUp)
predicate(ClimbUpWhat)
CloseAction
predicate(Close)
ConsultAction
predicate(Consult)
CutAction
DetachAction
predicate(Detach)
DigAction
predicate(Dig)
DoffAction
predicate(Doff)
DrinkAction
predicate(Drink)
DropAction
predicate(Drop)
EatAction
predicate(Eat)
EnterAction
predicate(Enter)
ExamineAction
predicate(Examine)
ExtinguishAction
predicate(Extinguish)
FastenAction
predicate(Fasten)
FeelAction
predicate(Feel)
FlipAction
predicate(Flip)
FollowAction
predicate(Follow)
GetOffOfAction
predicate(GetOffOf)
GetOutOfAction
predicate(GetOutOf)
GoThroughAction
predicate(GoThrough)
JumpOffAction
predicate(JumpOff)
JumpOverAction
predicate(JumpOver)
KissAction
predicate(Kiss)
LieOnAction
predicate(LieOn)
LightAction
predicate(Light)
ListenToAction
predicate(ListenTo)
LiteralTAction
EnterOnAction
predicate(EnterOn)
predicate(EnterOnWhat)
SetToAction
predicate(SetTo)
TurnToAction
predicate(TurnTo)
TypeLiteralOnAction
predicate(TypeLiteralOn)
predicate(TypeLiteralOnWhat)
LockAction
predicate(Lock)
LookBehindAction
predicate(LookBehind)
LookInAction
predicate(LookIn)
LookThroughAction
predicate(LookThrough)
LookUnderAction
predicate(LookUnder)
MoveAction
predicate(Move)
OpenAction
predicate(Open)
PlugInAction
predicate(PlugIn)
PourAction
predicate(Pour)
PullAction
predicate(Pull)
PushAction
predicate(Push)
PushTravelAction
PushTravelDirAction
predicate(PushTravelDir)
PushAftAction
PushDownAction
PushEastAction
PushForeAction
PushInAction
PushNorthAction
PushNortheastAction
PushNorthwestAction
PushOutAction
PushPortAction
PushSouthAction
PushSoutheastAction
PushSouthwestAction
PushStarboardAction
PushUpAction
PushWestAction
PushTravelViaIobjAction
PushTravelClimbDownAction
predicate(PushTravelClimbDown)
PushTravelClimbUpAction
predicate(PushTravelClimbUp)
PushTravelEnterAction
predicate(PushTravelEnter)
PushTravelGetOutOfAction
predicate(PushTravelGetOutOf)
PushTravelThroughAction
predicate(PushTravelThrough)
ReadAction
predicate(Read)
RemoveAction
predicate(Remove)
ScrewAction
predicate(Screw)
SearchAction
predicate(Search)
SetAction
predicate(Set)
SitOnAction
predicate(SitOn)
SmellAction
predicate(Smell)
StandOnAction
predicate(StandOn)
StrikeAction
predicate(Strike)
SwitchAction
predicate(Switch)
TakeAction
predicate(Take)
TalkToAction
predicate(TalkTo)
predicate(TalkToWhat)
TasteAction
predicate(Taste)
ThrowAction
predicate(Throw)
ThrowDirAction
predicate(ThrowDir)
predicate(ThrowDirDown)
TIAction
AttachToAction
predicate(AttachTo)
predicate(AttachToWhat)
AttackWithAction
predicate(AttackWith)
BurnWithAction
predicate(BurnWith)
CleanWithAction
predicate(CleanWith)
CutWithAction
predicate(CutWith)
predicate(CutWithWhat)
DetachFromAction
predicate(DetachFrom)
DigWithAction
predicate(DigWith)
FastenToAction
predicate(FastenTo)
GiveToAction
predicate(GiveTo)
predicate(GiveToType2)
predicate(GiveToWhom)
LockWithAction
predicate(LockWith)
MoveToAction
predicate(MoveTo)
MoveWithAction
predicate(MoveWith)
PlugIntoAction
predicate(PlugInto)
predicate(PlugIntoWhat)
PourIntoAction
predicate(PourInto)
PourOntoAction
predicate(PourOnto)
PushTravelViaIobjAction
PushTravelClimbDownAction
predicate(PushTravelClimbDown)
PushTravelClimbUpAction
predicate(PushTravelClimbUp)
PushTravelEnterAction
predicate(PushTravelEnter)
PushTravelGetOutOfAction
predicate(PushTravelGetOutOf)
PushTravelThroughAction
predicate(PushTravelThrough)
PutBehindAction
predicate(PutBehind)
PutInAction
predicate(PutIn)
predicate(PutInWhat)
PutOnAction
predicate(PutOn)
PutUnderAction
predicate(PutUnder)
ScrewWithAction
predicate(ScrewWith)
ShowToAction
predicate(ShowTo)
predicate(ShowToType2)
predicate(ShowToWhom)
TakeFromAction
predicate(TakeFrom)
ThrowAtAction
predicate(ThrowAt)
ThrowToAction
predicate(ThrowTo)
predicate(ThrowToType2)
TurnWithAction
predicate(TurnWith)
UnfastenFromAction
predicate(UnfastenFrom)
UnlockWithAction
predicate(UnlockWith)
UnplugFromAction
predicate(UnplugFrom)
UnscrewWithAction
predicate(UnscrewWith)
TopicTAction
AskVagueAction
predicate(AskVague)
predicate(TellVague)
ConsultAboutAction
predicate(ConsultAbout)
predicate(ConsultWhatAbout)
ConvTopicTAction
AskAboutAction
predicate(AskAbout)
predicate(AskAboutImplicit)
predicate(AskAboutWhat)
AskForAction
predicate(AskFor)
predicate(AskWhomFor)
TellAboutAction
predicate(TellAbout)
predicate(TellAboutImplicit)
predicate(TellAboutWhat)
TellVagueAction
TravelViaAction
EnTravelVia
TurnAction
predicate(Turn)
TurnOffAction
predicate(TurnOff)
TurnOnAction
predicate(TurnOn)
TypeOnAction
predicate(TypeOn)
UnfastenAction
predicate(Unfasten)
UnlockAction
predicate(Unlock)
UnplugAction
predicate(Unplug)
UnscrewAction
predicate(Unscrew)
WearAction
predicate(Wear)
Global Objects
(none)
Summary of Properties
actionTime
afterActionMainList
beforeAfterObjs
defaultForRecursion
extraMessageParams
implicitMsg
includeInUndo
isImplicit
isRepeatable
iterationCanceled
originalAction
parentAction
preCond
predicateNounPhrases
pronounOverride
remappedFrom
showDefaultReports
synthParamID
verbFlags
verifiedOkay
Inherited from BasicProd
:
firstTokenIndex
isSpecialResponseMatch
lastTokenIndex
Summary of Methods
actionOfKind
addBeforeAfterObj
afterAction
afterActionMain
announceActionObject
announceAllDefaultObjects
announceDefaultObject
beforeAction
beforeActionMain
cacheMultiObjectAnnouncements
callAfterActionMain
callCatchAllProp
callPreConditions
callVerifyPreCond
callVerifyProp
cancelIteration
checkAction
checkPreConditions
checkRemapping
combineRemappedVerifyResults
createActionFrom
createActionInstance
createTopicQualifierResolver
doAction
doActionOnce
execAction
filterAmbiguousWithVerify
filterFacets
filterPluralWithVerify
finishResolveList
getAnaphoricBinding
getCurrentObjects
getDefaultWithVerify
getEnteredVerbPhrase
getImplicitPhrase
getInfPhrase
getMatchForRole
getMessageParam
getNotifyTable
getObjectForRole
getObjPreCondDescList
getObjPreConditions
getObjResponseProd
getOriginalAction
getOrigTokenList
getOtherObjectRole
getParticiplePhrase
getPreCondDescList
getPreCondPropForRole
getPredicate
getPronounOverride
getQuestionInf
getRemappedFrom
getRemapPropForRole
getResolvedObjList
getResolveInfo
getRoleFromIndex
getSimpleSynonymRemap
getSortedVerifyResults
getVerbPhrase
getVerifyPropForRole
initTentative
isConversational
isNestedIn
isPartOf
isRemapped
makeResolveInfo
makeResolveInfoList
maybeAnnounceDefaultObject
maybeAnnounceImplicit
maybeAnnounceMultiObject
noMatch
notifyBeforeAfter
objListPronoun
preAnnounceActionObject
recalcSenseContext
repeatAction
resetAction
resolveAction
resolvedObjectsInScope
runBeforeNotifiers
saveActionForAgain
setCurrentObjects
setImplicit
setMessageParam
setMessageParams
setNested
setObjectMatches
setOriginalAction
setPronounOverride
setRemapped
setResolvedObjects
spPrefix
spSuffix
synthMessageParam
verifyAction
verifyHandlersExist
whatObj
whatTranslate
withVerifyResults
zeroActionTime
Inherited from BasicProd
:
canResolveTo
getOrigText
setOrigTokenList
Properties
actionTime
the amount of time on the game clock that the action consumes - by default, each action consumes one unit, but actions can override this to consume more or less game time
afterActionMainList
list of methods to invoke after we’ve completed the action
beforeAfterObjs
vector of objects requiring explicit before/after notification
defaultForRecursion
the defaultForRecursion flag must be explicitly set in subclasses when desired - by default we’ll use any language-specific subclass of an Action for recursive commands
extraMessageParams
Extra message parameters. If a message processor wants to add special message parameters of its own, we’ll create a lookup table for the extra parameters. Message processors might want to add their own special parameters to allow referring to objects other than the main objects of the command.
implicitMsg
the libMessage property, if any, to announce the implicit command
includeInUndo
Flag: this command should be included in the undo records. This is true for almost every command, but a few special commands (undo, save) are not subject to undo.
isImplicit
Flag: the command is implicit. An implicit command is one that is performed as an implied enabling step of another command - for example, if an actor wants to throw something, the actor must be holding the object, so will implicitly try to take the object.
isRepeatable
Flag: this command is repeatable with ‘again’. Before executing a command, we’ll save it for use by the ‘again’ command if this flag is true.
iterationCanceled
internal flag: object iteration has been canceled
originalAction
the original action - we are effectively part of the original action for reporting purposes
parentAction
The parent action. If the command is performed programmatically in the course of executing another command, this is set to the enclosing action.
Note that while all implicit commands are nested, not all nested commands are implicit. A nested command may simply be a component of another command, or another command may be handled entirely by running a different command as a nested command. In any case, a nested but non-implicit command does not appear to the player as a separate command; it is simply part of the original command.
preCond
Our list of action-level pre-condition objects. These are the conditions that apply to the overall action, not to the individual objects involved. (Object-level pre-conditions are attached to the objects, not to the action.)
predicateNounPhrases
Get the noun-phrase information for my predicate grammar. This returns a list of the match-tree properties for the noun-phrase sub-productions in our predicate grammar. The properties generally include &dobjMatch, &iobjMatch, &literalMatch, and &topicMatch. The order of the slots isn’t important; they simply tell us which ones we should find in our predicate grammar match.
The base Action is intransitive, so it doesn’t have any noun-phrase slots, hence this is an empty list.
pronounOverride
the pronoun override table - this is nil by default, which means that no overrides have been defined yet; we create a LookupTable upon adding the first entry to the table
remappedFrom
The original action we were remapped from. This is valid when the action was explicitly remapped during the remap() phase to a different action.
showDefaultReports
Flag: we are to show default reports for this action. In most cases we will do so, but for some types of commands (such as implicit commands), we suppress default reports.
synthParamID
synthesized message object parameter serial number
verbFlags
Verb flags - these are used to control certain aspects of verb formatting. By default, we have no special flags.
verifiedOkay
List of objects that verified okay on a prior pass. This is a scratch-pad for use by verifier routines, to keep track of work they’ve already done. A few verifiers use this as a way to detect when an implicit action actually finished the entire job, which would in many cases result in a verify failure if not checked (because a command that effects conditions that already hold is normally illogical); by tracking that the verification previously succeeded, the verifier can know that the action should be allowed to proceed and do nothing.
Methods
actionOfKind (cls)
Are we the given kind of action? By default, this simply returns true if we’re of the given action class.
addBeforeAfterObj (obj)
Register an object for explicit inclusion in beforeAction and afterAction notifications. This can be used to register objects that might not be connected by containment or otherwise notifiable by normal means. If this is called after the beforeAction notification loop has already started, then the object will only be sent an afterAction notification.
afterAction ( )
Run our action-specific post-processing. By default, we do nothing here.
afterActionMain ( )
Perform processing after running the entire action. This is called just once per action, even if the action was iterated for a list of objects.
announceActionObject (info, numberInList, whichObj)
Announce the object of an action. This should be used for each iteration of a command that takes objects to announce the objects on this iteration.
We announce an object under several circumstances:
- If we are iterating through multiple objects, we’ll show the current object to show the player the individual step in the command being performed.
- If ‘all’ was used to specify the object, we’ll announce it even if only one object is involved, to make it clear to the player exactly what we chose as a match.
- If we are executing the command on a single object, and the object was chosen through disambiguation of a set of ambiguous choices, and some of the discarded possibilities were logical but less so than the chosen object, we’ll show the assumption we made. In such cases, our assumption is not necessarily correct, so we’ll tell the user about our choice explicitly by way of confirmation - this gives the user a better chance of noticing quickly if our assumption was incorrect.
- If we supplied a default for a missing noun phrase in the player’s command, we’ll show what we chose. Since the player didn’t say what they meant, we’ll make it plain that we’re providing an assumption about what we thought they must have meant.
‘info’ is the ResolveInfo object describing this resolved object, and ‘numberInList’ is the total number of objects we’re iterating over for this object function (direct object, indirect object, etc). ‘whichObj’ is one of the object function constants (DirectObject, IndirectObject, etc) describing which object we’re mentioning; the language-specific message generator might use this in conjunction with the action to include a preposition with the displayed phrase, for example, or choose an appropriate inflection.
announceAllDefaultObjects (allResolved)
Announce all defaulted objects in the action. By default, we show nothing.
announceDefaultObject (obj, whichObj, resolvedAllObjects)
Announce a default object used with this action.
‘resolvedAllObjects’ indicates where we are in the command processing: this is true if we’ve already resolved all of the other objects in the command, nil if not. We use this information to get the phrasing right according to the situation.
beforeAction ( )
Run our action-specific pre-processing. By default, we do nothing here.
beforeActionMain ( )
Perform processing before running the action. This is called just once per action, even if the action will be iterated for a list of objects.
cacheMultiObjectAnnouncements (lst, whichObj)
Pre-calculate the multi-object announcement text for each object. This is important because these announcements might choose a form for the name that distinguishes it from the other objects in the iteration, and the basis for distinction might be state-dependent (such as the object’s current owner or location), and the relevant state might change as we iterate over the objects. From the user’s perspective, they’re referring to the objects based on the state at the start of the command, so the user will expect to see names based on the that state.
callAfterActionMain (obj)
Register an object for afterActionMain invocation. After we’ve finished with the entire action - including all iterated objects involved in the action - we’ll invoke each registered object’s afterActionMain() method. This registration is only meaningful for the current action instance, and can only be set up before the action has been finished (i.e., before the current gAction invokes its own afterActionMain() method).
Each object is only registered once. If a caller attempts to register the same object repeatedly, we’ll simply ignore the repeated requests.
This is a convenient way to implement a collective follow-up to the parts of an iterated action. Since repeated registrations are ignored, each handler for an iterated object (such as a “dobjFor” action() handler) can register its follow-up handler without worrying about redundant registration. Then, when the overall action is completed for each iterated object involved, the follow-up handler will be invoked, and it can do any final work for the overall action. For example, the follow-up handler could display a message summarizing the iterated parts of the action; or, it could even scan the transcript for particular messages and replace them with a summary.
callCatchAllProp (obj, actionProp, defProp, allProp)
Call a catch-all property on the given object.
actionProp is the custom per-object/per-action property that we normally invoke to process the action. For example, if we’re processing verification for the direct object of Take, this would be &verifyDobjTake.
defProp is the default property that corresponds to actionProp. This is the per-object/default-action property that we invoke when the object doesn’t provide a “more specialized” version of actionProp - that is, if the object doesn’t define or inherit actionProp at a point in its class hierarchy that is more specialized than the point at which it defines defProp, we’ll call defProp. If there is a more specialized definition of actionProp for the object, it effectively overrides the default handler, so we do not invoke the default handler.
allProp is the catch-all property corresponding to actionProp. We invoke this property in all cases.
Returns true if there is indeed a Default property that overrides the action, nil if not.
callPreConditions (lst, allowImplicit)
Call a method on all of the precondition objects in the precondition list obtained from the given property of the given object.
callVerifyPreCond (resultSoFar)
Verify the non-object-related pre-conditions. This runs verification on each of the pre-condition objects defined for the action.
callVerifyProp (obj, verProp, preCondProp, remapProp, resultSoFar, whichObj)
Call a verification routine. This creates a results object and makes it active, then invokes the given verification routine on the given object.
We call verification directly on the object, and we also call verification on the object’s preconditions.
If resultSoFar is non-nil, it is a VerifyResultList that has the results so far - this can be used for multi-object verifications to gather all of the verification results for all of the objects into a single result list. If resultSoFar is nil, we’ll create a new result list.
cancelIteration ( )
Cancel iteration of the action. This can be called during the ‘check’ or ‘action’ phases of executing this action. It tells the action that we want to stop executing the action when we’re finished with the current object.
Note that this doesn’t cause a jump out of the current code, so it’s not like ‘exit’ or the other termination signals. Instead, this simply tells the action to proceed normally for the remainder of the processing for the current object, and then act as though there were no more objects to iterate over, ending the command normally. If you want to cut off the remainder of the execution cycle for the current object, you can use ‘exit’ (for example) immediately after calling this method.
checkAction ( )
Check the action. This runs the ‘check’ phase, and must be overridden for each subclass.
Intransitive actions don’t generally have to do anything in the ‘check’ phase, since they can simply do any necessary checks in the ‘execute’ phase that runs immediately after ‘check’. This phase is separated out from ‘execute’ mostly for the benefit of transitive actions, where the ‘check’ phase gives the involved objects a chance to object to the action.
checkPreConditions (allowImplicit)
Check any pre-conditions for the action.
This should check all of the conditions that must be met for the action to proceed. If any pre-condition can be met by running an implicit command first, that implicit command should be executed here. If any pre-condition cannot be met, this routine should notify the actor and throw an ExitSignal.
Returns true if any implicit commands are executed, nil if not. Implicit commands can only be attempted if allowImplicit is true; if this is nil, a precondition must simply fail (by displaying an appropriate failure report and using ‘exit’) without attempting an implicit command if its assertion does not hold.
checkRemapping ( )
Check for remapping the action. This should check with each resolved object involved in the command to see if the object wants to remap the action to a new action; if it does, the object must replace the current action (using replaceAction or equivalent). Note that replacing the action must use ‘exit’ to terminate the original action, so this will never return if remapping actually does occur.
combineRemappedVerifyResults (lst, role)
Combine any remapped verify results in the given verify result list. We will remove any result that was remapped to a different object if and only if the target of the remapping appears in the list and has the same results as the remapped original. When objects are remapped in this fashion, they become effectively equivalent for the purposes of this command, so we don’t have to distinguish between them for disambiguation or defaulting purposes.
createActionFrom (orig)
Create an instance of this action based on another action. We’ll copy the basic properties of the original action.
createActionInstance ( )
Create an instance of this action, for use by a recursive or programmatically-generated command.
The generic actions defined in the library are always subclassed by language-specific library modules, because the language modules have to define the grammar rules for the verbs - we can’t define the grammar rules generically because the verbs wouldn’t be reusable for non-English translations if we did. As a result, library code referring to one of the library verbs by name, say TakeAction, doesn’t get a language-specific subclass of the verb, but just gets the language-independent base class.
However, to make full use of an Action object in a recursive command, we do need a final language-specific subclass - without this, we won’t be able to generate text describing the command, for example. This method bridges this gap by finding a suitable language-specific subclass of the given action, then creating an instance of that subclass rather than an instance of the base class.
By default, we’ll take any subclass of this action that is itself a class. However, if any subclass has the property defaultForRecursion set to true, we’ll use that class specifically - this lets the language module designate a particular subclass to use as the default for recursive commands, which might be desirable in cases where the language module defines more than one subclass of an action.
createTopicQualifierResolver (issuingActor, targetActor)
Create a topic qualifier resolver. This type of resolver is used for qualifier phrases (e.g., possessives) within topic phrases within objects of this verb. Topics *usually* only apply to TopicActionBase subclasses, but not exclusively: action remappings can sometimes require a topic phrase from one action to be resolved in the context of another action that wouldn’t normally involve a topic phrase. That’s why this is needed on the base Action class.
doAction (issuingActor, targetActor, targetActorPhrase, countsAsIssuerTurn)
Perform this action. Throughout execution of the action, the global parser variables that specify the current actor and action are valid.
doActionOnce ( )
Execute the action for a single set of objects. This runs the full execution sequence for the current set of objects.
Subclasses generally won’t override this method, but will instead override the methods that implement the individual steps in the execution sequence.
execAction ( )
Execute the action. This must be overridden by each subclass.
Intransitive actions must do all of their work in this routine. In most cases, transitive actions will delegate processing to one or more of the objects involved in the command - for example, most single-object commands will call a method in the direct object to carry out the command.
filterAmbiguousWithVerify (lst, requiredNum, verProp, preCondProp, remapProp, whichObj, np)
Filter an ambiguous object list using the given verification method. We call the given verification method on each object, noting the result, then find the best (most logical) result in the list. We reduce the set to the objects that all have the same best value - everything else in the list is less logical, so we discard it. This gives us a set of objects that are all of equivalent likelihood and all of the best likelihood of all the objects.
This is the typical way that we disambiguate a list of objects, but this is merely a service routine, so individual actions can choose to use this or other mechanisms as appropriate.
filterFacets (lst)
Filter out redundant facets of the same object. The various facets of an object are equivalent to the parser. An object that has multiple facets is meant to appear to be one game world object from the perspective of a character - the multiple facet objects are an internal implementation detail.
filterPluralWithVerify (lst, verProp, preCondProp, remapProp, whichObj, np)
Filter a plural list with a verification method. We’ll reduce the list to the subset of objects that verify as logical, if there are any. If there are no logical objects in the list, we’ll simply return the entire original list.
finishResolveList (lst, whichObj, np, requiredNum)
Finish the result list for a resolved noun phrase. This is used just before disambiguation. We’ll give each object in the list a chance to filter the list with filterResolveList, and we’ll note the noun phrase we matched in each resolved object.
getAnaphoricBinding (typ)
Get the list of bindings for an anaphoric pronoun - this is a pronoun that refers back to an earlier noun phrase in the same sentence, such as HIMSELF in ASK BOB ABOUT HIMSELF. These obviously make no sense for verbs that take one (or zero) objects, since there’s no earlier phrase to refer back to; these should return nil to indicate that an anaphoric pronoun is simply nonsensical in such a context. Actions of two or more objects should return a list of objects for the preceding noun phrase.
Actions of two or more objects should set this if possible to the resolved object list for the previous noun phrase, as a ResolveInfo list.
The tricky part is that some actions will resolve noun phrases in a different order than they appear in the actual command grammar; similarly, it’s also possible that some non-English languages use cataphoric pronouns (i.e., pronouns that refer to noun phrases that appear later in the sentence). To allow for these cases, return an empty list here if a binding is grammatically possible but not yet available because of the resolution order, and note internally that the parser asked us for an anaphoric binding. Afterwards, the action’s resolver method must go back and perform *another* resolve pass on the noun phrase production that requested the anaphor binding.
‘typ’ is the PronounType specifier for the corresponding ordinary pronoun. For ‘himself’, for example, typ will be PronounHim.
getCurrentObjects ( )
Get the list of all of the objects (direct object, indirect object, and any additional objects for actions with three or more object roles) involved in the current execution. This is valid only during a call to doActionOnce(), since that’s the only time a particular set of objects are selected for the action.
By default, an action has no objects roles at all, so we’ll just return an empty list.
getDefaultWithVerify (resolver, verProp, preCondProp, remapProp, whichObj, np)
Get a default object using the given verification method. We’ll start with the ‘all’ list, then use the verification method to reduce the list to the most likely candidates. If we find a unique most likely candidate, we’ll return a ResolveInfo list with that result; otherwise, we’ll return nothing, since there is no suitable default.
getEnteredVerbPhrase ( )
Get the actual verb phrase the player typed in to generate this Action, expressed in a canonical format. The canonical format consists of the lower-case version of all of the actual text the player typed, but with each noun phrase replaced by a standard placeholder token describing the slot. The placeholder tokens are ‘(dobj)’ for the direct object, ‘(iobj)’ for the indirect object, ‘(literal)’ for a literal text phrase, and ‘(topic)’ for a topic phrase.
For example, if the player typed PUT BOOK AND PENCIL IN BOX, the canonical phrasing we return would be “put (dobj) in (iobj)”.
getImplicitPhrase (ctx)
Return a phrase describing the action performed implicitly, as a participle phrase. ‘ctx’ is an ImplicitAnnouncementContext object describing the context in which we’re generating the phrase.
This comes in two forms: if the context indicates we’re only attempting the action, we’ll return an infinitive phrase (“open the box”) for use in a larger participle phrase describing the attempt (“trying to…”). Otherwise, we’ll be describing the action as actually having been performed, so we’ll return a present participle phrase (“opening the box”).
getInfPhrase ( )
Get the infinitive form of the action. We are NOT to include the infinitive complementizer (i.e., “to”) as part of the result, since the complementizer isn’t used in all contexts in which we might want to use the infinitive; for example, we don’t want a “to” in phrases involving an auxiliary verb, such as “he can open the box.”
getMatchForRole (role)
get the match tree for the noun phrase in the given role
getMessageParam (objName)
Get a message parameter object for the action. Each action subclass defines this to return its objects according to its own classifications. The default action has no objects, but recognizes ‘actor’ as the current command’s actor.
getNotifyTable ( )
Get the list of objects to notify before or after the action has been performed.
getObjectForRole (role)
get the resolved object in a given role
getObjPreCondDescList (obj, preCondProp, checkArg, whichObj)
Get a precondition descriptor list for the given object. This returns a list of PreCondDesc objects that wrap the preconditions for the given object in the given role for this action.
getObjPreConditions (obj, preCondProp, whichObj)
Get the precondition list for an object. whichObj is the object role of the object whose preconditions we’re retrieving; this is nil if we’re looking for action-level preconditions.
getObjResponseProd (resolver)
Get the missing object response production for a given resolver role. (The base action doesn’t have any objects, so there’s no such thing as a missing object query.)
getOriginalAction ( )
Get the “original” action. If I’m a replacement or nested action, this returns the original main action of which I’m a part, for reporting pruposes.
It’s important to note that an implied action does NOT count as a nested or replacement action for the purposes of this method. That is, if a command A triggers an implied action B, which triggers a nested action C, and then after that command A itself triggers a nested action D, then
A.getOriginalAction -> A
B.getOriginalAction -> B (B is implied, not nested)
C.getOriginalAction -> C (C is nested within B)
D.getOriginalAction -> A (D is nested within A)
The purpose of the original action is to tell us, mainly for reporting purposes, what we’re really trying to do with the action. This allows reports to hide the internal details of how the action is carried out, and instead say what the action was meant to do from the player’s perspective.
getOrigTokenList ( )
OVERRIDDEN
A synthesized Action (one that’s generated by something other than parsing a command line, such as an event action or nested action) won’t have a parser token list attached to it. If we’re asked to get the token list, we need to check for this possibility. If we don’t have a token list, but we do have a parent action, we’ll defer to the parent action. Otherwise, we’ll simply return nil.
getOtherObjectRole (role)
Get the “other object” role - this is the complement of the given object role for a two-object action, and is used to determine the real role of the special OtherObject placeholder in a remapTo(). This is only meaningful with actions of exactly two objects.
getParticiplePhrase ( )
Get a string describing the full action in present participle form, using the current command objects: “taking the watch”, “putting the book on the shelf”
getPreCondDescList ( )
Get the precondition descriptor list for the action. For the base intransitive action type, this simply returns the list of conditions for the action itself.
getPreCondPropForRole (role)
get the ‘preCond’ property for a given object role
getPredicate ( )
Get the grammar match tree object for the predicate that was used to enter this command. By default, if we have an original action, we return the original action; otherwise we just return ‘self’.
Language libraries must override this to return the original match tree object if Actions are separate from predicate match trees.
(The ‘predicate’ is simply the grammar match tree object for the entire verb phrase from the player’s actual command entry text that matched this Action. For example, in “BOB, TAKE BOX”, the predicate is the match tree for the “TAKE BOX” part. In “BOB, TAKE BOX AND GO NORTH”, the predicate for the Take action is still the “TAKE BOX” part. For “BOB, TAKE BOX AND BOOK AND GO NORTH”, the predicate for the Take action is “TAKE BOX AND BOOK” - the full verb phrase includes any multiple-object lists in the original command.)
getPronounOverride (typ)
Get any special pronoun override in effect for the action, as set via setPronounOverride(). This looks in our own override table for a definition; then, if we have no override of our own, we ask our parent action if we have one, then our original action.
getQuestionInf (which)
Get the root infinitive form of our verb phrase as part of a question in which one of the verb’s objects is the “unknown” of the interrogative. ‘which’ is one of the role markers (DirectObject, IndirectObject, etc), indicating which object is the subject of the interrogative.
For example, for the verb UNLOCK <dobj> WITH <iobj>, if the unknown is the direct object, the phrase we’d return would be “unlock”: this would plug into contexts such as “what do you want to unlock.” If the indirect object is the unknown for the same verb, the phrase would be “unlock it with”, which would plug in as “what do you want to unlock it with”.
Note that we are NOT to include the infinitive complementizer (i.e., “to”) as part of the phrase we generate, since the complementizer isn’t used in some contexts where the infinitive conjugation is needed (for example, “what should I <infinitive>”).
getRemappedFrom ( )
no description available
getRemapPropForRole (role)
get the ‘remap’ property for a given object role
getResolvedObjList (which)
get the list of resolved objects in the given role
getResolveInfo (obj, oldRole)
Get the ResolveInfo for the given object in the current command. Since we don’t have any objects at all, we’ll simply return a new ResolveInfo wrapping the given object. ‘cur’ is the object we’re looking for, and ‘oldRole’ is the role the object previously played in the action.
getRoleFromIndex (idx)
Get the object “role” identifier for the given index. This returns the identifier (DirectObject, IndirectObject, etc.) for the object at the given slot index, as used in setResolvedObjects(). The first object is at index 1.
getSimpleSynonymRemap (obj, role, remapProp)
Get the “simple synonym” remapping for one of our objects, if any. ‘obj’ is the resolved object to remap, and ‘role’ is the object role identifier (DirectObject, IndirectObject, etc). ‘remapProp’ is the remapping property for the role; this is simply the result of our getRemapPropForRole(role), but we ask the caller to pass this in so that it can be pre-computed in cases where we’ll called in a loop.
A simple synonym remapping is a remapTo that applies the same verb to a new object in the same role. For example, if we remap OPEN DESK to OPEN DRAWER, then the drawer is the simple synonym remapping for the desk in an OPEN command. A remapping is considered a simple synonym remapping only if we’re remapping to the same action, AND the new object is in the same action role as the original object was.
If there’s no simple synonym remapping, we’ll return nil.
getSortedVerifyResults (lst, verProp, preCondProp, remapProp, whichObj, np, requiredNum)
Get a list of verification results for the given ResolveInfo objects, sorted from best to worst. Each entry in the returned list will be a VerifyResultList object whose obj_ property is set to the ResolveInfo object for which it was generated.
getVerbPhrase (inf, ctx)
Get the full verb phrase in either infinitive or participle format. This is a common handler for getInfinitivePhrase() and getParticiplePhrase().
‘ctx’ is a GetVerbPhraseContext object, which lets us keep track of antecedents when we’re stringing together multiple verb phrases. ‘ctx’ can be nil if the verb phrase is being used in isolation.
getVerifyPropForRole (role)
get the ‘verify’ property for a given object role
initTentative (issuingActor, targetActor, whichObj)
Initialize tentative resolutions for other noun phrases besides the one indicated.
isConversational (issuingActor)
Flag: this is a “conversational” command, as opposed to an order. When this type of command is addressed to another character, it doesn’t ask the other character to do anything, but rather engages the other character in conversation. Examples:
Bob, hello
Bob, goodbye
Bob, tell me about the planet
Bob, yes
Bob, no
(“Tell me about…” is a little different from the others. We treat it as conversational because it means the same thing as “ask Bob about…”, which we consider conversational because it would be rendered in real life as a question. In other words, the action involves the issuing actor stating the question, which means that issuing actor is the one doing the physical work of the action. “Tell me about…” could be seen as an order, but it seems more appropriate to view it as simply an alternative way of phrasing a question.)
The issuing actor is passed as a parameter because some actions are conversational only in some cases; “tell me about the planet” is conversational, but “tell Bill about the planet” isn’t, since the latter doesn’t ask Bob a question but orders Bob to talk to Bill.
When the issuing actor and target actor are the same, this is irrelevant. The purpose of this is to distinguish orders given to another character from conversational overtures directed to the other character, so if the command is coming from the player and bound for the player character, there’s obviously no conversation going on.
Note also that, contrary to what one might think at first glance, a command like ASK ABOUT is NOT conversational; it’s a command to ask someone about something, and isn’t itself a conversational overture. The act of asking is itself a conversational overture, but the asking is the *result* of the command, not the command itself. An action is only conversational if the action itself is a conversational overture. So, “BOB, HELLO” is conversational; “BOB, ASK BILL ABOUT COMPUTER” is not, because it orders Bob to do something.
isNestedIn (action)
Determine if I’m nested within the given action. Returns true if the given action is my parent action, or if my parent action is nested within the given action.
isPartOf (action)
Determine if this action is “part of” the given action. I’m part of the given action if I am the given action, or the given action is my “original” action, or my original action is part of the given action.
isRemapped ( )
determine if I’m remapped, and get the original action if so
makeResolveInfo (val)
wrap an object with a ResolveInfo
makeResolveInfoList (val)
Convert an object or list of objects to a ResolveInfo list
maybeAnnounceDefaultObject (lst, which, allResolved)
Announce a defaulted object list, if appropriate. We’ll announce the object if we have a single object in the given resolution list, it was defaulted, and it hasn’t yet been announced.
maybeAnnounceImplicit ( )
Maybe announce the action as an implied action.
maybeAnnounceMultiObject (info, numberInList, whichObj)
announce a multi-action object, if appropriate
noMatch (msgObj, actor, txt)
Show the “noMatch” library message. For most verbs, we use the basic “you can’t see that here”. Verbs that are mostly used with intangible objects, such as LISTEN TO and SMELL, might want to override this to use a less visually-oriented message.
notifyBeforeAfter (prop)
Call the beforeAction or afterAction method for each object in the notification list.
objListPronoun (objList)
Return a string with the appropriate pronoun (objective form) for a list of object matches, with the given resolved cardinality. This list is a list of ResolveInfo objects.
preAnnounceActionObject (info, mainList, whichObj)
“Pre-announce” a common object for a command that might involve iteration over other objects. For example, in “put all in box”, the box is common to all iterations of the command, so we would want to preannounce it, if it needs to be announced at all, before the iterations of the command.
We’ll announce the object only if it’s marked as defaulted or unclearly disambiguated, and then only if the other list will be announcing its objects as multi-action objects. However, we do not pre-announce anything for a remapped action, because we’ll show the full action description for each individually announced object, so we don’t need or want a separate announcement for the group.
Returns true if we did any pre-announcing, nil otherwise. If we return true, the caller should not re-announce this object during the iteration, since our pre-announcement is common to all iterations.
recalcSenseContext ( )
Reset the message generation context for a sense change. This can be called when something substantial happens in the midst of a command, and we might need different message generation rules before and after the change. For example, this is used when a non-player character moves from one location to another, because the NPC might want to generate leaving and arriving messages differently in the two locations.
repeatAction (lastTargetActor, lastTargetActorPhrase, lastIssuingActor, countsAsIssuerTurn)
Repeat the action, for an AGAIN command.
resetAction ( )
Reset the action in preparation for re-execution. This should discard any scoped context from any past execution of the command, such as cached scope information.
resolveAction (issuingActor, targetActor)
In the English grammar, all ‘predicate’ grammar definitions (which are usually made via the VerbRule macro) are associated with Action match tree objects; in fact, each ‘predicate’ grammar match tree is the specific Action subclass associated with the grammar for the predicate. This means that the Action associated with a grammar match is simply the grammar match object itself. Hence, we can resolve the action for a ‘predicate’ match simply by returning the match itself: it is the Action as well as the grammar match.
This approach (‘grammar predicate’ matches are based on Action subclasses) works well for languages like English that encode the role of each phrase in the word order of the sentence.
Languages that encode phrase roles using case markers or other devices tend to be freer with word order. As a result, ‘predicate’ grammars for such languages should generally not attempt to capture all possible word orderings for a given action, but should instead take the complementary approach of capturing the possible overall sentence structures independently of verb phrases, and plug in a verb phrase as a component, just like noun phrases plug into the English grammar. In these cases, the match objects will NOT be Action subclasses; the Action objects will instead be buried down deeper in the match tree. Hence, resolveAction() must be defined on whatever class is used to construct ‘predicate’ grammar matches, instead of on Action, since Action will not be a ‘predicate’ match.
resolvedObjectsInScope ( )
Check that the resolved objects are all in scope. Returns true if so, nil if not.
This routine is meant for use only for actions built programmatically using setResolvedObjects(). In particular, we assume that we have only one object in each slot. For normal parser-built actions, this check isn’t necessary, because the parser only resolves objects that are in scope in the first place.
runBeforeNotifiers ( )
Run the “before” notifiers: this calls beforeAction on everything in scope, and calls roomBeforeAction on the actor’s containers.
saveActionForAgain (issuingActor, countsAsIssuerTurn, targetActor, targetActorPhrase)
If the command is repeatable, save it for use by ‘again’.
setCurrentObjects (lst)
Set the current objects. This takes a list of the same form returned by getCurrentObjects().
setImplicit (msgProp)
Mark the command as implicit. ‘msgProp’ is the property (of gLibMessages) to use to announce the implicit command.
setMessageParam (objName, obj)
Define an extra message-specific parameter. Message processors can use this to add their own special parameters, so that they can refer to parameters that aren’t involved directly in the command. For example, a message for “take <dobj>” might want to refer to the object containing the direct object.
setMessageParams ([lst])
For convenience, this method allows setting any number of name/value pairs for message parameters.
setNested ( )
Mark the command as nested, noting the parent action (which we take as the global current action).
setObjectMatches ( )
Explicitly set the object match trees. This sets the pre-resolved production match trees. The arguments are given in the order of their roles in the action, using the same order that setResolvedObjects() uses.
The arguments to this routine can either be match tree objects, which we’ll plug into our grammar tree in the respective roles exactly as given; or they can be ResolveInfo objects giving the desired resolutions, in which case we’ll build the appropriate kind of PreResolvedProd for each one. The types can be freely mixed.
setOriginalAction (action)
Set the “original” action. An action with an original action is effectively part of the original action for the purposes of its reported results.
An action has an original action if it’s a nested or replacement action for an action.
setPronounOverride (typ, val)
Set a special pronoun override. This creates a temporary pronoun definition, which lasts as long as this action (and any nested actions). The temporary definition overrides the normal meaning of the pronoun.
One example of where this is useful is in global action remapping cases where the target actor changes in the course of the remapping. For example, if we remap BOB, GIVE ME YOUR BOOK to ASK BOB FOR YOUR BOOK, the YOUR qualifier should still refer to Bob even though the command is no longer addressing Bob directly. This routine can be used in this case to override the meaning of ‘you’ so that it refers to Bob.
setRemapped (orig)
Mark the action as “remapped.” This indicates that the action was explicitly remapped to a different action during the remap() phase.
setResolvedObjects ( )
Explicitly set the resolved objects. This should be overridden in each subclass for the number of objects specific to the action (a simple transitive action takes one argument, an action with both a direct and indirect object takes two arguments, and so on). The base action doesn’t have any objects at all, so this takes no arguments.
This method is used to set up an action to be performed programmatically, rather than based on parsed input. Since there’s no parsed input in such cases, the objects are specified directly by the programmatic caller.
spPrefix (str)
add a space prefix/suffix to a string if the string is non-empty
spSuffix (str)
no description available
synthMessageParam (obj)
Synthesize a global message parameter name for the given object. We’ll store the association and return the synthesized name.
verifyAction ( )
Verify the action. Action subclasses with one or more objects should call object verification routines here. Returns a VerifyResultList with the results, or nil if there are no verification results at all. A nil return should be taken as success, not failure, because it means that we found no objection to the command.
verifyHandlersExist (objList, propList, result)
Verify that some sort of handling for this action is defined on at least one of the given objects. If we have no handlers at all definfed, we’ll add an “illogical” status to the verification results to indicate that the action is not defined on this object. This check provides a last resort for verbs with no handling at all defined on the involved objects, to ensure that the verb won’t go completely unprocessed.
Each entry in objList is an object involved in the action. For each entry in objList, there must be *THREE* entries in propList: a verify property, a check property, and an action property. If any of these three properties is defined on the corresponding object, we’ll allow the command to proceed. If we can find none of the given handler properties on any of our objects, we’ll add an “illogical” verify result.
whatObj (which)
Return the interrogative pronoun for a missing object in one of our object roles. In most cases, this is simply “what”, but for some actions, “whom” is more appropriate (for example, the direct object of “ask” is implicitly a person, so “whom” is most appropriate for this role).
whatTranslate (txt)
Translate an interrogative word for whatObj. If the word is ‘whom’, translate to the library message for ‘whom’; this allows authors to use ‘who’ rather than ‘whom’ as the objective form of ‘who’, which sounds less stuffy to many people.
withVerifyResults (resultsSoFar, obj, func)
Invoke a callback with a verify results list in gVerifyResults, using the existing results list or creating a new one if there is no existing one. Returns the results list used.
zeroActionTime ( )
Zero the action time in this action and any parent actions. This should be used when a nested replacement action is to completely take over the time-keeping responsibility for the entire turn; all containing actions in this case are to take zero time, since the nested action is the only part of the turn that will count for timing.
TADS 3 Library Manual
Generated on 5/16/2013 from TADS version 3.1.3