Thingclass

thing.t[979], senseRegion.t[560], english.t[2125], brightness.t[34], cmdhelp.t[855], postures.t[114], roomparts.t[154], sensory.t[561], signals.t[201], tiaaction.t[380], weight.t[15]

Superclass
Tree

Subclass
Tree

Global
Objects

Property
Summary

Method
Summary

Property
Details

Method
Details

Thing is the base class for all game objects that represent physical objects which can be interacted with in the game world. All such physical objects are either Things or based on a subclass of Thing.

Modified in senseRegion.t[560]:
Modifications to Thing to support the other mods required for use with SenseRegion.

Modified in english.t[2125]:
English modifications for Thing. This adds some methods that vary by language, so they can’t be defined in the generic Thing class.

Modified in cmdhelp.t[855]:
Modifications to Thing for the CMDHELP EXTENSION

Modified in postures.t[114]:
Modifications to Thing needed for the POSTURES EXTENSION.

Modified in roomparts.t[154]:
Modifications to Thing to allow things to be associated with room parts. Note that a Thing associated with a room part should be directly located in the room, not in the room part. [MODIFIED FOR ROOMPARTS EXTENSION]

Modified in sensory.t[561]:
Modifications to Thing to work with the <i>SENSORY EXTENSION</i>

Modified in tiaaction.t[380]:
MODIFICATION TO THING FOR TIAACTION EXTENSION

Modified in weight.t[15]:
Modifications to Thing class for WEIGHT extension

class Thing :   ReplaceRedirector Mentionable

Superclass Tree   (in declaration order)

Thing
ReplaceRedirector
Redirector
`                         object [Mentionable](../object/Mentionable.html) [LMentionable](../object/LMentionable.html)                         object`

Subclass Tree  

Thing
Actor
Button
Collective
DispensingCollective
Consultable
Container
Booth
OpenableContainer
KeyedContainer
LockableContainer
Door
SecretDoor
Fixture
CollectiveGroup
MobileCollectiveGroup
Component
ContainerDoor
Decoration
Distant
RoomPart
Ceiling
DefaultWall
SensoryEmanation
Noise
SimpleNoise
Odor
SimpleOdor
Unthing
Enterable
Heavy
Floor
Food
Immovable
Key
Lever
MinorItem
Passage
PathPassage
Player
RearContainer
Room
OutdoorRoom
Settable
Dial
NumberedDial
SimpleAttachable
AttachableComponent
NearbyAttachable
Attachable
StairwayDown
StairwayUp
SubComponent
Surface
Platform
Bed
Chair
Switch
Flashlight
SymPassage
SymDoor
SymPathPassage
SymStairway
Underside
Wearable

Global Objects  

dummy_ lightProbe_ pluralDummy_ scopeProbe_

Summary of Properties  

actorAlreadyInMsg actorAlreadyOnMsg actorNotInMsg actorNotOnMsg allowPourIntoMe allowPourOntoMe alreadyCleanMsg alreadyClosedMsg alreadyFastenedMsg alreadyHasMsg alreadyHeldMsg alreadyInMsg alreadyLitMsg alreadyLockedMsg alreadyMovedToMsg alreadyOnMsg alreadyOpenMsg alreadyPresentMsg alreadyThereMsg alreadyWornMsg autoGetOutToReach autoTakeOnFindHidden autoUnlock brightness brightnessForReading brightnessOff brightnessOn bulk bulkCapacity canAttachToMe canAttackWithMe canBurnWithMe canCleanWithMe canClimbDownMe canClimbUpMe canCutWithMe canDetachFromMe canDigWithMe canEnterOnMe canFastenToMe canGoAlongMe canGoThrougMe canHearIn canHearOut canJumpOffMe canJumpOverMe canLieInMe canLieOnMe canLockWithMe canLookBehindMe canLookThroughMe canLookUnderMe canMoveToMe canMoveWithMe cannotAttachMsg cannotAttachToMsg cannotAttachToSelfMsg cannotAttackMsg cannotAttackWithMsg cannotAttackWithSelfMsg cannotBoardMsg cannotBreakMsg cannotBurnMsg cannotBurnWithMsg cannotCleanMsg cannotCleanWithMsg cannotClimbDownMsg cannotClimbMsg cannotCloseMsg cannotConsultMsg cannotCutMsg cannotCutWithMsg cannotCutWithSelfMsg cannotDetachFromMsg cannotDetachFromSelfMsg cannotDetachMsg cannotDigMsg cannotDigWithMsg cannotDigWithSelfMsg cannotDoffMsg cannotDrinkMsg cannotDropMsg cannotEatMsg cannotEnterMsg cannotEnterOnMsg cannotExtinguishMsg cannotFastenMsg cannotFastenToMsg cannotFastenToSelfMsg cannotFeelMsg cannotFlipMsg cannotFollowMsg cannotFollowSelfMsg cannotGetInCarriedMsg cannotGetOnCarriedMsg cannotGiveToMsg cannotGiveToSelfMsg cannotGoAlongMsg cannotGoNearThereMsg cannotGoThroughMsg cannotJumpOffMsg cannotJumpOverMsg cannotKissMsg cannotLieInMsg cannotLieOnMsg cannotLightMsg cannotLockWithMsg cannotLockWithSelfMsg cannotLookBehindMsg cannotLookThroughMsg cannotLookUnderMsg cannotMoveMsg cannotMoveToMsg cannotMoveToSelfMsg cannotMoveWithMsg cannotMoveWithSelfMsg cannotOpenMsg cannotPlugIntoMsg cannotPlugIntoSelfMsg cannotPlugMsg cannotPourIntoMsg cannotPourIntoSelfMsg cannotPourMsg cannotPourOntoMsg cannotPourOntoSelfMsg cannotPullMsg cannotPurloinContainerMsg cannotPurloinRoomMsg cannotPurloinSelfMsg cannotPushDownMsg cannotPushIntoMsg cannotPushMsg cannotPushOwnContainerMsg cannotPushThroughMsg cannotPushUpMsg cannotPushViaSelfMsg cannotPutBehindMsg cannotPutInMsg cannotPutInSelfMsg cannotPutMsg cannotPutOnMsg cannotPutUnderMsg cannotReadMsg cannotRemoveMsg cannotScrewMsg cannotScrewWithMsg cannotScrewWithSelfMsg cannotSetMsg cannotSetToMsg cannotShowToMsg cannotShowToSelfMsg cannotSitInMsg cannotSitOnMsg cannotSmellMsg cannotStandInMsg cannotStandOnMsg cannotTakeFromSelfMsg cannotTakeMsg cannotTakeMyContainerMsg cannotTakeSelfMsg cannotTalkToMsg cannotTalkToSelfMsg cannotTasteMsg cannotThrowAtMsg cannotThrowAtSelfMsg cannotThrowMsg cannotThrowToMsg cannotThrowToSelfMsg cannotTurnMsg cannotTurnToMsg cannotTurnWithMsg cannotTurnWithSelfMsg cannotTypeOnMsg cannotUnfastenFromMsg cannotUnfastenFromSelfMsg cannotUnfastenMsg cannotUnlockWithMsg cannotUnlockWithSelfMsg cannotUnplugFromMsg cannotUnplugFromSelfMsg cannotUnplugMsg cannotUnscrewMsg cannotUnscrewWithMsg cannotUnscrewWithSelfMsg cannotWearMsg cannotWriteOnMsg canPlugIntoMe canPourIntoMe canPourOntoMe canPullTravel canPushTravel canPutBehindMe canPutInMe canPutUnderMe canReachIn canReachOut canScrewWithMe canSeeIn canSeeOut canSetMeTo canSitInMe canSitOnMe canSmellIn canSmellOut canStandInMe canStandOnMe canSupply canTalkToMe canThrowAtMe canThrowToMe canTurnMeTo canTurnWithMe canTypeOnMe canUnfastenFromMe canUnlockWithMe canUnplugFromMe canUnscrewWithMe canWriteOnMe checkAttackMsg checkFeelMsg checkKissMsg circularlyInMsg collectiveGroups contents contentsListed contentsListedInExamine contentsListedInLook contentsListedInSearch contType currentInterlocutor curSetting darkName decorationActions decorationActions defaultPosture desc directlyHeld directlyIn directlyWorn distinguishByContents dontNeedCleaningObjMsg dropItemsBehind dropItemsUnder dropLocation enclosing examined examineListed examineLister exitLocation extContents familiar feelDesc findHiddenDest fluidName futileToAttackMsg futileToKissMsg getBulkHiddenBehind getBulkHiddenIn getBulkHiddenUnder getFacets getOutermostRoom getOutToJump getWeightHiddenBehind getWeightHiddenIn getWeightHiddenUnder globalParamName groupOrder hearNothingMsg hiddenBehind hiddenIn hiddenUnder illuminationThreshold inDarkDesc indirectLockableMsg initSpecialDesc intContents interiorDesc inventoryListed isAttachable isAttackable isBoardable isBreakable isBurnable isClean isCleanable isClimbable isCloseable isConsultable isCuttable isDecoration isDetachable isDiggable isDoffable isDrinkable isDroppable isEdible isEnterable isExtinguishable isFastenable isFastened isFeelable isFixed isFlippable isFollowable isHidden isInitialPlayerChar isKissable isLightable isListed isLit isLocked isMoveable isOn isOpen isOpenable isPlayerChar isPlugable isPourable isProminentNoise isProminentSmell isPullable isPushable isReadable isRemoveable isScrewable isSettable isSmellable isSwitchable isTakeable isTasteable isThrowable isTransparent isTurnable isUnfastenable isUnplugable isUnscrewable isVehicle isWearable keyDoesntWorkMsg keyList keyNotNeededMsg kissRank known knownKeyList knownProp lastSeenAt lieOnScore lightSources listableContents listenDesc listenDescWithoutSource listenDescWithSource listOrder listWith location lockability lockedMsg lookBehindMsg lookInMsg lookListed lookThroughMsg lookUnderMsg markInventoryAsSeen matchPullOnly matchPushOnly maxBulkHiddenBehind maxBulkHiddenIn maxBulkHiddenUnder maxSingleBulk maxSingleWeight maxWeightHiddenBehind maxWeightHiddenIn maxWeightHiddenUnder mentioned moved movedTo moveNoEffectMsg mustBeCleanedWith myInventoryLister myLookBehindLister myLookInLister myLookUnderLister myOpeningContentsLister myWornLister needsCleaning noLongerTalkingToAnyoneMsg nominalContents noNeedToCleanMsg notFastenedMsg notHoldingMsg notImportantMsg notInMsg notLitMsg notLockableMsg notLockedMsg notSwitchableMsg notTalkingToAnyoneMsg notWornMsg objInPrep objIntoPrep okayCleanMsg okayGetOutOfMsg okayLieInMsg okayLieOnMsg okayLockMsg okayOpenMsg okayPushIntoMsg okayPushOutOfMsg okaySetMsg okaySitInMsg okaySitOnMsg okayStandInMsg okayStandOnMsg okayUnlockMsg opacity opened openStatusReportable owner ownsContents paraBrksBtwnSubcontents partOfYouMsg posture preCondActor pullNoEffectMsg pushNoEffectMsg readDesc recognizableInDark remapActor remapBehind remapIn remapOn remapProps remapUnder roomContentsLister roomPart roomPartDesc roomSubContentsLister roomTitle searchListed seen seenProp shouldBeBroken shouldNotBreakMsg shouldNotPourIntoMsg shouldNotPourOntoMsg sightSize sitOnScore smellDesc smellDescWithoutSource smellDescWithSource smellNothingMsg smellObj smellSize soundObj soundSize specialDesc specialDescBeforeContents specialDescListWith specialDescOrder stagingLocation standOnScore stateDesc tasteDesc throwFallsShortMsg tooDarkToReadMsg tooDarkToSeeMsg tooFarAwayToHearMsg tooFarAwayToReadMsg tooFarAwayToSeeDetailMsg tooFarAwayToSmellMsg totalWeight turnLastExamined turnLastMoved turnLastMovedInto turnNoEffectMsg useInitSpecialDesc useKey_ useSpecialDesc viaMode visibleInDark vocabLikelihood weight weightCapacity withKeyMsg wornBy

Inherited from Mentionable :
ambiguouslyPlural disambigGroup disambigMatchPhrases disambigName disambigOrder isHer isHim isIt massNoun matchPhrases matchPhrasesExclude name person plural proper qualified states vocab vocabWords

Inherited from LMentionable :
acronymPluralPat alphaCharPat aName apostPluralPat apostSPat deannotatePat dictComp dummyName elevenEighteenPat emptyVocabWords esPluralPat firstWordPat heName herName hersName himName iesPluralPat irregularPlurals lastWordPat leadingTagOrQuotePat menPluralPat objInName objIntoName objName objOutOfName oneLetterAnWordPat oneLetterWordPat ownerNamed pluralPat posPat possAdj possEnding possNoun prepList prepPhrasePat prepWordPat pronounMap properNamePat properPat reflexiveName specialAOrAn tagOrQuotePat thatName thatObjName theName theObjName trimPat truncationLength weakWordPat

Summary of Methods  

abcName accumulateBrightness accumulatedBrightnessWithin actionMoveInto actorAction addToAllContents addToContents afterAction afterTravel allContents allowReachOut aobjFor beforeAction beforeMovePushable beforeTravel brightnessWithin byRoom canHear cannotPushTravelMsg cannotReachOutMsg canReach canSee canSmell canTalkTo checkDisplay checkInsert checkPushTravel checkReach checkReachIn checkRemove checkRoomToHold checkSetting childLocType commonContainingParent commonInteriorParent containerPath containerPathBlock darkDesc describeMovePushable describePushTravel directChildParent discover display displayAlt dobjFor(AskAbout) dobjFor(AskFor) dobjFor(Attach) dobjFor(AttachTo) dobjFor(Attack) dobjFor(AttackWith) dobjFor(Board) dobjFor(Break) dobjFor(Burn) dobjFor(BurnWith) dobjFor(Clean) dobjFor(CleanWith) dobjFor(Climb) dobjFor(ClimbDown) dobjFor(ClimbUp) dobjFor(Close) dobjFor(ConsultAbout) dobjFor(Cut) dobjFor(CutWith) dobjFor(Default) dobjFor(Detach) dobjFor(DetachFrom) dobjFor(Dig) dobjFor(DigWith) dobjFor(Doff) dobjFor(Drink) dobjFor(Drop) dobjFor(Eat) dobjFor(Enter) dobjFor(EnterOn) dobjFor(Examine) dobjFor(Extinguish) dobjFor(Fasten) dobjFor(FastenTo) dobjFor(Feel) dobjFor(Flip) dobjFor(Follow) dobjFor(GetOff) dobjFor(GetOutOf) dobjFor(GiveTo) dobjFor(GiveToImplicit) dobjFor(GoAlong) dobjFor(GoNear) dobjFor(GoThrough) dobjFor(GoTo) dobjFor(JumpOff) dobjFor(JumpOver) dobjFor(Kiss) dobjFor(LieIn) dobjFor(LieOn) dobjFor(LieOn) dobjFor(Light) dobjFor(ListenTo) dobjFor(Lock) dobjFor(LockWith) dobjFor(LookBehind) dobjFor(LookIn) dobjFor(LookThrough) dobjFor(LookUnder) dobjFor(Move) dobjFor(MoveTo) dobjFor(MoveWith) dobjFor(Open) dobjFor(PlugIn) dobjFor(PlugInto) dobjFor(Pour) dobjFor(PourInto) dobjFor(PourOnto) dobjFor(Pull) dobjFor(Purloin) dobjFor(Push) dobjFor(PushTravelClimbDown) dobjFor(PushTravelClimbUp) dobjFor(PushTravelDir) dobjFor(PushTravelEnter) dobjFor(PushTravelGetOutOf) dobjFor(PushTravelThrough) dobjFor(PutBehind) dobjFor(PutIn) dobjFor(PutOn) dobjFor(PutUnder) dobjFor(QueryAbout) dobjFor(Read) dobjFor(Remove) dobjFor(SayTo) dobjFor(Screw) dobjFor(ScrewWith) dobjFor(Search) dobjFor(Set) dobjFor(SetTo) dobjFor(ShowTo) dobjFor(ShowToImplicit) dobjFor(SitIn) dobjFor(SitOn) dobjFor(SitOn) dobjFor(SmellSomething) dobjFor(StandIn) dobjFor(StandOn) dobjFor(StandOn) dobjFor(Strike) dobjFor(SwitchOff) dobjFor(SwitchOn) dobjFor(SwitchVague) dobjFor(Take) dobjFor(TakeFrom) dobjFor(TakeFrom) dobjFor(TalkAbout) dobjFor(TalkTo) dobjFor(Taste) dobjFor(TellAbout) dobjFor(Throw) dobjFor(ThrowAt) dobjFor(ThrowDir) dobjFor(ThrowTo) dobjFor(Turn) dobjFor(TurnTo) dobjFor(TurnWith) dobjFor(TypeOn) dobjFor(TypeOnVague) dobjFor(Unfasten) dobjFor(UnfastenFrom) dobjFor(Unlock) dobjFor(UnlockWith) dobjFor(Unplug) dobjFor(UnplugFrom) dobjFor(Unscrew) dobjFor(UnscrewWith) dobjFor(Wear) dobjFor(WriteOn) doPushTravel examineStatus filterResolveList findHidden findPlausibleKey firstContainerPathBlock getBulkWithin getCarriedBulk getCarriedWeight getStatuslineExitsHeight getWeightWithin handleCommand hasSeen hideFromAll interiorParent iobjFor(AttachTo) iobjFor(AttackWith) iobjFor(BurnWith) iobjFor(CleanWith) iobjFor(CutWith) iobjFor(Default) iobjFor(DetachFrom) iobjFor(DigWith) iobjFor(FastenTo) iobjFor(GiveTo) iobjFor(LockWith) iobjFor(MoveTo) iobjFor(MoveWith) iobjFor(PlugInto) iobjFor(PourInto) iobjFor(PourOnto) iobjFor(PushTravelClimbDown) iobjFor(PushTravelClimbUp) iobjFor(PushTravelEnter) iobjFor(PushTravelGetOutOf) iobjFor(PushTravelThrough) iobjFor(PutBehind) iobjFor(PutIn) iobjFor(PutOn) iobjFor(PutUnder) iobjFor(ScrewWith) iobjFor(ShowTo) iobjFor(TakeFrom) iobjFor(ThrowAt) iobjFor(ThrowTo) iobjFor(TurnWith) iobjFor(UnfastenFrom) iobjFor(UnlockWith) iobjFor(UnplugFrom) iobjFor(UnscrewWith) isAudibleFrom isChild isDirectChild isDirectlyHeldBy isDirectlyIn isDirectlyWornBy isHeldBy isIlluminated isIn isInterior isOrIsIn isOutside isReadableFrom isSmellableFrom isThereALightSourceIn isVisibleFrom isWornBy knowsAbout listableContentsOf listContents listenDesc listRemoteContents listSubcontentsOf litWithin locationWhich locType lookAroundWithin makeCleaned makeFastened makeLit makeLocked makeMovedTo makeOn makeOpen makeSetting makeWorn moveHidden moveInto moveMLIntoAdd moveMLOutOf nestedLoc nominalOwner noteSeen notifyEvent notifyInsert notifyRemove notifySightEvent notifySmellEvent notifySoundEvent notionalContents outermostParent outermostVisibleParent ownedBy preinitThing pushTravelRevealItems reachBlockedMsg remoteBrightness remoteInitSpecialDesc remoteObjInName remoteSpecialDesc removeFromContents revealOnMove roomHeadline roomSubhead sayCantBearMoreWeight sayDontKnowHowToGetThere sayDontKnowHowToReach sayFindHidden sayPushTravel sayTooHeavy sayTooHeavyToHide scoreObject setHasSeen setKnown setKnowsAbout setSeen shinesOut showConnectedMiscContents showFirstConnectedSpecials showRemoteSpecialDesc showSecondConnectedSpecials showSpecialDesc showStatuslineExits smellDesc statusName totalBulkIn totalWeightIn traceContainerPath travelVia tryCheck tryMakingPosture unmention unmentionRemoteContents verifyActor verifyEnterPosture verifyPushTravel wouldBeLitFor

Inherited from ReplaceRedirector :
redirect

Inherited from Redirector :
doInstead doNested doOtherAction

Inherited from Mentionable :
construct matchName matchNameCommon matchNameDisambig phraseMatchName simpleMatchName

Inherited from LMentionable :
addDictWord addVocab addVocabWord aNameFrom aNameFromPoss classInit contify distinguishedName ifPronoun inheritVocab initVocab initVocabWord locify matchPronoun pluralNameFrom pluralWordFrom possessify pronoun removeVocabWord replaceVocab theNameFrom theNameIs

Properties  

actorAlreadyInMsg

thing.t[6591]

no description available

actorAlreadyOnMsg

thing.t[6458]

no description available

actorNotInMsg

thing.t[6658]

no description available

actorNotOnMsg

thing.t[6659]

no description available

allowPourIntoMe

thing.t[8226]

While it’s possible to pour stuff into any container, we probably don’t want to allow it on most of them

allowPourOntoMe

thing.t[8178]

The allowPourOntoMe property controls whether we want allow anything to be poured onto this thing (even if it’s possible). By default we don’t.

alreadyCleanMsg

thing.t[7056]

no description available

alreadyClosedMsg

thing.t[4838]

no description available

alreadyFastenedMsg

thing.t[7688]

no description available

alreadyHasMsg

thing.t[8981]

no description available

alreadyHeldMsg

thing.t[4236]

no description available

alreadyInMsg

thing.t[5431]

Handled on iobj

alreadyLitMsg

thing.t[6893]

no description available

alreadyLockedMsg

thing.t[5896]

Remap the lock action to our remapIn object if we’re not lockable but we have a lockable remapIn object (i.e. an associated container).

alreadyMovedToMsg

thing.t[6861]

no description available

alreadyOnMsg

thing.t[6185]

no description available

alreadyOpenMsg

thing.t[4795]

no description available

alreadyPresentMsg

thing.t[7544]

no description available

alreadyThereMsg

thing.t[7542]

no description available

alreadyWornMsg

thing.t[6318]

no description available

autoGetOutToReach

thing.t[3489]

If an actor within me cannot reach an object from me, should the actor automatically try to get out of me?

autoTakeOnFindHidden

thing.t[4974]

If the actor finds something in a hiddenPrep list and there’s nowhere obvious for it go, should he take it? By default the actor should take it if the object he’s found it in/under/behind is fixed in place.

autoUnlock

thing.t[4720]

Flag, do we want to attempt to unlock this item it it’s locked when we try to open it?

brightness

brightness.t[79]

[BRIGHTNESS EXTENSION]

The strength of the light the object is giving off, if indeed it is giving off light. This value should be one of the following:

0: The object is giving off no light at all.

1: The object is self-illuminating, but doesn’t give off enough light to illuminate any other objects. This is suitable for something like an LED digital clock.

2: The object gives off dim light. This level is bright enough to illuminate nearby objects, but not enough to go through obscuring media, and not enough for certain activities requiring strong lighting, such as reading.

3: The object gives off medium light. This level is bright enough to illuminate nearby objects, and is enough for most activities, including reading and the like. Traveling through an obscuring medium reduces this level to dim (2).

4: The object gives off strong light. This level is bright enough to illuminate nearby objects, and travel through an obscuring medium reduces it to medium light (3).

There is nothing to stop game code using a higher value still to model a a super-powerful light source if that seems suitable to the situation being modelled in the game, but this probably will only rarely be necessary.

Note that the special value -1 is reserved as an invalid level, used to flag certain events (such as the need to recalculate the ambient light level from a new point of view).

Most objects do not give off light at all.

Return the appropriate on/off brightness, depending on whether or not we’re currently lit

brightnessForReading

brightness.t[375]

The brightness needed for us to be able to read this object (as opposed to merely examine it) By default we’ll set this at 3 (the brightness used by adv3) but game code can overrife this to some other value if desired. [BRIGHTNESS EXTENSION]

brightnessOff

brightness.t[43]

Our brightness when unlit. This would normally be 0, but if we’re visible in the dark it will be 1. [BRIGHTNESS EXTENSION]

brightnessOn

brightness.t[37]

Our brightness when lit [BRIGHTNESS EXTENSION]

bulk

thing.t[2052]

This object’s bulk, in arbitrary units (game authors should devise their own bulk scale according to the needs of their game).

bulkCapacity

thing.t[2058]

The maximum bulk that can be contained in this Thing. We set a very large number by default.

canAttachToMe

thing.t[7575]

no description available

canAttackWithMe

thing.t[4609]

By default we can’t use most things as weapons

canBurnWithMe

thing.t[6279]

By default we assume most things can’t be used to burn other things with.

canCleanWithMe

thing.t[7106]

We assume most objects aren’t suitable for cleaning other objects with. Since the dobj is resolved first canCleanWithMe could be a method that checks whether the proposed iobj is suitable for cleaning gDobj; but a better way of doing it might be to list suitable objects in the mustBeCleanedWith property.

canClimbDownMe

thing.t[6384]

no description available

canClimbUpMe

thing.t[6369]

no description available

canCutWithMe

thing.t[4946]

Most things can’t be used to cut other things with

canDetachFromMe

thing.t[7629]

no description available

canDigWithMe

thing.t[7143]

Most objects aren’t suitable digging instruments

canEnterOnMe

thing.t[8061]

Entering something on means ENTER FOO ON BAR where FOO is a string literal and BAR is an object such as a computer terminal. Most objects can’t be entered on in this sense.

canFastenToMe

thing.t[7702]

no description available

canGoAlongMe

thing.t[5330]

Most things cannot be gone along

canGoThrougMe

thing.t[5313]

Most things cannot be gone through

canHearIn

thing.t[3391]

Can we hear in from my exterior to my interior? That is, can an observer on the outside of this container hear a sound source on the inside?

By default, we can hear in for all containers, since most materials transmit at least some sound even if they’re opaque to light. For a soundproof material (a glass booth, say), you could override this to make it (!enclosing) instead.

canHearOut

thing.t[3403]

Can we hear out from my interior to my exterior? That is, can an observer on the inside of this container hear a sound source on the outside?

By default, we can hear out for all containers, since most materials transmit at least some sound even if they’re opaque to light. For a soundproof material (a glass both, say), you could override this to make it (!enclosing) instead.

canJumpOffMe

thing.t[7951]

It should be possible to jump off something if and only if the actor is on it in the first place.

canJumpOverMe

thing.t[7982]

It usually isn’t possible (or at least useful) to jump over things.

canLieInMe

postures.t[134]

no description available

canLieOnMe

thing.t[6483]

no description available

canLockWithMe

thing.t[5903]

Usually, if something can be used to unlock things it can also be used to lock them

canLookBehindMe

thing.t[5194]

By default we make it possible to look behind things, but there could be many things it makes no sense to try to look behind.

canLookThroughMe

thing.t[5290]

By default we make it possible to look through things, but there may well be things you obviously couldn’t look through.

canLookUnderMe

thing.t[5103]

We can look under most things, but there are some things (houses, the ground, sunlight) it might not make much sense to try looking under.

canMoveToMe

thing.t[6833]

In general there’s no reason why most objects can’t be moved to.

canMoveWithMe

thing.t[6766]

Most things can’t be used to move other things with. Note that since the dobj is resolved first, objects or subclasses could override this with a method that returns true or nil depending on the identity of the dobj.

cannotAttachMsg

thing.t[7591]

no description available

cannotAttachToMsg

thing.t[7593]

no description available

cannotAttachToSelfMsg

thing.t[7596]

no description available

cannotAttackMsg

thing.t[4568]

no description available

cannotAttackWithMsg

thing.t[4615]

no description available

cannotAttackWithSelfMsg

thing.t[4612]

no description available

cannotBoardMsg

thing.t[6457]

no description available

cannotBreakMsg

thing.t[4642]

no description available

cannotBurnMsg

thing.t[6291]

no description available

cannotBurnWithMsg

thing.t[6293]

no description available

cannotCleanMsg

thing.t[7053]

no description available

cannotCleanWithMsg

thing.t[7119]

no description available

cannotClimbDownMsg

thing.t[6397]

no description available

cannotClimbMsg

thing.t[6382]

no description available

cannotCloseMsg

thing.t[4837]

no description available

cannotConsultMsg

thing.t[8121]

no description available

cannotCutMsg

thing.t[4962]

no description available

cannotCutWithMsg

thing.t[4964]

no description available

cannotCutWithSelfMsg

thing.t[4966]

no description available

cannotDetachFromMsg

thing.t[7641]

no description available

cannotDetachFromSelfMsg

thing.t[7644]

no description available

cannotDetachMsg

thing.t[7612]

no description available

cannotDigMsg

thing.t[7174]

no description available

cannotDigWithMsg

thing.t[7176]

no description available

cannotDigWithSelfMsg

thing.t[7178]

no description available

cannotDoffMsg

thing.t[6352]

no description available

cannotDrinkMsg

thing.t[6975]

no description available

cannotDropMsg

thing.t[4427]

The message to display if something can’t be dropped.

cannotEatMsg

thing.t[6957]

no description available

cannotEnterMsg

thing.t[6590]

no description available

cannotEnterOnMsg

thing.t[8080]

no description available

cannotExtinguishMsg

thing.t[6933]

no description available

cannotFastenMsg

thing.t[7685]

no description available

cannotFastenToMsg

thing.t[7718]

no description available

cannotFastenToSelfMsg

thing.t[7721]

no description available

cannotFeelMsg

thing.t[4132]

no description available

cannotFlipMsg

thing.t[6249]

no description available

cannotFollowMsg

thing.t[4522]

no description available

cannotFollowSelfMsg

thing.t[4525]

no description available

cannotGetInCarriedMsg

thing.t[6594]

no description available

cannotGetOnCarriedMsg

thing.t[6461]

no description available

cannotGiveToMsg

thing.t[8997]

no description available

cannotGiveToSelfMsg

thing.t[9000]

no description available

cannotGoAlongMsg

thing.t[5343]

no description available

cannotGoNearThereMsg

thing.t[9195]

no description available

cannotGoThroughMsg

thing.t[5326]

no description available

cannotJumpOffMsg

thing.t[7979]

Jumping off something has much the same effect as getting off it, i.e. moving the actor to our exitLocation.

cannotJumpOverMsg

thing.t[8000]

no description available

cannotKissMsg

thing.t[7932]

no description available

cannotLieInMsg

postures.t[463]

[MODIFIED FOR POSTURES EXTENSION]

cannotLieOnMsg

thing.t[6546]

no description available

cannotLightMsg

thing.t[6891]

no description available

cannotLockWithMsg

thing.t[5920]

no description available

cannotLockWithSelfMsg

thing.t[5923]

no description available

cannotLookBehindMsg

thing.t[5279]

no description available

cannotLookThroughMsg

thing.t[5306]

no description available

cannotLookUnderMsg

thing.t[5183]

no description available

cannotMoveMsg

thing.t[6736]

no description available

cannotMoveToMsg

thing.t[6855]

no description available

cannotMoveToSelfMsg

thing.t[6858]

no description available

cannotMoveWithMsg

thing.t[6783]

no description available

cannotMoveWithSelfMsg

thing.t[6786]

no description available

cannotOpenMsg

thing.t[4794]

no description available

cannotPlugIntoMsg

thing.t[7821]

no description available

cannotPlugIntoSelfMsg

thing.t[7819]

no description available

cannotPlugMsg

thing.t[7817]

no description available

cannotPourIntoMsg

thing.t[8253]

no description available

cannotPourIntoSelfMsg

thing.t[8251]

no description available

cannotPourMsg

thing.t[8247]

no description available

cannotPourOntoMsg

thing.t[8255]

no description available

cannotPourOntoSelfMsg

thing.t[8249]

no description available

cannotPullMsg

thing.t[5384]

no description available

cannotPurloinContainerMsg

thing.t[9166]

no description available

cannotPurloinRoomMsg

thing.t[9164]

no description available

cannotPurloinSelfMsg

thing.t[9162]

Note that the player char has seen the purloined item. Not doing this can make it appear that the player character doesn’t know about an object that’s in his/her inventory.

cannotPushDownMsg

thing.t[8839]

no description available

cannotPushIntoMsg

thing.t[8751]

no description available

cannotPushMsg

thing.t[5362]

no description available

cannotPushOwnContainerMsg

thing.t[8403]

no description available

cannotPushThroughMsg

thing.t[8705]

no description available

cannotPushUpMsg

thing.t[8815]

no description available

cannotPushViaSelfMsg

thing.t[8406]

no description available

cannotPutBehindMsg

thing.t[5744]

If we’re actually a rear-like object (i.e. if our contType is Behind) then something put behind us can be moved inside us. Otherwise, all we can do with something put behind us is to add it to our hiddenBehind list and move it off-stage.

cannotPutInMsg

thing.t[5558]

If we’re actually a container-like object (i.e. if our contType is In) then something put in us can be moved inside us. Otherwise, all we can do with something put in us is to add it to our hiddenIn list and move it off-stage.

cannotPutInSelfMsg

thing.t[5437]

no description available

cannotPutMsg

thing.t[5394]

The most usual reason why we can’t put something somewhere is that we can’t pick it up in the first place, so by default we’ll just copy cannotPutMsg from cannotTakeMsg.

cannotPutOnMsg

thing.t[5467]

no description available

cannotPutUnderMsg

thing.t[5651]

If we’re actually an underside-like object (i.e. if our contType is Under) then something put under us can be moved inside us. Otherwise, all we can do with something put under us is to add it to our hiddenUnder list and move it off-stage.

cannotReadMsg

thing.t[4497]

no description available

cannotRemoveMsg

thing.t[6701]

Note that this message should never display in an English-language game since removeDoer will intercept the action before it gets to this point.

cannotScrewMsg

thing.t[8343]

no description available

cannotScrewWithMsg

thing.t[8345]

no description available

cannotScrewWithSelfMsg

thing.t[8347]

no description available

cannotSetMsg

thing.t[8021]

no description available

cannotSetToMsg

thing.t[7419]

no description available

cannotShowToMsg

thing.t[9028]

no description available

cannotShowToSelfMsg

thing.t[9031]

no description available

cannotSitInMsg

postures.t[431]

[MODIFIED FOR POSTURES EXTENSION]

cannotSitOnMsg

thing.t[6544]

no description available

cannotSmellMsg

thing.t[4059]

no description available

cannotStandInMsg

postures.t[396]

[MODIFIED FOR POSTURES EXTENSION]

cannotStandOnMsg

thing.t[6542]

no description available

cannotTakeFromSelfMsg

thing.t[7224]

no description available

cannotTakeMsg

thing.t[4233]

Report that we’ve been taken. Note that if the action causes several items to be taken, this method will only be called on the final item, and will need to report on all the items taken.

cannotTakeMyContainerMsg

thing.t[4239]

no description available

cannotTakeSelfMsg

thing.t[4241]

no description available

cannotTalkToMsg

thing.t[8955]

no description available

cannotTalkToSelfMsg

thing.t[8958]

no description available

cannotTasteMsg

thing.t[4102]

no description available

cannotThrowAtMsg

thing.t[7292]

Particular instances will nearly always need to override with a less generic and more plausible refusal message.

cannotThrowAtSelfMsg

thing.t[7295]

no description available

cannotThrowMsg

thing.t[4679]

The default result of throwing something in a compass direction is that it lands in the dropLocation of its outermost room.

cannotThrowToMsg

thing.t[7327]

no description available

cannotThrowToSelfMsg

thing.t[7330]

no description available

cannotTurnMsg

thing.t[4871]

no description available

cannotTurnToMsg

thing.t[7381]

no description available

cannotTurnWithMsg

thing.t[4915]

no description available

cannotTurnWithSelfMsg

thing.t[4918]

no description available

cannotTypeOnMsg

thing.t[8053]

no description available

cannotUnfastenFromMsg

thing.t[7770]

no description available

cannotUnfastenFromSelfMsg

thing.t[7773]

no description available

cannotUnfastenMsg

thing.t[7767]

no description available

cannotUnlockWithMsg

thing.t[5850]

no description available

cannotUnlockWithSelfMsg

thing.t[5853]

no description available

cannotUnplugFromMsg

thing.t[7860]

no description available

cannotUnplugFromSelfMsg

thing.t[7857]

no description available

cannotUnplugMsg

thing.t[7854]

no description available

cannotUnscrewMsg

thing.t[8348]

no description available

cannotUnscrewWithMsg

thing.t[8350]

no description available

cannotUnscrewWithSelfMsg

thing.t[8352]

no description available

cannotWearMsg

thing.t[6317]

no description available

cannotWriteOnMsg

thing.t[8099]

no description available

canPlugIntoMe

thing.t[7782]

no description available

canPourIntoMe

thing.t[8219]

Presumably it’s possible by default to pour something into me if I’m a container; but this could be overridden simply to true for objects like the sea or a river.

canPourOntoMe

thing.t[8172]

Most things can probably have something poured onto them in principle, though we might want to prevent it in practice. The canPourOntoMe property controls whether it’s possible to pour onto this thing.

canPullTravel

thing.t[8419]

Normally we don’t distinguish PushTravel from PullTravel, but if we want something to be pushable between rooms but not pullable, or vice versa, we can set these to different values.

canPushTravel

thing.t[8412]

By default we can’t push travel most things. Push Travel means pushing an object from one place to another and traveling with it.

canPutBehindMe

thing.t[2347]

Flag: can under objects be placed behind us? By default they can if our contType is Behind. If this is set to true and our contType is not Behind, anything placed behind us will be treated as hidden behind.

canPutInMe

thing.t[2354]

Flag: can under objects be placed inside us? By default they can if our contType is In. If this is set to true and our contType is not In, anything placed in us will be treated as hidden in.

canPutUnderMe

thing.t[2340]

Flag: can under objects be placed under us? By default they can if our contType is Under. If this is set to true and our contType is not Under, anything placed under us will be treated as hidden under.

canReachIn

thing.t[3433]

Can we reach in from my exterior to my interior? That is, can an observer outside this object reach something inside of it? By default, we can reach in if we’re non-enclosing.

canReachOut

thing.t[3426]

Can we reach out from my interior to my exterior? That is, can an observer inside this object reach something outside of it? By default, we can reach out if we’re non-enclosing.

canScrewWithMe

thing.t[8267]

Most things can’t be used to screw other things with.

canSeeIn

thing.t[3371]

Can we see in from my exterior to my interior? That is, can an observer outside of this object see things located within it? By default, we can see in from outside if we’re transparent or we’re non-enclosing.

canSeeOut

thing.t[3379]

Can we see out from my interior to my exterior? That is, can an observer inside this object see things located outside of it? By default, we can see out from inside if we’re transparent or we’re non-enclosing.

canSetMeTo

thing.t[7384]

no description available

canSitInMe

postures.t[133]

no description available

canSitOnMe

thing.t[6482]

Although we don’t track postures as such, some objects may be better choices than other for sitting on (e.g. chairs), lying on (e.g. beds) and standing on (e.g. rugs), so we allow these to be tested for individually at the verify stage.

Note that none of these three properties (canSitOnMe, canLieOnMe, canStandOnMe) should normally be overridden to simply true, since they cannot make it possible to sit, lie or stand on something for which isBoardable is not true (or which contType is not On).

canSmellIn

thing.t[3411]

Can we smell in (from an observer on my exterior to an odor source on my interior)? By default, we can smell in if we’re non-enclosing, since most solid materials aren’t very permeable to scents (at human sensitivities, at least).

canSmellOut

thing.t[3419]

Can we smell out (from an observer on my interior to an odor source on my exterior)? By default, we can smell out if we’re non-enclosing, since most solid materials aren’t very permeable to scents (at human sensitivities, at least).

canStandInMe

postures.t[132]

By default we can’t stand, sit or lie in anything. [POSTURES EXTENSION]

canStandOnMe

thing.t[6484]

no description available

canSupply

thing.t[7230]

Flag, can we supply more items from us that are currently in scope? By default we can’t; but a DispensingCollective may be able to.

canTalkToMe

thing.t[8858]

We don’t bother to define isAskable etc. properties since we assume that no inanimate object can be conversed with, and that game code will use the Actor class to allow conversation. In any case since there’s never any difficult in talking about oneself, the various illogicalSelf checks aren’t needed.

Indeed, the handling of conversational commands on Thing is minimal; they are simply ruled out at the verify stage, since most Things can’t converse. The implementation of these actions that allows conversation to take place is on the Actor class. We do however define a canTalkToMe property so that Actor can use the verify handling defined on Thing by just overriding it.

Things can’t be talked to, so game code shouldn’t normally override this property; it’s there to be overridden on the Actor class.

canThrowAtMe

thing.t[7256]

Most objects can the target of a throw, but it’s conceivable that some might be obviously unsuitable

canThrowToMe

thing.t[7309]

Most objects cannot have things thrown to then, since this would imply that they might be able to catch them, which only animate objects can do.

canTurnMeTo

thing.t[7335]

no description available

canTurnWithMe

thing.t[4898]

By default things can’t be used to turn other things with

canTypeOnMe

thing.t[8024]

Most things can’t be typed on.

canUnfastenFromMe

thing.t[7754]

no description available

canUnlockWithMe

thing.t[5833]

Most things can’t be used to unlock with. In practice there’s probably little point in overriding this property since if you do want to use something to unlock other things with, you’d use the Key class.

canUnplugFromMe

thing.t[7824]

no description available

canUnscrewWithMe

thing.t[8308]

no description available

canWriteOnMe

thing.t[8084]

Most things can’t be written on.

checkAttackMsg

thing.t[4565]

If we want Attack to fail at the check stage we can supply a message explaining why.

checkFeelMsg

thing.t[4140]

This property can be defined to display a message at the check stage (and so stop the FEEL action there). Normally checkFeelMsg would be defined as a double-quoted string, but it can also be defined as a double-quoted string or a method that displays some text.

checkKissMsg

thing.t[7939]

If we want Kissing to fail at the check stage we can supply a message here explaining why. This is most simply given as a single-quoted string, but a double-quoted string or method will also work.

circularlyInMsg

thing.t[5434]

no description available

collectiveGroups

thing.t[3183]

CollectiveGroup, or a list of CollectiveGroups, to which this item belongs.

contents

thing.t[2403]

The list of things directly contained by this object

contentsListed

thing.t[1917]

Flag: should this item’s contents be listed? This can be used to control both contentsListedInLook and contentsListedInExamine.

contentsListedInExamine

thing.t[1929]

Flag: should this item’s contents be listed when its container is examined.

contentsListedInLook

thing.t[1923]

Flag: should this item’s contents be listed as part of a room description (when looking around).

contentsListedInSearch

thing.t[1936]

Flag, should this item’s contents be listed when it is searched (by default this is simply true, since it would be odd to have a container that failed to reveal its contents when searched).

contType

thing.t[2399]

This object’s containment type - that is, the locType for direct children. This is given as one of the spatial relation types (In, On, Under, Behind etc).

currentInterlocutor

thing.t[3690]

The currentInterlocutor is the Actor this object is currently in conversation with. This property is only relevant on gPlayerChar, but it is defined here rather than on Actor since the player char can be of kind Thing.

curSetting

thing.t[7378]

The value we’re currently set to.

darkName

thing.t[1017]

The name to display at the head of a room description when it’s dark

decorationActions

thing.t[3916]

The list of actions this object will respond to specifically if isDecoration is true. All other actions will be handled by dobjFor(Default) and/or iobjFor(Default). Game code can override this list (usually to expand it) for decorations that are required to handle additional actions.

If we’re compiling for debugging, it will be useful to allow the GONEAR command with Decorations for testing purposes, but this can’t be included in a release build without causing a compilation error, so we define the decorationActions property with different lists of actions depending on whether we’re compiling for debugging or release.

decorationActions

thing.t[3918]

no description available

defaultPosture

postures.t[129]

The posture that’s adopted by default by an actor entering or boarding this this. [DEFINED IN POSTURES EXTENSION]

desc

thing.t[1638]

The description of this Thing that’s displayed when it’s examined. Normally this would be defined as a double-quoted string, but in more complicated cases you could also define it as a method that displays some text.

directlyHeld

thing.t[2317]

Get everything I’m directly holding, which is everything in my immediate contents which is neither fixed in place nor being worn.

directlyIn

thing.t[3295]

get everything that’s directly in me

directlyWorn

thing.t[2331]

get everything I’m directly wearing

distinguishByContentsOVERRIDDEN

thing.t[2391]

Can I be distinguished in parser messages by my contents? If so, we can be distinguished (in parser messages) from similar objects by our contents, or lack thereof: “bucket of water” vs “empty bucket”. If this is true, our nominalContents property determines the contents we display for this.

dontNeedCleaningObjMsg

thing.t[7063]

no description available

dropItemsBehind

thing.t[4247]

Flag, should any items behind me be left behind when I’m moved; by default, they should.

dropItemsUnder

thing.t[4253]

Flag, should any items behind me be left behind when I’m moved; by default, they should.

dropLocation

thing.t[4430]

The location in which something dropped in me should land.

enclosing

thing.t[3363]

Do we fully enclose our interior contents (true), or only partially (nil)? By default, we assume that our contents are fully enclosed. This can be set to nil for objects that represent spaces that are open on one side, such as a nook in a rock or a create without a lid.

For an object that’s sometimes fully enclosing and sometimes not, such as a cabinet with a door that can be opened and closed, this should be overridden with a method that figures the current value based on the open/closed state.

Note that this only applies to our *interior* contents, such as contents of location type In. Contents that are atop the object or otherwise arranged around the exterior aren’t affected by this.

examined

thing.t[3606]

Have we been examined? This is set to true when the player character examines the object. For a room, LOOK AROUND counts as examination, as does triggering a room description by traveling into the room.

examineListed

thing.t[1906]

Flag: is this item listed when its container is examined.

examineLister

thing.t[1674]

The lister to use to list an item’s contents when it’s examined.

exitLocation

thing.t[6609]

Our exitLocation is the location an actor should be moved to when s/he gets off/out of us.

extContents

thing.t[2664]

Get my list of unenclosed direct contents. This is the subset of my direct contents that have exterior location types (On, Outside, Behind, Under).

familiar

thing.t[3637]

Whether the player character knows of the existence of this object, if if it hasn’t been seen. Set to true for objects that the player character should be familiar with at the start of play, or make true when the PC learns of them.

feelDesc

thing.t[1963]

The description displayed in response to a FEEL command

findHiddenDest

thing.t[4982]

Where should an item that’s been hidden in/under/behind something be moved to when its found? If it’s taken, move into the actor; otherwise move it to the location of the object it’s just been found in/under/behind.

fluidName

thing.t[8137]

Sometimes we may have a container, such as an oilcan, from which we want to pour a liquid, such as oil, and we’re using the same object to do duty for both. We can then use the fluidName property to say ‘the oil’ rather than ‘the oilcan’ in messages that refer specifically to pouring the liquid.

futileToAttackMsg

thing.t[4592]

In case isAttackable is changed to true but no other handling is added, we need to provide some kind of default report.

futileToKissMsg

thing.t[7930]

It’s more logical to kiss actors, so we give the Kiss action a lower logical rank on ordinary things.

getBulkHiddenBehind

thing.t[2226]

no description available

getBulkHiddenIn

thing.t[2225]

no description available

getBulkHiddenUnder

thing.t[2224]

The total bulk of items hidden in, under or behind this object

getFacets

thing.t[3788]

A list of objects that are facets of this object, and so can be referred to with the same pronoun.

getOutermostRoom

thing.t[2783]

Our outermost room, i.e. the top level Room in which we are indirectly or directly contained.

getOutToJump

thing.t[7945]

Flag, if this is a nested room, should an actor get out of it before executing an intransitive Jump command. By default it should.

getWeightHiddenBehind

weight.t[143]

no description available

getWeightHiddenIn

weight.t[142]

no description available

getWeightHiddenUnder

weight.t[141]

The total weight of items hidden in, under or behind this object [WEIGHT EXTENSION]

globalParamName

thing.t[2000]

Our globalParamName is an arbitrary string value that can be used to refer to this thing in a message substitution parameter; for code readability it may be a good idea to make this a string representation of our programmatic name (where we want to define it at all).

groupOrder

thing.t[3177]

Group order. This gives the relative order of this item within its list group.

hearNothingMsg

thing.t[4092]

no description available

hiddenBehind

thing.t[2201]

A list of objects that are treated as hidden behind this one. A LOOK BEHIND command will list them and move them into the enclosing room. It follows that objects placed in this property should not be given an initial location. This should deal with the most common reason for wanting items to be placed behind things (i.e. to hide them). Note, the items in the hiddenBehind property should also be revealed when the player moves the hiding item.

hiddenIn

thing.t[2209]

A list of objects that are treated as hidden inside this one. A LOOK IN command will list them and move them into the enclosing room (or in this one if we’re a container). It follows that objects placed in this property should not be given an initial location.

hiddenUnder

thing.t[2190]

A list of objects that are treated as hidden under this one. A LOOK UNDER command will list them and move them into the enclosing room. It follows that objects placed in this property should not be given an initial location. This should deal with the most common reason for wanting items to be placed under things (i.e. to hide them). Note, the items in the hiddenUnder property should also be revealed when the player moves the hiding item.

illuminationThreshold

brightness.t[369]

[BRIGHTNESS EXTENSION]

The illumination threshold is the available brightness (returned by the brightnessWithin method) that needs to be exceeded in our interior to be able to examine objects or look around or satisfy other visibility criteris (mostly where the objVisible precondition is applies to the current action). The default illuminationThreshold is 1, which mimics the behaviour of both the adv3 library and the adv3Lite library in the absence of this extension.

inDarkDesc

thing.t[2024]

An optional description to be displayed instead of our normal desc and any status information (such as our contents) if we’re examined in a dark room and visibleInDark is true. Note that if visibleInDark is nil inDarkDesc will never be used.

indirectLockableMsg

thing.t[5825]

no description available

initSpecialDesc

thing.t[1809]

A specialDesc that’s shown until this item has been moved

intContents

thing.t[2657]

Get my list of enclosed direct contents. This is the subset of my direct contents that have interior location types (In).

interiorDesc

thing.t[1038]

The “inside” description. This is displayed when an actor LOOKS AROUND from within this object. Note that this applies not only to top-level rooms but also to things like chairs, platforms, and booths that can contain an actor. By default, we simply show the ordinary EXAMINE description (or the darkDesc if there’s no illumination). Non-room containers such as chairs or booths should usually override this to provide the view from inside the object, which usually differs from the ordinary EXAMINE description. For a top-level room, you don’t usually override this, since the only description needed for a room is normally the LOOK AROUND perspective.

inventoryListed

thing.t[1903]

Flag: is this item listed in an inventory listing.

isAttachable

thing.t[7552]

By default most things can’t be attached to any things. The base handling of ATTACH and DETACH on Thing merely rules them out at the verify stage. The SimpleAttachable and NearbyAttachable classes define in the optional attachables.t module provide fuller handling.

isAttackable

thing.t[4533]

Although in theory we can attack almost anything, in practice there’s seldom reason to do so.

isBoardable

thing.t[2361]

Can an actor enter (get in or on) this object. Note that for such an action to be allowing the contType must also match the proposed action.

isBreakable

thing.t[4623]

By default treat everything as breakable, but there are somethings that clearly aren’t like sunbeams, sounds and mountains.

isBurnable

thing.t[6253]

By default we assume most things aren’t burnable

isClean

thing.t[6986]

Assume most things start out not as clean as they could be

isCleanable

thing.t[6983]

Most things probably could be cleaned, even if they’re not worth cleaning in practice. Some things like a mountain or the moon probably can’t be cleaned and could reasonably define isCleanable = nil.

isClimbable

thing.t[6357]

Most things can’t be climbed

isCloseable

thing.t[4800]

By default something is closeable if it’s openable

isConsultable

thing.t[8102]

Most things aren’t consultable

isCuttable

thing.t[4921]

By default things can’t be cut

isDecoration

thing.t[3900]

If I declare this object to be a decoration (i.e. isDecoration = true) then its default behaviour will be to display its notImportantMsg for every action except Examine or GoTo. We can extend the actions it will respond to by adding them to the list in the decorationActions property.

isDetachable

thing.t[7599]

no description available

isDiggable

thing.t[7122]

Most things are not suitable for digging in

isDoffable

thing.t[6322]

By default we assume that something’s doffable if it’s wearable

isDrinkable

thing.t[6960]

Most things aren’t drinkable

isDroppable

thing.t[4424]

By default we can drop anything that’s held

isEdible

thing.t[2365]

Flag: Can this thing be eaten

isEnterable

thing.t[6553]

Flag, can we enter (i.e. get inside) this thing? For most objects, we can’t

isExtinguishable

thing.t[6903]

Most things are extinguishable if they’re lit, but some things (like the sun or a nuclear explosion) might conceivably not be. Note that this property should only be set to nil for things that couldn’t be extinguished even if they were lit (the flames of Hell, for example, which might be considered undousable for all eternity, if you’re bent on writing an infernal game).

isFastenable

thing.t[7652]

Fasten by itself presumably refers to objects like seat-belts. There are not many such fastenable objects so we may things not fastenable by default.

isFastened

thing.t[7655]

Most things start out unfastened.

isFeelable

thing.t[4129]

By default we can try feeling most things, but there may be some things it would be inappropriate to try feeling (like a blazing fire or Aunt Mable) or somethings that cannot be felt (like a ray of light).

isFixed

thing.t[1883]

Flag to indicate whether this item is portable (nil) or fixed in place (true). If it’s fixed in place it can’t be picked up or moved around (by player commands).

isFlippable

thing.t[6238]

Since FLIP X is often synonymous with SWITCH X , by default we make something flippable if it’s switchable.

isFollowable

thing.t[4504]

Flag: can this object be followed? Most inanimate objects cannot, so the default value is nil.

isHidden

thing.t[2242]

Flag, do we want to treat this object as hidden from view (so that the player can’t interact with it)?

isInitialPlayerChar

thing.t[2675]

Am I the Thing object that starts out as the initial player character? For just about every Thing this will not the case, but this can be overridden to true on the one Thing, Player or Actor object that is meant to represent the initial player character. Note, however, that if gameMain already defines a non-nil initialPlayerChar property, this will be used to identify the initial player character object whatever the value of the isInitialPlayerChar on any other object.

isKissable

thing.t[7885]

We can try kissing most things, even if it isn’t very rewarding

isLightable

thing.t[2032]

Is this object lightable (via a player command)? Note that setting this property to true also automatically makes the LitUnlit State applicable to this object, allowing it to be referred to as ‘lit’ or ‘unlit’ as appropriate.

isListed

thing.t[1895]

A global isListed property that can be used to set the value of all the others. By default we’re listed if we’re not fixed in place.

isLit

thing.t[2007]

Is this object lit, i.e. providing sufficient light to see not only this object but other objects in the vicinity by.

isLocked

thing.t[2272]

Flag: is this object currently locked. By default we start out locked if we’re lockable.

isMoveable

thing.t[6711]

By default we assume anything fixed isn’t moveable. That’s not necessarily the case since we may be able to move something by pushing it around (say) even if we can’t pick it up.

isOn

thing.t[2290]

is this item currently switched on?

isOpen

thing.t[4696]

Is this object open. By default we’ll make Things open so that their interiors (if they have any) are accessible, unless they’re openable, in which case we’ll assume they start out closed.

isOpenable

thing.t[4689]

Is this object openable. If this property is set to true then this object can be open and closed via the OPEN and CLOSE commands. Note that setting this property to true also automatically makes the OpenClosed State apply to this object, so that it can be referred to as ‘open’ or ‘closed’ accordingly.

isPlayerChar

thing.t[3861]

Is this object the player character?

isPlugable

thing.t[7781]

Most things can’t be plugged into other things or have other things plugged into them.

isPourable

thing.t[8127]

Most things aren’t pourable (they can’t be poured into or onto other things.

isProminentNoise

thing.t[1972]

Is the this object’s listenDesc displayed in response to an intransitive LISTEN command? (Only relevant if listenDesc is not nil)

isProminentSmell

thing.t[1960]

Is the this object’s smellDesc displayed in response to an intransitive SMELL command? (Only relevant if smellDesc is not nil)

isPullable

thing.t[5368]

We can at least try to pull most things.

isPushable

thing.t[5347]

We can at least try to push most things.

isReadable

thing.t[4475]

By default an object is readable if it defines a non-nil readDesc

isRemoveable

thing.t[6693]

By default an object is removeable if it’s takeable

isScrewable

thing.t[8264]

Most things can’t be screwed

isSettable

thing.t[8004]

Most things aren’t settable.

isSmellable

thing.t[4056]

By default everything is smellable, but you can override this to nil if something isn’t

isSwitchable

thing.t[2287]

Can this object be switched on and off?

isTakeable

thing.t[4169]

By default a Thing is takeable if it’s not fixed in place

isTasteable

thing.t[4098]

By default everything is tasteable, but there might well be things the that it would not be appropriate to taste.

isThrowable

thing.t[4648]

By default something is throwable unless it’s fixed in place.

isTransparent

thing.t[3345]

Are we transparent to light? If this is true, then an observer outside this object can see through it to objects on its interior, and an observer inside can see through to objects on its exterior.

This property controls transparency symmetrically (looking in from outside and looking out from within). The library also lets you control transparency asymmetrically, using canSeeIn and canSeeOut. Those values are by default derived from this one, but you can override them separately to create something like a one-way mirror.

isTurnable

thing.t[4846]

By default we make everything turnable, but lots of things clearly won’t be.

isUnfastenable

thing.t[7723]

no description available

isUnplugable

thing.t[7823]

no description available

isUnscrewable

thing.t[8307]

no description available

isVehicle

thing.t[3144]

Flag; is this Thing a vehicle for an actor? If so then issuing a travel command while in this vehicle will call this vehicle to travel

isWearable

thing.t[2296]

is this object something that can be worn

keyDoesntWorkMsg

thing.t[6152]

If we’ve found a possible key but it doesn’t actually work on this object, report that we’re trying this key but it doesn’t work.

keyList

thing.t[5752]

A list of Keys that can be used to lock or unlock this Thing. Any Keys in this list will cause this Thing to be added to the plausible and actual lock lists of that Key at PreInit. This provides an alternative way of specifying the relation between locks and keys.

keyNotNeededMsg

thing.t[5823]

no description available

kissRank

thing.t[7891]

The logical rank assigned to kissing this object if kissing is allowed. Kissing an inanimate object is less likely than kissing an Actor.

known

thing.t[3672]

Test whether this Thing is known to the player character.

knownKeyList

thing.t[5758]

A list of Keys that the player character starts out knowing at the start of the game can lock our unlock this Thing.

knownProp

thing.t[3681]

If we want to track whether characters other than than the player char know about or have seen this object, we can define knownProp and seenProp as the properties used by this Thing to track what it knows about and has seen.

lastSeenAt

thing.t[3622]

The last location where the player character saw this object. Whenever the object is described or listed in the description of a room or another object, we set this to the object’s location at that time.

lieOnScore

thing.t[6499]

no description available

lightSources

brightness.t[287]

The list of lightSources and their adjusted (for opacity and/or distance) brightness generated by the most recent call to brightnessWithin(). Each element in the list is itself a two-element list of the form [obj, adjustedBrightness] where obj is the object providing light and adjustedBrightness is the brightness of that object adjusted for transmission through distance or partial opacity. [BRIGHTNESS EXTENSION]

listableContents

thing.t[1980]

The subset of our contents that should be listed.

listenDesc

thing.t[1966]

The description displayed in response to a LISTEN command

listenDescWithoutSource

sensory.t[635]

The response to LISTENing TO this object when the actor can’t see us. [DEFINED IN SENSORY EXTENSION]

listenDescWithSource

sensory.t[629]

The response to LISTENing TO this object when the actor can see us. [DEFINED IN SENSORY EXTENSION]

listOrder

thing.t[3165]

Listing order. This is an integer giving the relative position of this item in a miscellaneous item list. The list is sorted in ascending order of this value.

listWith

thing.t[3171]

List group. At the moment this does nothing, but it has been retained from the Mercury library for possible future use.

location

thing.t[2414]

The location of this object, i.e. this object’s immediate container (which may be another Thing, a Room, or an Actor such as the player char). Note that while you should specify the initial location of an object via this property you should never directly alter this property in game code thereafter; to change the location on object during the the course of a game use the moveInto(loc) or actionMoveInto(loc) method.

lockability

thing.t[2266]

The lockability property determines whether this object is lockable and if so how. The possible values are notLockable, lockableWithoutKey, lockableWithKey and indirectLockable.

lockedMsg

thing.t[4796]

no description available

lookBehindMsg

thing.t[5282]

no description available

lookInMsg

thing.t[5069]

By default our lookInMsg just says the actor finds nothing of interest in us; this could be overridden for an objecy with a more interesting interior.

lookListed

thing.t[1900]

Flag: is this item listed in a room description (when looking around).

lookThroughMsg

thing.t[5309]

no description available

lookUnderMsg

thing.t[5186]

no description available

markInventoryAsSeen

thing.t[1944]

Flag, if our contType is Carrier (i.e. we’re an Actor), should our contents be marked as seen even though it hasn’t been listed in a room description? By default this is set to true, on the basis that the inventory (and parts) of an actor would normally be in plain sight.

matchPullOnly

thing.t[8396]

Check if the player specifically asked to PULL this object somewhere. In the main library we assume not, but language-specific code will need to override to check what that player’s command actually said.

matchPushOnly

thing.t[8388]

Check if the player specifically asked to PUSH this object somewhere. In the main library we assume not, but language-specific code will need to override to check what that player’s command actually said.

maxBulkHiddenBehind

thing.t[2220]

no description available

maxBulkHiddenIn

thing.t[2221]

no description available

maxBulkHiddenUnder

thing.t[2219]

The maximum bulk that can be hidden under, behind or in this object, assuming that the player can put anything there at all. Note that this only affects what the player can place there with PUT IN, PUT UNDER and PUT BEHIND commands, not what can be defined there initially or moved there programmatically.

maxSingleBulk

thing.t[2066]

The maximum bulk that a single item may have to be inserted into (onto, under, behind) this object; by default this is the same as the bulk capacity, but you could set a lower value, e.g. to model a bottle with a narrow neck.

maxSingleWeight

weight.t[41]

The maximum weight of any single item we can contain [WEIGHT EXTENSION

maxWeightHiddenBehind

weight.t[137]

no description available

maxWeightHiddenIn

weight.t[138]

no description available

maxWeightHiddenUnder

weight.t[136]

The maximum weight that can be hidden under, behind or in this object, assuming that the player can put anything there at all. Note that this only affects what the player can place there with PUT IN, PUT UNDER and PUT BEHIND commands, not what can be defined there initially or moved there programmatically. [WEIGHT EXTENSION]

mentioned

thing.t[1778]

Has this item been mentioned yet in a room description. Note that this flag is used internally by the library; it shouldn’t normally be necessary to manipulate it directly from game code.

moved

thing.t[3598]

Has this object ever been moved by the player character? This is set to true when the PC takes the object or puts it somewhere.

movedTo

thing.t[6827]

The notional location (other object) this object has been moved to as the result of a MoveTo command.

moveNoEffectMsg

thing.t[6758]

no description available

mustBeCleanedWith

thing.t[6995]

If this is non-nil then this is an object or a list of objects that must be/can be used to clean this object.

myInventoryLister

thing.t[3707]

The lister to use when listing this object’s inventory. By default we use the standard inventory lister for the default WIDE inventory listing and the inventoryTallLister for the TALL inventory listing.

myLookBehindLister

thing.t[5275]

The lister to use when listing the objects behind me in response to a LOOK BEHIND command. By default we use the lookInLister.

myLookInLister

thing.t[5060]

The lister to use when listing the objects inside me in response to a LOOK IN command. By default we use the lookInLister.

myLookUnderLister

thing.t[5180]

The lister to use when listing the objects under me in response to a LOOK UNDER command. By default we use the lookInLister.

myOpeningContentsLister

thing.t[4789]

The lister to use when listing my contents when I’m opened. By default we use the openingContentsLister.

myWornLister

thing.t[3710]

The lister to use when listing what this object is wearing.

needsCleaning

thing.t[6989]

But that most things don’t actually need cleaning in the game

noLongerTalkingToAnyoneMsg

thing.t[9094]

no description available

nominalContentsOVERRIDDEN

thing.t[2382]

My nominal contents is the special contents item we can use in naming the object. This is useful for containers whose identities come primarily from their contents, such as a vessel for liquids or a box of loose files. Returns an object that qualifies the name: a “water” object for BOX OF WATER, a “files” object for BOX OF FILES. Nil means that the object isn’t named by its contents.

Note that this is always a single object (or nil), not the whole list of contents. We can only be named by one content object. (So you can’t have a “box of books and papers” by having separate nominal contents objects for the books and the papers; although you could fake it by creating a “books and papers” object.)

noNeedToCleanMsg

thing.t[7059]

no description available

notFastenedMsg

thing.t[7775]

no description available

notHoldingMsg

thing.t[4471]

And I can’t drop something that game code has deemed to be not droppable for some other reason.

notImportantMsg

thing.t[3943]

no description available

notInMsg

thing.t[7222]

We’re also a poor choice if none of the tentative direct objects is in our list of notional contents

notLitMsg

thing.t[6930]

no description available

notLockableMsg

thing.t[5821]

If we are lockable with key, then were a good choice of object for an UnlockWith action provided we’re currently locked.

notLockedMsg

thing.t[5826]

no description available

notSwitchableMsg

thing.t[6183]

no description available

notTalkingToAnyoneMsg

thing.t[9091]

no description available

notWornMsg

thing.t[6354]

no description available

objInPrep

thing.t[2039]

The preposition that should be used to describe containment within this thing (e.g. ‘in’, ‘on’ , ‘under’ or ‘behind’). By default we get this from our contType.

objIntoPrep

thing.t[2046]

The preposition that should be used to describe movement to within this thing (e.g. ‘into’, ‘onto’ , ‘under’ or ‘behind’). By default we get this from our contType.

okayCleanMsg

thing.t[7066]

no description available

okayGetOutOfMsg

thing.t[6656]

no description available

okayLieInMsg

postures.t[460]

[MODIFIED FOR POSTURES EXTENSION]

okayLieOnMsg

postures.t[275]

[DEFINED IN POSTURES EXTENSION]

okayLockMsg

thing.t[6079]

Make us locked.

okayOpenMsg

thing.t[4791]

no description available

okayPushIntoMsg

thing.t[8723]

no description available

okayPushOutOfMsg

thing.t[8791]

no description available

okaySetMsg

thing.t[7416]

no description available

okaySitInMsg

postures.t[428]

[MODIFIED FOR POSTURES EXTENSION]

okaySitOnMsg

postures.t[243]

[DEFINED IN POSTURES EXTENSION]

okayStandInMsg

postures.t[399]

[MODIFIED FOR POSTURES EXTENSION]

okayStandOnMsg

postures.t[212]

[DEFINED IN POSTURES EXTENSION]

okayUnlockMsg

thing.t[6000]

Make us unlocked.

opacity

brightness.t[93]

[BRIGHTNESS EXTENSION]

Our opacity is the extent to which we reduce the brightness of any light that passes through us. An opacity of 4 or more will cut off the brightest light, while an opacity of 0 means we’re transparent. By default we have an opacity of 0 if we’re transparent and 4 otherwise.

Note that if we want any light to penetrate us at all we should set transparency to true (we’re at least somewhat light permeable) and then set opacity to some suitable value (if we don’t want it to be zero, which is otherwise the default for a transparent object).

opened

thing.t[4714]

Flag, has this object ever been opened. Note that this is nil for an object that starts out open but has never been closed and opened again.

openStatusReportable

thing.t[1786]

Do we want this object to report whether it’s open? By default we do if it’s both openable and open.

owner

thing.t[3205]

The owner or owners of the object. This is for resolving possessives in the player’s input, such as BOB’S WALLET. By default, an object has no explicit owner, so this is an empty list.

This should only return the *explicit* owner(s), not an implied locational owner. For example, if Bob is holding a key, it’s implicitly BOB’S KEY. However, the key may or may not still be Bob’s after he drops it. If the key is something that’s understood to belong to Bob, whether it’s currently in his physical possession or not, then this routine would return Bob; otherwise it would return nil.

An object can have multiple explicit owners, in which case it’ll be recognized with a possessive qualifier for any of the owners. The first owner in the list is the nominal owner, meaning its the one we’ll use if we’re called upon to display the object’s name with a possessive phrase.

ownsContents

thing.t[3224]

Are we the nominal owner of the objects we contain? This controls whether or not we can be chosen as the nominal owner of a contained object for display purposes. If a contained object has no explicit owner, it can still be implicitly owned by an actor carrying it, or by another suitable container. (Note that this only applies as a default. When an item in our contents has an explicit owner, that will override the implied container ownership for that item. So, for example, Bob can be carrying Bill’s wallet wallet, and as long as the wallet has its explicit owner set, we’ll still describe it as Bill’s despite its location.)

By default, most objects are not nominal owners. Actors generally should set this to true, so that (for example) anything Bob is carrying can be described as Bob’s. Something with contType = Carrier is likely to be an actor and hence something that can own its contents.

paraBrksBtwnSubcontents

thing.t[1540]

Do we want paragraph breaks between the listings of subcontents (i.e. the contents of this item’s contents)? By default we take our value from the global setting on gameMain.

partOfYouMsg

thing.t[4472]

no description available

posture

postures.t[123]

The posture currently adopted by this Thing. We define this on Thing rather than Actor mainly because the player character can be a Thing, but it could also use to describe the metaphorical posture of inanimate objects (A rug lies on the floor, the jug sits on the rug, the tall grandfather clock stands by the door). [DEFINED IN POSTURES EXTENSION]

preCondActor

thing.t[3963]

no description available

pullNoEffectMsg

thing.t[5387]

no description available

pushNoEffectMsg

thing.t[5365]

no description available

readDesc

thing.t[1951]

The text we display in response to a READ command. This can be nil (if we’re not readable), a single-quoted string, a double-quoted string

recognizableInDark

thing.t[1011]

Can the player character recognize this room (enough to know its name and have a rough idea of its location) in the dark? (If so then looking around in this room in the dark makes it visited and familiar, otherwise it doesn’t).

remapActor

thing.t[3961]

If our contType isn’t Carrier we’re unlikely to be an actor, so we’re a poor choice of object if the parser has to select an actor, typically when the player has entered a command targeted at an NPC.

remapBehind

thing.t[2154]

If non-nil, remapUnder specified the object that acts as our proxy rear, i.e. the object to which any PUT BEHIND or LOOK BEHIND action directed at us will be redirected.

remapIn

thing.t[2134]

If remapIn is not nil, a LOOK IN, PUT IN, OPEN, CLOSE, LOCK or UNLOCK command performed on this Thing will be redirected to the object specified on remapIn. In other words, remapIn specifies the object that acts as our proxy container.

remapOn

thing.t[2140]

If non-nil, remapOn speficies the object that acts as our proxy surface, in other words the object to which PUT ON will be redirected.

remapProps

thing.t[2125]

The list of possible remap props

remapUnder

thing.t[2147]

If non-nil, remapUnder specified the object that acts as our proxy underside, i.e. the object to which any PUT UNDER or LOOK UNDER action directed at us will be redirected.

roomContentsLister

thing.t[1095]

The contents lister to use for listing this room’s miscellaneous contents. By default we use the standard lookLister but this can be overridden to use a CustomRoomLister (say) to provide just about any wording we like.

roomPart

roomparts.t[164]

The room part (e.g. defaultNorthWall) with which we’re notionally associated. [DEFINED IN ROOMPARTS EXTENSION]

roomPartDesc

roomparts.t[170]

The description of ourselves to be displayed when our associated roomPart is examined. [DEFINED IN ROOMPARTS EXTENSION]

roomSubContentsLister

thing.t[1102]

The contents lister to use for listing this room’s miscellaneous subcontents. By default we use the standard lookContentsLister but this can be overridden.

roomTitleOVERRIDDEN

thing.t[1014]

The name to display at the head of a room description

searchListed

thing.t[1911]

Flag: is this item listed when is container is searched (or looked in).

seen

thing.t[3614]

Have we been seen? This is set to true the first time the object is described or listed in a room description or the description of another object (such as LOOK IN this object’s container).

seenProp

thing.t[3682]

no description available

shouldBeBroken

thing.t[4626]

Probably most things shouldn’t be broken though.

shouldNotBreakMsg

thing.t[4645]

no description available

shouldNotPourIntoMsg

thing.t[8257]

no description available

shouldNotPourOntoMsg

thing.t[8260]

no description available

sightSize

senseRegion.t[794]

The sightSize can be small, medium or large and controls how visible this object is from a remote location. If it’s small, it can’t be seen from a remote location at all. It it’s medium, the object can be seen, but it’s not possible to discern any detail. If it’s large, it can be seen and described. Note that this behaviour is only the default, however, since it can be changed by overriding the isVisibleFrom() and remoteDesc() methods. Note also that sightSize is not related to the bulk property (unless you override sightSize to make it so).

sitOnScore

thing.t[6498]

As well as ruling out certain objects for sitting, lying or standing on, we can also give them a score for each of these postures; e.g. a bed may be particularly suitable for lying on (although you could lie on the sofa) while a chair may be particularly suitable for sitting on (though you could sit on the bed.

By default we’ll give each posture a score of 100, the normal logical verify score. Note that these scores have no effect if the corresponding can xxxOnMe property is nil.

smellDesc

thing.t[1954]

The description displayed in response to a SMELL command

smellDescWithoutSource

sensory.t[609]

The response to SMELLing this object when the actor can’t see us. [DEFINED IN SENSORY EXTENSION]

smellDescWithSource

sensory.t[603]

The response to SMELLing this object when the actor can see us. [DEFINED IN SENSORY EXTENSION]

smellNothingMsg

thing.t[4078]

no description available

smellObj

sensory.t[702]

Our associated Odor object, if we have one [SENSORY EXTENSION]

smellSize

senseRegion.t[810]

The smellSize can be small, medium or large. By default something is smellable from a remote location either if its smellSize is large or if it smellSize is not small and its remoteSmellDesc() method has been defined. Overriding isSmellableFrom(pov) may change these rules.

soundObj

sensory.t[705]

Our associated Noise object, if we have one. [SENSORY EXTENSION]

soundSize

senseRegion.t[802]

The soundSize can be small, medium or large. By default something is audible from a remote location either if its soundSize is large or if it soundSize is not small and its remoteListenDesc() method has been defined. Overriding isAudibleFrom(pov) may change these rules.

specialDesc

thing.t[1795]

If present, a description of this object shown in a separate paragraph in the listing of the contents of a Room. If specialDesc is defined then this paragraph will be displayed regardless of the value of isListed.

specialDescBeforeContents

thing.t[1833]

Is this item listed before or after the list of miscellaneous contents in the room. By default we’ll show the specialDesc of items before miscellaneous items in a room description but afterwards otherwise: this places specialDescs in a more logical order in relation to the text of listers used to list the contents of obejcts other than rooms.

specialDescListWith

thing.t[1836]

For possible future use; at the moment this doesn’t do anything

specialDescOrder

thing.t[1824]

The specialDescOrder property controls where in a series of specialDesc paragraphs this item is mentioned: the higher the number, the later it will come relative to other items. Note that this does not override the specialDescBeforeContents setting.

stagingLocation

thing.t[6612]

Our staging location is where we need to be to get on/in us

standOnScore

thing.t[6500]

no description available

stateDesc

thing.t[1645]

The state-specific description of this object, which is appended to its desc when examined. This is defined as a single-quoted string to make it easy to change at run-time.

tasteDesc

thing.t[1975]

The description displayed in response to a TASTE command

throwFallsShortMsg

thing.t[7333]

no description available

tooDarkToReadMsg

brightness.t[395]

The message to display if there’s not enough light to read this item. [BRIGHTNESS EXTENSION]

tooDarkToSeeMsg

thing.t[4050]

The message to display when it’s too dark to see anything

tooFarAwayToHearMsg

senseRegion.t[962]

Otherwise say this object is too far away for the actor to hear.

tooFarAwayToReadMsg

senseRegion.t[981]

no description available

tooFarAwayToSeeDetailMsg

senseRegion.t[907]

Otherwise say this object is too far away for the actor to see any detail.

tooFarAwayToSmellMsg

senseRegion.t[1036]

Otherwise say this object is too far away for the actor to smell.

totalWeight

weight.t[20]

Our total weight, including the weight of our contents [WEIGHT EXTENSION

turnLastExamined

cmdhelp.t[873]

no description available

turnLastMoved

cmdhelp.t[856]

no description available

turnLastMovedInto

cmdhelp.t[857]

no description available

turnNoEffectMsg

thing.t[4874]

no description available

useInitSpecialDesc

thing.t[1816]

By default we use the initSpecialDesc until the object has been moved, but this can be overridden with some other condition.

useKey_

thing.t[6154]

no description available

useSpecialDesc

thing.t[1805]

Should the specialDesc be used? Normally we use the specialDesc if we have one, but we may want to override this for particular cases. For example, if we want an item to have a paragraph to itself until it’s moved we could define useSpecialDesc = (!moved) [making it equivalent to initSpecialDesc]. Note that the useSpecialDesc property only has any effect if specialDesc is not nil.

viaMode

thing.t[8399]

no description available

visibleInDark

thing.t[2016]

Is this object visible in the dark without (necessarily) providing enough light to see anything else by, e.g. the night sky.

vocabLikelihood

thing.t[3781]

A property that can be used to boost this object being chosen by the parser, other things being equal; it can be used as a tie-breaker between two objects that otherwise have the same verification scores. Game code should normally use fairly small values for this property, say between -20 and +20, to prevent overriding the verification score.

weight

weight.t[17]

Our own weight, not counting the weight of our contents [WEIGHT EXTENSION]

weightCapacity

weight.t[38]

The total weight we’re capable of containing [WEIGHT EXTENSION

withKeyMsg

thing.t[6081]

no description available

wornBy

thing.t[2302]

If this object is currently being worn by someone, the wornBy property contains the identity of the person wearing it.

Methods  

abcName (action, role)

english.t[2169]

Announce Best Choice name. This can be used in those rare cases where you want to override the name the parser uses to describe an object when announcing its best choice of object. For example, if you have a bottle of wine from which you can fill a glass, you might prefer ‘(with wine from the bottle)’ to ‘(with the bottle of wine)’ following FILL GLASS; action is the action being carried out for which the object has been chosen and role(DirectObject or IndirectObject) is the role the chosen object is playing in the action. By default this method just returns theName.

accumulateBrightness (maxBrightness)

brightness.t[326]

[BRIGHTNESS EXTENSION] The accumulateBrightness() method is a stub (or hook) for a user-defined algorithm for accumulating the brightness of multiple ligjt sources if this is desired. By default we simply return the value of the maxBrightness parameter that is passed to us (which is the brightness returned by the latest call to brightnessWithin()), but game code can override this method to provide some other calculation of accumulated brightness by iterating over the list of objects and their adjusted brightnesses in our lightSources property.

Note that accumulateBrightness is provided to allow it to be readily overridden by game code, but is not designed to be directly called from game code, which should call it only via accumulatedBrightnessWithin();

accumulatedBrightnessWithin ( )

brightness.t[296]

[BRIGHTNESS EXTENSION] This is little more than a hook for user code to provide its own means of accumulating the brightness from multiple light sources.

actionMoveInto (newCont)

thing.t[2476], cmdhelp.t[863], roomparts.t[178], signals.t[275]

Move into generated by a user action, which includes notifications

Modified in cmdhelp.t[863]:
Modified for CMDHELP EXTENSION. Note the last turns on which this object was moved and on which something was moved into this object.

Modified in roomparts.t[178]:
We modify actionMoveInto here so that an action that results in moving an object (e.g. taking a picture that’s notionally hanging on a wall) removes the association between the object and its room part. [MODIFIED FOR ROOMPARTS EXTENSION]

Modified in signals.t[275]:
emit a actmoveSignal or unlitSignal when this object moved as part of action handling. [SIGNALS EXTENSION]

actorAction ( )

thing.t[3843]

The before action handling on this Thing if it’s the current actor. We define it here rather than on Actor since the player character can be a Thing. By default we do nothing.

addToAllContents (vec, lst)

thing.t[3286]

no description available

addToContents (obj, vec?)

thing.t[2423]

Add an item to this object’s contents. Normally this method is used internally in the library than directly by game code. If the vec parameter is supplied, the object added to our contents is also added to vec; again this is intended primarily for internal use by the library.

afterAction ( )

thing.t[3858]

After action notification on this Thing; this is triggered whenever an action has just been performed when we’re in scope. The action we’d test for here would normally be one that *doesn’t* involve this Thing.

afterTravel (traveler, connector)

thing.t[3802]

After travel notification. This is called just after traveler has traveled via connector.

allContents ( )

thing.t[3277]

Return a list of everything that’s directly or indirectly contained within us.

allowReachOut (obj)

thing.t[3481]

Check whether the actor can reach out of this object to touch obj, if obj is not in this object.

aobjFor (Default)

tiaaction.t[382]

Defined on TIAAction extension.

beforeAction ( )

thing.t[3851]

Before action notification on this Thing; this is triggered whenever an action is about to be performed when we’re in scope (and could be used to veto the action with an exit macro). The action we’d test for here would normally be one that *doesn’t* involve this Thing.

beforeMovePushable (connector, dir)

thing.t[8584]

Use the travelVia() method of the iobj to move the dobj to its new location.

beforeTravel (traveler, connector)

thing.t[3795]

Before travel notification. This is called just before traveler attempts to travel via connector. By default we do nothing

brightnessWithin ( )

brightness.t[111]

How bright is it within us (assuming, in practice, that we’re either a Room or an enterable container (aka Booth)? [BRIGHTNESS EXTENSION]

byRoom (arg)

thing.t[3882]

This method is primarily intended for use with the symconn extension, where it is redefined, but other code may find a use for it.

canHear (obj)

thing.t[2565]

Is obj audible from us?

cannotPushTravelMsg ( )

thing.t[8506]

Display a message explaining that push travel is not possible

cannotReachOutMsg (target)

thing.t[3522]

Return a message (single-quoted string) explaining why target can’t be reached from inside this Thing (when this Thing is typically some kind of nested room such as a Booth or Platform).

canReach (obj)

thing.t[2571]

Is obj reachable (by touch) from us?

canSee (obj)

thing.t[2562]

Is obj visible from us?

canSmell (obj)

thing.t[2568]

Is obj smellable from us?

canTalkTo (other)

thing.t[3697]

Can this Thing (which might be the Player Char for instance) talk to other?

checkDisplay (prop)

thing.t[1766]

Check if displaying prop could possibly produce any output. The only tests we apply here is that prop is not defined as nil.

checkInsert (obj)

thing.t[2099], weight.t[48]

Check whether an item can be inserted into this object, or whether doing so would either exceed the total bulk capacity of the object or the maximum bulk allowed for a single item.

Modified in weight.t[48]:
Check whether obj can be inserted into us without exceeding our bulk and weight constraints. [WEIGHT EXTENSION]

checkPushTravel ( )

thing.t[8516]

Check the travel barriers on the indirect object of the action

checkReach (actor)

thing.t[3457]

Check whether the actor can reach (touch) this object. If this method displays anything (which should be the reason this object can’t be touched) then the object can’t be reached. Note that this only has any effect when the touchObj preCondition is defined.

checkReachIn (actor, target?)

thing.t[3471]

Check whether an actor can reach inside this object (for reasons other that it enclosing its contents; e.g. because it’s out of reach). If this method displays anything (which should be the reason the interior of this object can’t be reached) then disallow reaching inside. Note that this only has any effect when the touchObj preCondition is defined on this object. By default we can reach inside if we can reach this object and not otherwise. If the optional target parameter is supplied, it’s the object that actor is trying to reach.

checkRemove (obj)

thing.t[2520]

checkRemove is called from the check stage of an action (typically TAKE) that might remove obj from me. If it wants to object to the removal of the object, it should simply display a message explaining why. By default we call the same method our container to check whether anything in our containment hierarchy objects to the removal. If this method is overridden in game code it may only need to call inherited(obj) on any branch that doesn’t itself object to the removal.

checkRoomToHold ( )

thing.t[4394], weight.t[99]

Check that the actor has enough spare bulkCapacity to add this item to his/her inventory. Since by default everything has a bulk of zero and a very large bulkCapacity, by default there will be no effective restriction on what an actor (and in particular the player char) can carry, but game authors may often wish to give portable items bulk in the interests of realism and may wish to impose an inventory limit by bulk by reducing the bulkCapacity of the player char.

Modified in weight.t[99]:
Check whether the actor has the bulk and weight capacity to hold us. [WEIGHT EXTENSION]

checkSetting (val)

thing.t[7375]

If the setting is valid, do nothing. If it’s invalid display a message explaining why. We do nothing here but this is overridden on the Settable class, which may be easier to use than providing your own implementation on Thing.

childLocType (child)

thing.t[2844]

Get the containment relationship between ‘child’ and ‘self’. This returns the containment type of the immediate child of ‘self’ that contains ‘child’.

commonContainingParent (other)

thing.t[2863]

Find the nearest common containing parent of self and other. Unlike commonInteriorParent this doesn’t take account of the type of containment (it can be In, On, Under, Behind or anything else) just so long as we find a common parent in the containment hierarchy.

commonInteriorParent (other)

thing.t[2902]

Find the nearest common interior parent of self and other. This finds the nearest parent that both self and other are inside of.

containerPath (other)

thing.t[2947]

Get the interior containment path from ‘self’ to ‘other’. This returns a list containing three elements. The first element is a sublist giving the interior containers you have to traverse outwards from self up to the common interior parent. The second element is the common container; this will be nil if the two objects are in separate rooms. The third element is a sublist giving the containers you have to traverse inwards from the common parent to other.

containerPathBlock (other, inProp, outProp)

thing.t[3026]

Search for a “blockage” along the container path between ‘self’ and ‘other’. ‘outProp’ and ‘inProp’ are “can” properties (&canSeeOut, &canReachIn, etc) that test a container to see whether we can see/reach/hear/etc in or out of the container.

We trace the containment path, using traceContainerPath(). For each outbound container on the path, we evaluate the container’s outProp property: if this is nil, we add that container to the blockage list. Next, if there’s no common parent, we add the outermost room containing ‘self’ to the list. Next, we trace the inbound path, evaluating each container’s inProp property: if nil, we add that container to the blockage list.

Finally, we return the blockage list. This is a vector giving all of the blockages we found, in the order we encountered them.

darkDesc ( )

thing.t[1020]

The description of the room when it’s dark

describeMovePushable (connector, dest)

thing.t[8647]

Otherwise do nothing, because our ‘connector’ must be a string or method that explains why travel that way isn’t possible.

describePushTravel (via)

thing.t[8663]

This message, called on the direct object of a PushTravel command (i.e. the object being pushed) is displayed just before travel takes place. It is used when the PushTravel command also involves an indirect object, e.g. a Passage, Door or Stairway the direct object is being pushed through, up or down. The via parameter is the preposition relevant to the kind of pushing, e.g. Into, Through or Up.

directChildParent (other)

thing.t[2826]

Find the immediate child of ‘self’ that contains ‘other’. If ‘other’ is directly in ‘self’, we return ‘other’; otherwise, we return an object directly within ‘self’ that contains ‘obj’, directly or indirectly. If ‘other’ is not within ‘self’, we return nil.

discover (stat, =, true)

thing.t[2249], signals.t[221]

Make a hidden item unhidden. If the method is called with the optional parameter and the parameter is nil, i.e. discover(nil), the method instead hides the object.

Modified in signals.t[221]:
emit a discoverSignal or undiscoverSignal when this object is discovered or undiscovered. SIGNALS EXTENSION]

display (prop)

thing.t[1682]

Attempt to display prop appropriately according to it data type (single-quoted string, double-quoted string, integer or code). The prop parameter must be provided as a property pointer.

displayAlt (prop, altMsg?)

thing.t[1731]

Attempt to display the message defined in the property prop, and return true if anything is displayed. Otherwise, if the altMsg parameter is supplied (either as a single-quoted string or as a property pointer) display it instead, and then in any case return nil to tell the caller that nothing was displayed by prop.

This method is primarily for use with properties such as smellDesc and listenDesc for which alternatives may need to be displayed if they don’t display anything.

dobjFor(AskAbout)

thing.t[8861]

no description available

dobjFor(AskFor)

thing.t[8874]

no description available

dobjFor(Attach)

thing.t[7554]

no description available

dobjFor(AttachTo)

thing.t[7565]

no description available

dobjFor(Attack)

thing.t[4535]

no description available

dobjFor(AttackWith)

thing.t[4570]

no description available

dobjFor(Board)

thing.t[6425], postures.t[282]

no description available

Modified in postures.t[282]:
If an actor Boards something, we need to know what posture the actor ends up in; we use the new location’s default posture. [MODIFIED FOR POSTURES EXTENSION]

dobjFor(Break)

thing.t[4628]

no description available

dobjFor(Burn)

thing.t[6255]

no description available

dobjFor(BurnWith)

thing.t[6265]

no description available

dobjFor(Clean)

thing.t[7012]

The handling of the Clean action is possibly more elaborate than it needs to be by default, and game code may wish to override it with a different implementation, but the aim is to provide a framework that covers some common cases.

An object starts out with isClean = nil. Cleaning the object makes isClean true (at which point it doesn’t need cleaning again).

If an object needs another object to be cleaned with (e.g. if in order to clean the window you need a wet sponge to clean it with), this can be defined by setting mustBeCleanedWith to an object or a list of objects that can be used to clean this direct object.

dobjFor(CleanWith)

thing.t[7068]

no description available

dobjFor(Climb)

thing.t[6359]

no description available

dobjFor(ClimbDown)

thing.t[6386]

no description available

dobjFor(ClimbUp)

thing.t[6371]

no description available

dobjFor(Close)

thing.t[4802]

no description available

dobjFor(ConsultAbout)

thing.t[8109]

The base handling on Thing merely rules out the Consult action at the verify stage. For a fuller implementation that allows consulting use the Consultable class.

dobjFor(Cut)

thing.t[4923]

no description available

dobjFor(CutWith)

thing.t[4935]

no description available

dobjFor(Default)

thing.t[3926]

Our handling of any action of which we’re the direct or indirect action that’s not in our list of decorationActions when our isDecoration property is true. By default we just stop the action at the verify stage and display our notImportantMsg.

dobjFor(Detach)

thing.t[7601]

no description available

dobjFor(DetachFrom)

thing.t[7615]

no description available

dobjFor(Dig)

thing.t[7124]

no description available

dobjFor(DigWith)

thing.t[7151]

For DigWith we merely provide verify handlers that rule out the action wih the default values of isDiggable and canDigWithMe. The library cannot model the effect of digging in general, so it’s up to game code to implement this on particular objects as required.

dobjFor(Doff)

thing.t[6324]

no description available

dobjFor(Drink)

thing.t[6962]

no description available

dobjFor(Drop)

thing.t[4432]

no description available

dobjFor(Eat)

thing.t[6936]

no description available

dobjFor(Enter)

thing.t[6557], postures.t[470]

Treat Enter X as equivalent to Get In X

Modified in postures.t[470]:
When an actor enters something we need to determine what posture the actor ends up in. [MODIFIED FOR POSTURES EXTENSION]

dobjFor(EnterOn)

thing.t[8069]

The base handling is simply to rule out EnterOn at verify. There’s no further handling the library can provide for a ‘general’ case so it’s up to game code to define it for specific cases.

dobjFor(Examine)

thing.t[3968], senseRegion.t[862], cmdhelp.t[879]

Now the handling for specific actions

Modified in senseRegion.t[862]:
Modify the effect of Examine to show the remoteDesc if appropriate, or else our regular desc if our sightSize is large, or else a message to say we’re too far away to see any detail. If we’re in the same room as the actor, simply carry out the regular (inherited) method.

Modified in cmdhelp.t[879]:
Modified for CMDHELP EXTENSION. Note the last turn on which this object was examined.

dobjFor(Extinguish)

thing.t[6905]

no description available

dobjFor(Fasten)

thing.t[7664]

no description available

dobjFor(FastenTo)

thing.t[7692]

no description available

dobjFor(Feel)

thing.t[4142]

no description available

dobjFor(Flip)

thing.t[6240]

no description available

dobjFor(Follow)

thing.t[4506]

no description available

dobjFor(GetOff)

thing.t[6614], postures.t[309]

no description available

Modified in postures.t[309]:
If an actor gets off something, we need to know what posture the actor ends up in. We use the new location’s defaultPosture. [MODIFIED FOR POSTURES EXTENSION]

dobjFor(GetOutOf)

thing.t[6634], postures.t[490]

no description available

Modified in postures.t[490]:
When an actor gets out of something we need to determine what posture the actor ends up in. We use the new location’s default posture. [MODIFIED FOR POSTURES EXTENSION]

dobjFor(GiveTo)

thing.t[8961]

no description available

dobjFor(GiveToImplicit)

thing.t[9062]

no description available

dobjFor(GoAlong)

thing.t[5332]

no description available

dobjFor(GoNear)

thing.t[9173]

The GoNear action allows the player character to teleport around the map.

dobjFor(GoThrough)

thing.t[5315]

no description available

dobjFor(GoTo)

thing.t[7426]

The GoTo action allows the player character to navigate the map through the use of commands such as GO TO LOUNGE.

dobjFor(JumpOff)

thing.t[7953]

no description available

dobjFor(JumpOver)

thing.t[7988]

The base handling of JumpOver is simply to rule it out at the verify stage.

dobjFor(Kiss)

thing.t[7893]

no description available

dobjFor(LieIn)

thing.t[6603], postures.t[437]

no description available

Modified in postures.t[437]:
LieIn is handled much like StandIn [MODIFIED FOR POSTURES EXTENSION]

dobjFor(LieOn)

thing.t[6469], postures.t[251]

no description available

Modified in postures.t[251]:
Modification for LieOn handling [DEFINED IN POSTURES EXTENSION] If the actor is already on the dobj, we just try to change the actor’s posture to lying. Otherwise we first move the actor to the dobj and then change the actor’s posture to lying.

dobjFor(LieOn)

thing.t[6528]

no description available

dobjFor(Light)

thing.t[6867]

Lighting an object makes it a light source by making its isLit property true.

dobjFor(ListenTo)

thing.t[4080], senseRegion.t[916], sensory.t[642]

no description available

Modified in senseRegion.t[916]:
Modify the effect of ListenTo to show the remoteListenDesc if appropriate, or else our regular listenDesc if our soundSize is large, or else a message to say we’re too far away to hear. If we’re in the same room as the actor, simply carry out the regular (inherited) method.

Modified in sensory.t[642]:
[MODIFIED FOR SENSORY EXTENSION] If I have an associated Noise object which isn’t emanating, assume I have fallen silent, otherwise carry out the inherited handling.

dobjFor(Lock)

thing.t[6002]

no description available

dobjFor(LockWith)

thing.t[5855]

no description available

dobjFor(LookBehind)

thing.t[5196]

no description available

dobjFor(LookIn)

thing.t[4984]

no description available

dobjFor(LookThrough)

thing.t[5292]

no description available

dobjFor(LookUnder)

thing.t[5106]

no description available

dobjFor(Move)

thing.t[6718]

Moving an object is generally possible if the object is portable, but there’s no obvious effect, so by default this action does nothing except say it’s done nothing.

dobjFor(MoveTo)

thing.t[6801]

MoveTo is a more complex case than MOVE or MOVE WITH. In this implementation we assume that it represents moving the direct object to the vicinity of the indirect object, and so we track the object it’s been moved to.

This might be useful, say, if you wanted the player to have to MOVE the chair TO the bookcase before being able to reach the top shelf by standing on the chair, since you could then check the value of the chair’s movedTo property before deciding whether the top shelf was accesssible.

dobjFor(MoveWith)

thing.t[6738]

no description available

dobjFor(Open)

thing.t[4723]

no description available

dobjFor(PlugIn)

thing.t[7862]

no description available

dobjFor(PlugInto)

thing.t[7790]

The base handling of PlugInto on Thing merely rules it out at the verify stage. A fuller implementation is provided by the PlugAttachable class in the optional attachables module.

dobjFor(Pour)

thing.t[8145]

The base handling of Pour, PourOnto and PourInto is simply to rule out all three actions at the verify stage. Game code that wants to allow these actions on specific objects will need to provide further handling for them.

dobjFor(PourInto)

thing.t[8204]

no description available

dobjFor(PourOnto)

thing.t[8155]

no description available

dobjFor(Pull)

thing.t[5370]

no description available

dobjFor(Purloin)

thing.t[9105]

PURLOIN allows the player to move any portable object in the game directly into his/her inventory, wherever it is currently. We don’t allow absolutely anything to be purloined, as this could cause chaos.

dobjFor(Push)

thing.t[5349]

no description available

dobjFor(PushTravelClimbDown)

thing.t[8817]

no description available

dobjFor(PushTravelClimbUp)

thing.t[8793]

no description available

dobjFor(PushTravelDir)

thing.t[8425]

PushTravelDir handles pushing an object in a particular direction, e.g. PUSH BOX NORTH

dobjFor(PushTravelEnter)

thing.t[8715]

PushTravelEnter handles commands like PUSH BOX INTO COFFIN, where the indirect object is a Booth-like object. The syntactically identical command for pushing things into an Enterable (e.g. PUSH BOX INTO HOUSE where HOUSE represents the outside of a separate location) is handled on the Enterable class.

dobjFor(PushTravelGetOutOf)

thing.t[8753]

no description available

dobjFor(PushTravelThrough)

thing.t[8684]

PushTravelThrough handles pushing something through something, such as a door or archway. Most of the actual handling is dealt with by the common routines defined above.

dobjFor(PutBehind)

thing.t[5653]

no description available

dobjFor(PutIn)

thing.t[5469]

no description available

dobjFor(PutOn)

thing.t[5396]

no description available

dobjFor(PutUnder)

thing.t[5560]

no description available

dobjFor(QueryAbout)

thing.t[8915]

no description available

dobjFor(Read)

thing.t[4477], senseRegion.t[969], brightness.t[382]

no description available

Modified in senseRegion.t[969]:
Modify the effect of a Read action to prevent this item being read from a remote location unless isReadableFrom(gActor) is true.

Modified in brightness.t[382]:
If the available light is less than the light we need to read this item (its brightnessForReading) then stop the read action at the check stage by displaying our tooDarkToReadMsg.

dobjFor(Remove)

thing.t[6668]

We’ll take REMOVE to mean DOFF when it’s dobj is worn and TAKE otherwise. This handling will be dealt with by removeDoer insteadof remap, since this form of remap has now been discontinued. See english.t for removeDoer (which seems to be a language-specific construct)

dobjFor(SayTo)

thing.t[8902]

no description available

dobjFor(Screw)

thing.t[8274]

In the base handling we simply rule out Screw and Unscrew actions at the verify stage. It’s up to game code to provide specific handling for objects that can be screwed and unscrewed.

dobjFor(ScrewWith)

thing.t[8284]

no description available

dobjFor(Search)

thing.t[6704]

Treat SEARCH as equivalent to LOOK IN

dobjFor(Set)

thing.t[8010]

The Set command by itself doesn’t do much. By default we just rule it out at the verify stage.

dobjFor(SetTo)

thing.t[7386]

no description available

dobjFor(ShowTo)

thing.t[9002]

no description available

dobjFor(ShowToImplicit)

thing.t[9034]

no description available

dobjFor(SitIn)

thing.t[6602], postures.t[405]

no description available

Modified in postures.t[405]:
SitIn is handled much like StandIn [MODIFIED FOR POSTURES EXTENSION]

dobjFor(SitOn)

thing.t[6468], postures.t[220]

no description available

dobjFor(SitOn)

thing.t[6515]

no description available

dobjFor(SmellSomething)

thing.t[4061], senseRegion.t[990], sensory.t[663]

no description available

Modified in senseRegion.t[990]:
Modify the effect of SmellSomething to show the remoteSmellDesc if appropriate, or else our regular smellDesc if our smellSize is large, or else a message to say we’re too far away to smell. If we’re in the same room as the actor, simply carry out the regular (inherited) method.

Modified in sensory.t[663]:
[MODIFIED FOR SENSORY EXTENSION] If I have an associated Odor object which isn’t emanating, assume I no longer smell of anything, otherwise carry out the inherited handling.

dobjFor(StandIn)

thing.t[6601], postures.t[355]

By default we’ll treat standing, sitting or lying IN something as simply equivalent to entering it.

Modified in postures.t[355]:
[MODIFIED FOR POSTURES EXTENSION]

dobjFor(StandOn)

thing.t[6467], postures.t[182]

Since we don’t track postures in this library we’ll treat STAND ON as equivalent to BOARD

Modified in postures.t[182]:
Modification for StandOn handling [DEFINED IN POSTURES EXTENSION] If the actor is already on the dobj, we just try to change the actor’s posture to standing. Otherwise we first move the actor to the dobj and then change the actor’s posture to standing.

dobjFor(StandOn)

thing.t[6502]

no description available

dobjFor(Strike)

thing.t[4617]

no description available

dobjFor(SwitchOff)

thing.t[6187]

no description available

dobjFor(SwitchOn)

thing.t[6158]

no description available

dobjFor(SwitchVague)

thing.t[6214]

no description available

dobjFor(Take)

thing.t[4171]

no description available

dobjFor(TakeFrom)

thing.t[7186]

We treat TAKE FROM as equivalent to TAKE except at the verify stage, where we first check that the direct object is actually in the indirect object.

dobjFor(TakeFrom)

thing.t[7188]

no description available

dobjFor(TalkAbout)

thing.t[8928]

no description available

dobjFor(TalkTo)

thing.t[8941]

no description available

dobjFor(Taste)

thing.t[4104]

no description available

dobjFor(TellAbout)

thing.t[8888]

no description available

dobjFor(Throw)

thing.t[6399]

no description available

dobjFor(ThrowAt)

thing.t[7232]

no description available

dobjFor(ThrowDir)

thing.t[4650]

no description available

dobjFor(ThrowTo)

thing.t[7297]

no description available

dobjFor(Turn)

thing.t[4849]

no description available

dobjFor(TurnTo)

thing.t[7342]

Turning something To is setting it to a value by rotating it, such as turning a dial to point to a particular number.

dobjFor(TurnWith)

thing.t[4876]

no description available

dobjFor(TypeOn)

thing.t[8042]

no description available

dobjFor(TypeOnVague)

thing.t[8032]

The base handling of both the vague (TYPE ON X) and specific (TYPE FOO ON X) forms of TypeOn is simply to rule them out at the verify stage. Game code that needs objects that can be typed on is responsible for handling these actions in custom code.

dobjFor(Unfasten)

thing.t[7725]

no description available

dobjFor(UnfastenFrom)

thing.t[7741]

no description available

dobjFor(Unlock)

thing.t[5926]

no description available

dobjFor(UnlockWith)

thing.t[5766]

Note: we don’t use isLockable, because this is not a binary property; there are different kings of lockability and defining an isLockable property in addition would only confuse things and might break the logic.

dobjFor(Unplug)

thing.t[7873]

no description available

dobjFor(UnplugFrom)

thing.t[7826]

no description available

dobjFor(Unscrew)

thing.t[8310]

no description available

dobjFor(UnscrewWith)

thing.t[8320]

no description available

dobjFor(Wear)

thing.t[6295]

no description available

dobjFor(WriteOn)

thing.t[8087]

By default we simply rule out writing on things at the verify stage.

doPushTravel (via)

thing.t[8530]

Carry out the push travel on the direct object of the action.

examineStatus ( )

thing.t[1651]

Additional information to display after our desc in response to an EXAMINE command.

filterResolveList (np, cmd, mode)OVERRIDDEN

senseRegion.t[1067]

For certain actions like EXAMINE there’s no point trying to carry them out on something that can’t be seen (remotely) if there are other things that can be seen that matched the player’s command.

findHidden (prop, prep)

thing.t[5078]

If there’s something hidden in the dobj but nowhere obvious to move it to then by default we move everything from the hiddenIn list to the actor’s inventory and announce that the actor has taken it. We call this out as a separate method to make it easy to override if desired.

findPlausibleKey (silent, =, nil)

thing.t[6088]

Find a key among the actor’s possessions that might plausibly lock or unlock us. If the silent parameter is true, then don’t report a failed attempt.

firstContainerPathBlock (other, inProp, outProp)

thing.t[3047]

Get the first blockage in a container path. This calls containerPathBlock() and returns the first blockage in the list, or nil if there’s no blockage.

getBulkWithin ( )

thing.t[2070]

Calculate the total bulk of the items contained within this object.

getCarriedBulk ( )

thing.t[2083]

Calculate the total bulk carried by an actor, which excludes the bulk of any items currently worn or anything fixed in place.

getCarriedWeight ( )

weight.t[32]

The total weight of the items we’re carrying, excluding anything worn or anything fixed in place. [WEIGHT EXTENSION

getStatuslineExitsHeight ( )

thing.t[1603]

Get the estimated height, in lines of text, of the exits display’s contribution to the status line. This is used to calculate the extra height we need in the status line, if any, to display the exit list. If we’re not configured to display exits in the status line, this should return zero.

getWeightWithin ( )

weight.t[23]

The total weight of our contents, excluding our own weight. [WEIGHT EXTENSION]

handleCommand (action)

thing.t[3831]

Handle a command directed to this open (e.g. BALL, GET IN BOX). Since inanimate objects generally can’t respond to commands we simply display a message announcing the futility of issuing one. This method is overridden on Actor to allow Actors to respond to commands via CommandTopics.

hasSeen (obj)

thing.t[3661]

Test whether this Thing has seen obbj.

hideFromAll (action)

thing.t[3876]

To exclude this item from the list of objects to be acted upon when the player types a command with ALL for action, override this method to return true for the action or actions concerned. Note that this exclusion is applied after the action has constructed its own list of objects that ALL should apply to, and can only be used to make further exclusions.

It shouldn’t be necessary to use this method very often, since the normal approach will be to override the getAll() method on the appropriate action. It may be useful to use this method to handle exceptional cases, however.

interiorParent ( )

thing.t[2786]

no description available

iobjFor(AttachTo)

thing.t[7577]

no description available

iobjFor(AttackWith)

thing.t[4594]

no description available

iobjFor(BurnWith)

thing.t[6281]

no description available

iobjFor(CleanWith)

thing.t[7108]

no description available

iobjFor(CutWith)

thing.t[4948]

no description available

iobjFor(Default)

thing.t[3934]

no description available

iobjFor(DetachFrom)

thing.t[7631]

no description available

iobjFor(DigWith)

thing.t[7161]

no description available

iobjFor(FastenTo)

thing.t[7704]

no description available

iobjFor(GiveTo)

thing.t[8983]

no description available

iobjFor(LockWith)

thing.t[5905]

no description available

iobjFor(MoveTo)

thing.t[6835]

no description available

iobjFor(MoveWith)

thing.t[6768]

no description available

iobjFor(PlugInto)

thing.t[7805]

no description available

iobjFor(PourInto)

thing.t[8228]

no description available

iobjFor(PourOnto)

thing.t[8182]

no description available

iobjFor(PushTravelClimbDown)

thing.t[8825]

no description available

iobjFor(PushTravelClimbUp)

thing.t[8801]

no description available

iobjFor(PushTravelEnter)

thing.t[8725]

no description available

iobjFor(PushTravelGetOutOf)

thing.t[8767]

no description available

iobjFor(PushTravelThrough)

thing.t[8692]

no description available

iobjFor(PutBehind)

thing.t[5689], weight.t[201]

Handled by iobj

Modified in weight.t[201]:
Modifications to PutBehind handling to check for weight hidden behind this item. [WEIGHT EXTENSION]

iobjFor(PutIn)

thing.t[5505], weight.t[159]

handled on iobj

Modified in weight.t[159]:
Modifications to PutIn handling to check for weight hidden inside this item. [WEIGHT EXTENSION]

iobjFor(PutOn)

thing.t[5439]

no description available

iobjFor(PutUnder)

thing.t[5597], weight.t[180]

Handled by iobj

Modified in weight.t[180]:
Modifications to PutUnder handling to check for weight hidden under this item. [WEIGHT EXTENSION]

iobjFor(ScrewWith)

thing.t[8294]

no description available

iobjFor(ShowTo)

thing.t[9015]

no description available

iobjFor(TakeFrom)

thing.t[7202]

no description available

iobjFor(ThrowAt)

thing.t[7258], senseRegion.t[1039]

no description available

Modified in senseRegion.t[1039]:
Modify the effects of throwing something at this object

iobjFor(ThrowTo)

thing.t[7311]

no description available

iobjFor(TurnWith)

thing.t[4900]

no description available

iobjFor(UnfastenFrom)

thing.t[7756]

no description available

iobjFor(UnlockWith)

thing.t[5835]

no description available

iobjFor(UnplugFrom)

thing.t[7840]

no description available

iobjFor(UnscrewWith)

thing.t[8330]

no description available

isAudibleFrom (pov)

senseRegion.t[766]

Is this item audible from the remote location containing pov? By default it is if it’s soundSize is not small, but this can be overridden, for example to vary with the pov.

isChild (obj, typ)

thing.t[2584]

Are we a containment “child” of the given object with the given location type? This returns true if our location is the given object and our locType is the given type, or our location is a containment child of the given object with the given type.

‘typ’ is a LocType giving the relationship to test for, or nil. If it’s nil, we’ll return true if we have any containment relationship to ‘obj’.

isDirectChild (obj, typ)

thing.t[2603]

Are we a direct containment child of the given object with the given containment type? ‘typ’ is a LocType giving the relationship to test for, or nil. If it’s nil, we’ll return true if we have any direct containment relationship with ‘obj’.

isDirectlyHeldBy (obj)

thing.t[2311]

are we directly held by the given object?

isDirectlyIn (cont)

thing.t[2618]

Are we directly in cont?

isDirectlyWornBy (obj)

thing.t[2328]

are we directly worn by the given object?

isHeldBy (obj)

thing.t[3133]

are we held by the given object, directly or indirectly?

isIlluminated ( )

thing.t[1044], brightness.t[341]

If we’re a room, are we illuminated (is there enough light for an actor within us to see by)?

Modified in brightness.t[341]:
[BRIGHTNESS EXTENSION]

Change the definition of having sufficient light to see by to have an accumulated brightess within greater than our illumination threshold. We only do this if the light probe is off-stage, however, since otherwise we’ll cause a stack overflow via a circular reference while the brightnessWithin is being calculated; if the lightProbe_ is in use we accordingly fall back on the inherited handling. (This will need looking at since it prevents recogition of a light source in a remote location in the same SenseRegion).

isIn (cont)

thing.t[2633]

Are we in cont?

isInterior (obj)

thing.t[2804]

Am I on the inside of the given object? This returns true if our relationship to the given object is an interior location type.

isOrIsIn (cont)

thing.t[2648]

Are either oont or in cont ?

isOutside (obj)

thing.t[3125]

are we on the exterior of the given object, directly or indirectly?

isReadableFrom (pov)

senseRegion.t[782]

Assuming this item is readable at all, is it readable from the remote location containing pov? By default we assume this is the case if and only if the item’s sightSize is large, but this can be overridden, for example for a large item with small lettering.

isSmellableFrom (pov)

senseRegion.t[773]

Is this item smellable from the remote location containing pov? By default it is if it’s smellSize is not small, but this can be overridden, for example to vary with the pov.

isThereALightSourceIn (lst)

thing.t[1065]

Determine (recursively) whether lst contains a light source; i.e. whether any of the items within list is lit or whether any of the visible contents of any of the items in lst it lit.

isVisibleFrom (pov)

senseRegion.t[758]

Is this item visible from the remote location containing pov? By default it is if it’s sightSize is not small, but this can be overridden, for example to vary with the pov.

isWornBy (obj)

thing.t[2321]

are we worn by the given object, directly or indirectly?

knowsAbout (obj)

thing.t[3667]

Test whether this Thing knows about obj, which it does either if it has seen this obj or its knownProp (by default, familiar) is true.

listableContentsOf (cont)

thing.t[1983]

The subset of the contents of cont that should be listed.

listContents (lister, =, &, roomContentsLister)

thing.t[1170]

List the contents of this object using lister.

listenDesc ( )

sensory.t[617]

By default we split our listenDesc into listenDescWithoutSource (when the player character can’t hear us) and listenDescWithSource (when the pc can). If we don’t need this distinction we can override this method directly. [MODIFIED FOR SENSORY EXTENSION]

listRemoteContents (lst, lister, pov)

senseRegion.t[598]

List contents as seen from a remote location

listSubcontentsOf (contList, lister, =, &, examineLister)

thing.t[1351]

List the contents of every item in contList, recursively listing the contents of contents all the way down the containment tree. The contList parameter can also be passed as a singleton object.

litWithin ( )

thing.t[3566], brightness.t[353]

Is this object’s interior lit? an object if the object itself is a light source, or anything directly inside shines outwards, or we can see out from within and our location shines inwards.

Modified in brightness.t[353]:
For the purposes of the BRIGHTNESS EXTENSION, litWithin() should return the same result as isIlluminated.

locationWhich (func)

thing.t[3320]

no description available

locType ( )

thing.t[3082]

Our location type with respect to our immediate container; e.g. are we In, On, Under or Behind it?

lookAroundWithin ( )

thing.t[1110]

Look around within this Thing (Room or Booth) to provide a full description of this location as seen from within, including our headline name, our internal description, and a listing of our visible contents.

makeCleaned (stat)

thing.t[7050]

Carry out the effects of cleaning. By default we just set the value of the isClean property, but game code could override this to carry out any side effects of cleaning, such as revealing the inscription on a dirty old gravestone.

makeFastened (stat)

thing.t[7662]

Make something fastened or unfastened. By default we just change the value of its isFastened property, but game code could override this to provide further side-effects on particular objects.

makeLit (stat)

thing.t[2010], english.t[2148], signals.t[211]

Make this object lit or unlit

Modified in english.t[2148]:
Check whether we need to add or remove the LitUnlit State from our list of states.

Modified in signals.t[211]:
emit a litSignal or unlitSignal when this object is lit or unlit. [SIGNALS EXTENSION]

makeLocked (stat)

thing.t[2279], signals.t[231]

Make us locked or ublocked. We define this as a method so that subclasses such as Door can override to produce side effects (such as locking or unlocking the other side).

Modified in signals.t[231]:
emit a lockSignal or unlockSignal when this object is locked or unlocked. [SIGNALS EXTENSION]

makeMovedTo (loc)

thing.t[6830]

Cause this object to be moved to loc

makeOn (stat)

thing.t[2293], signals.t[241]

switch this item on or off

Modified in signals.t[241]:
emit an onSignal or offSignal when this object is turned on or off [SIGNALS EXTENSION]

makeOpen (stat)

thing.t[4703], signals.t[297]

Make us open or closed. We define this as a method so that subclasses such as Door can override to produce side effects (such as opening or closing the other side).

Modified in signals.t[297]:
emit an openSignal or closeSignal when this object is open or closed. [SIGNALS EXTENSION]

makeSetting (val)

thing.t[7413]

This would be a good place to put code to validate the setting

makeWorn (stat)

thing.t[2308], signals.t[251]

Make this object worn or not worn. If this object is worn, note who it’s worn by. If stat is nil the object is no longer being worn.

Modified in signals.t[251]:
emit a wornSignal or doffSignal when this object is worn or doffed (taken off). [SIGNALS EXTENSION]

moveHidden (prop, loc)

thing.t[4374]

Service method: move everything in the prop property to loc and mark it as seen.

moveInto (newCont)

thing.t[2451], signals.t[264]

Basic moveInto for moving an object from one container to another by programmatic fiat.

Modified in signals.t[264]:
emit a moveSignal when this object is moved. [SIGNALS EXTENSION]

moveMLIntoAdd (ml)

thing.t[2538]

Move a MultiLoc (ml) into this additional Thing or Room, by adding it to this thing’s contents list and adding the Thing to ml’s locationList.

moveMLOutOf (ml)

thing.t[2552]

Move a MultiLoc (ml) out of this object, by removing it from our contents list and removing us from its locationList.

nestedLoc (actor)

postures.t[516]

MODIFIED FOR POSTURES EXTENSION to include the actor’s posture

nominalOwner ( )

thing.t[3231]

Get my nominal owner. If we have an explicit owner, we’ll return the first explicit owner. Otherwise, we’ll look for a container that has ownsContents = true, and return the first such container.

noteSeen ( )

thing.t[3625], signals.t[286]

Note that we’ve been seen and where we were last seen

Modified in signals.t[286]:
emit a seenSignal or unlitSignal when this object is seen. [SIGNALS EXTENSION]

notifyEvent (event, source)

sensory.t[583]

Our common handler for SensoryEvents; it may often be more convenient to use this than to write separate handlers for each kind of SensoryEvent, since in any case the event parameter (containing the SensoryEvent that’s just been triggered) tells us what kind of SensoryEvent it is. The source parameter is the object associated with the event. [DEFINED IN SENSORY EXTENSION]

notifyInsert (obj)

thing.t[2530]

Receive notification that obj is about to be inserted into us; by default we do nothing.

notifyRemove (obj)

thing.t[2510]

Receive notification that obj is about to be removed from inside us; by default we do nothing. Do NOT use this method to prevent the removal of the object from us; use checkRemove(obj) instead.

notifySightEvent (event, source)

sensory.t[573]

Our reaction to a SightEvent. By default we defer to the common handler.

notifySmellEvent (event, source)

sensory.t[570]

Our reaction to a SmellEvent. By default we defer to the common handler.

notifySoundEvent (event, source)

sensory.t[567]

The methods that define our reactions to SoundEvents, SmellEvents and SightEvents respectively. By default all three methods defer to a common handler. [DEFINED IN SENSORY EXTENSION]

notionalContents ( )

thing.t[2163]

Our notional total contents is our normal contents plus anything contained in any of our remapXX objects representing our associated proxy container, surface, underside and rear, excluding anything in a closed opaque container (which would not be visible).

outermostParent ( )

thing.t[3119]

Get my outermost parent. This is simply our ancestor in the location tree that has no location itself.

outermostVisibleParent ( )

thing.t[3054]

no description available

ownedBy (obj)

thing.t[3255]

Does the given object own me, explicitly or implicitly? This returns true if ‘obj’ is in my ‘owner’ list, but it can also return true if there’s merely an implied ownership relationship. Location can imply ownership: BOB’S KEY could refer to the key that Bob is holding, whether or not it would continue to be considered his key if he were to drop it.

We return true if ‘obj’ is an explicit owner, OR self is contained within ‘obj’, OR self is contained within an object owned by ‘obj’. (The latter case is for things like BOB’S TWENTY DOLLAR BILL, which is Bob’s by virtue of being inside a wallet explicitly owned by Bob.)

preinitThing ( )

thing.t[2678]

Carry out the preinitialization of a Thing

pushTravelRevealItems ( )

thing.t[8481]

no description available

reachBlockedMsg (target)

thing.t[3498]

Return a message explaining why an object outside me can’t reach one inside (or vice versa); this will normally be triggered by an attempt to reach an object inside a closed transparent container. The method is defined here to make it easier to customize the message on the container that’s doing the blocking.

remoteBrightness (pov)

brightness.t[102]

[BRIGHTNESS EXTENSION]

Our remote brightness when viewed from pov, where pov is in a remote location. By default we just return our brightness, but game code may wish to override when, for example, we’re a torch/flashlight that’s been dropped on the far side of a field at night.

remoteInitSpecialDesc (pov)

senseRegion.t[751]

Our remoteInitSpecialDesc, used when viewing this item from a remote location.By default we just show our ordinary initSpecialDesc, but in practice we’ll normally want to override this.

remoteObjInName (pov)

senseRegion.t[853]

The name given to this object when it’s the container for another object viewed remotely, e.g. ‘in the distant bucket’ as opposed to just ‘in the bucket’. By default we just use the objInName.

remoteSpecialDesc (pov)

senseRegion.t[744]

Our remoteSpecialDesc is the paragraph describing this item in a room description when viewed from a remote location containing the pov object. By default we just show our ordinary specialDesc, but in practice we’ll normally want to override this.

removeFromContents (obj, vec?)

thing.t[2437]

Remove an item to this object’s contents. Normally this method is used internally in the library than directly by game code. If the vec parameter is supplied, the object removed from our contents is also removed from vec; again this is intended primarily for internal use by the library.

revealOnMove ( )

thing.t[4267]

List and move into an appropriate location any item that was hidden behind or under us. We place this in a separate method so it can be conveniently called by other actions that move an object, or overridden by particular objects that want a different handling.

Note that we don’t provide any handling for the hiddenIn property here, on the assumption that items hidden in something may well stay there when it’s moved; but this method can always be overridden to provide custom behaviour.

roomHeadline (pov)

thing.t[992]

The title of this room to be displayed at the start of a room description, or in the status line.

// roomSubhead (pov)Interface description only

thing.t[3157], english.t[2133], postures.t[510]

The nested room subhead. This shows a little addendum to the room headline when the point-of-view actor is inside an object within the main room, such as a chair or platform. This usually shows something of the form “(in the chair)”. Note that only the *immediate* container is shown; if the actor is in a chair in a booth on a stage, we normally only mention the chair.

We leave this to the language library to define, since the exact syntax varies by language.

Modified in english.t[2133]:
Show the nested room subhead. This shows the actor’s immediate container as an addendum to the room name in the room description headline.

[Required]

Modified in postures.t[510]:
Include the actor’s posture in the subheading (e.g. ‘(sitting on the chair)’) [MODIFIED FOR POSTURES EXTENSION]

sayCantBearMoreWeight (obj)

weight.t[86]

Display a message saying that we can’t bear any more weight. [WEIGHT EXTENSION]

sayDontKnowHowToGetThere ( )

thing.t[7534]

We make these two sayDontKnowHowTo… methods separate methods so that they can be reused on the Distant class without having to repeat the DMsg() definitions.

sayDontKnowHowToReach ( )

thing.t[7537]

no description available

sayFindHidden (prop, prep)

thing.t[5092]

Report what was found hidded in/under/behind us. We make this a separate method so that it can be easily customized on individual objects.

sayPushTravel (dir)

thing.t[8473]

Display a message saying we pushed the direct object in a particular direction.

sayTooHeavy (obj)

weight.t[76]

Display a message saying that obj is too heavy to be inserted in us. [WEIGHT EXTENSION]

sayTooHeavyToHide (obj, insType)

weight.t[222]

Display a message to say that obj is too heavy to fit in/on/under us, where insType is In, On or Under. [WEIGHT EXTENSION]

scoreObject (cmd, role, lst, m)

thing.t[3752]

Score this object for disambiguation. When a noun phrase is ambiguous (for example, the phrase matches multiple in-scope objects, and we have to choose just one), the parser calls this routine on each object it’s considering as a match.

Our job here is to read the player’s mind. The question before us is: did the player mean *this* object when typing this noun phrase? Obviously we can’t really know what’s in the player’s mind, but in many cases we can make an educated guess based on what ought to make the most sense in context. The context in this case is the state of the simulated game world, as it’s portrayed to the player. That last bit is important: be cognizant of what the player is *meant* to know at this point. DON’T base the score on information that the player isn’t supposed to know, though: that could give away secrets that the player is meant to discover on her own.

Before this routine is called, the Action has already assigned an initial score to each object, but this routine can override the initial score by assigning its own score value. This routine is most useful in cases where a particular object has a special affinity for a verb, or for the verb in combination with particular other objects involved in the command.

‘cmd’ is the Command object. ‘role’ is the noun phrase’s role in the command (DirectObject, IndirectObject, etc). ‘lst’ is a list of NPMatch objects identifying the objects that matched the noun phrase. ‘m’ is the NPMatch object for self.

To override or adjust the score, simply set m.score to the new value. This routine is also free to override the scores of any other objects in the list, if needed.

By default, we don’t make any adjustment - we simply accept the initial score calculated by the Action, by leaving m.score unchanged.

See Action.scoreObjects() for full details.

setHasSeen (obj)

thing.t[3655]

Mark this Thing as having seen obj.

setKnown ( )

thing.t[3652]

Mark the player character as knowing about us (i.e. this Thing)

setKnowsAbout (obj)

thing.t[3649]

Mark this Thing as knowing about obj.

setSeen ( )

thing.t[3658]

Mark the player character as having seen this Thing.

shinesOut ( )

thing.t[3539]

Does this object shine light outwards? This determines if the object is a light source to objects outside of it. Light shines out from an object if the object itself is a light source, or one of its direct exterior contents shines out, or its contents are visible from the outside and one of its direct interior contents shines out.

showConnectedMiscContents (pov)

thing.t[1566]

no description available

showFirstConnectedSpecials (pov)

thing.t[1565]

no description available

showRemoteSpecialDesc (pov)

senseRegion.t[566]

Show our remoteSpecialDesc, i.e. the version of our specialDesc that should be seen when this item is viewed from a remote location.

showSecondConnectedSpecials (pov)

thing.t[1567]

no description available

showSpecialDesc ( )

thing.t[1840]

Show our specialDesc or initSpecialDesc, as appropriate

showStatuslineExits ( )

thing.t[1612]

Show our exits in the status line

smellDesc ( )

sensory.t[591]

By default we split our smellDesc into smellDescWithoutSource (when the player character can’t see us) and smellDescWithSource (when the pc can). If we don’t need this distinction we can override this method directly. [MODIFIED FOR SENSORY EXTENSION]

statusName (actor)

thing.t[1581]

Display the “status line” name of the room. This is normally a brief, single-line description.

By long-standing convention, each location in a game usually has a distinctive name that’s displayed here. Players usually find these names helpful in forming a mental map of the game.

By default, if we have an enclosing location, and the actor can see the enclosing location, we’ll defer to the location. Otherwise, we’ll display our roo interior name.

totalBulkIn (lst)

thing.t[2229]

Calculate the total bulk of the items in lst

totalWeightIn (lst)

weight.t[146]

Calculate the total weight of the items in lst [WEIGHT EXTENSION]

traceContainerPath (other, outFunc, parentFunc, inFunc)

thing.t[2982]

Trace the interior containment path from ‘self’ to ‘other’.

We’ll start by working up the containment tree from ‘self’ to the nearest interior container we have in common with ‘other’ - that is, the nearest object that contains both ‘self’ and ‘other’ with an interior location type for each object. For each container BELOW the common parent, we call outFunc(container).

Next, we call parentFunc(container) on the common container. If there is no common container, we call parentFunc(nil).

Next, we work back down the containment tree from the common parent to ‘other’. For each container below the common parent, we call inFunc(container).

travelVia (conn, announceArrival, =, true)

thing.t[3809]

Cause this Thing to travel via the connector conn. This method is supplied in case travelVia is called on a Thing which is not an Actor, although it’s Actor that has the full implementation.

tryCheck (prop)

thing.t[3302]

Run a check method passed as a property pointer in the prop parameter and return any string it tried to display

tryMakingPosture (pos)

postures.t[140]

Attempt to make this Thing adopt the posture pos (without changing location). [DEFINED IN POSTURES EXTENSION]

unmention (lst)

thing.t[1547]

Mark everything item in lst as not mentioned , and carry on down the containment tree marking the contents of every item in lst as not mentioned.

unmentionRemoteContents ( )

thing.t[1564]

The next four methods are provided so that listContents() can call them, but they do nothing in the core library. They are overridden in senseRegion.t (for use if senseRegion.t is included in the build).

verifyActor ( )

thing.t[3950]

Next deal with what happens if this object is being tested as a potential actor

verifyEnterPosture (pos)

postures.t[329]

Common verify routine for standing, sitting or lying IN something, where pos is the posture to be adopted. [DEFINED IN POSTURES EXTENSION]

verifyPushTravel (via)

thing.t[8361]

Common handler for verifying push travel actions. The via parameter may be a preposition object (such as Through) defining what kind of push traveling the actor is trying to do (e.g. through a door or up some stairs).

wouldBeLitFor (actor)

thing.t[1621]

Would this location be lit for actor. By default it would if it’s illuminated.

Adv3Lite Library Reference Manual
Generated on 15/03/2023 from adv3Lite version 1.6.1