Random-Firing script add-in.  This is a mix-in class that you can add   to the superclass list of any Script subclass to make the script   execute only a given percentage of the time it's invoked.  Each time   doScript() is invoked on the script, we'll look at the probability   settings (see the properties below) to determine whether we really   want to execute the script this time; if so, we'll proceed with the   scripted event, otherwise we'll just return immediately, doing   nothing. 
   Note that this must be used in the superclass list *before* the Script   subclass: 
   myScript: RandomFiringScript, EventList 
   // ...my definitions... 
 ; 
   This class is especially useful for random atmospheric events, because   it allows you to make the timing of scripted events random.  Rather   than making a scripted event happen on every single turn, you can use   this to make events happen only sporadically.  It can often feel too   predictable and repetitious when a random background event happens on   every single turn; firing events less frequently often makes them feel   more realistic. 
class 
RandomFiringScript :    object
Superclass Tree   (in declaration order)
RandomFiringScript
         object
Subclass Tree   
RandomFiringScript
         RandomEventList
         ShuffledEventList
Global Objects   
(none)
Summary of Properties   
eventPercent  
eventReduceAfter  
eventReduceTo  
Summary of Methods   
checkEventOdds  
doScript  
Properties   
   Percentage of the time an event occurs.  By default, we execute an   event 100% of the time - meaning every time that doScript() is   invoked.  If you set this to a lower percentage, then each time   doScript() is invoked, we'll randomly decide whether or not to   execute an event based on this percentage.  For example, if you   want an event to execute on average about a third of the time, set   this to 33. 
   Note that this is a probabilistic frequency.  Setting this to 33   does *not* mean that we'll execute exactly every third time.   Rather, it means that we'll randomly execute or not on each   invocation, and averaged over a large number of invocations, we'll   execute about a third of the time. 
   Random atmospheric events can get repetitive after a while, so we   provide an easy way to reduce the frequency of our events after a   while.  This way, we'll generate the events more frequently at   first, but once the player has seen them enough to get the idea,   we'll cut back.  Sometimes, the player will spend a lot of time in   one place trying to solve a puzzle, so the same set of random   events can get stale.  Set eventReduceAfter to the number of times   you want the events to be generated at full frequency; after we've   fired events that many times, we'll change eventPercent to   eventReduceTo.  If eventReduceAfter is nil, we won't ever change   eventPercent. 
Methods   
   Check the event odds to see if we want to fire an event at all on   this invocation. 
   When doScript() is invoked, check the event probabilities before   proceeding. 
TADS 3 Library Manual
Generated on 8/21/2012 from TADS version 3.1.2