Package ptolemy.domains.tdl.kernel
Class TDLReceiver
- java.lang.Object
- 
- ptolemy.actor.AbstractReceiver
- 
- ptolemy.domains.tdl.kernel.TDLReceiver
 
 
- 
- All Implemented Interfaces:
- Receiver,- StateReceiver
 
 public class TDLReceiver extends AbstractReceiver implements StateReceiver A TDL receiver stores a token until it gets a new token. A call to hasToken of a TDL receiver will always succeed. The TDL receiver is based on the Giotto receiver.- Since:
- Ptolemy II 8.0
- Version:
- $Id$
- Author:
- Patricia Derler
 
- 
- 
Constructor SummaryConstructors Constructor Description TDLReceiver()Construct an empty TDLReceiver with no container.TDLReceiver(IOPort container)Construct an empty TDLReceiver with the specified container.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclear()Clear this receiver of any contained tokens.voidcopyTokensTo(TDLReceiver newReceiver)Copy tokens to another receiver.java.util.List<Token>elementList()Return a list with the token currently in the receiver, or an empty list if there is no such token.Tokenget()Get the contained and available token, i.e., get the last token that has been put into the receiver before the last update.TokengetTok()access method for the token, for testing purposes.booleanhasRoom()Return true, since writing to this receiver is always allowed.booleanhasRoom(int numberOfTokens)Return true, since writing to this receiver is always allowed.booleanhasToken()Return true if there is a token available.booleanhasToken(int numberOfTokens)Return true if the receiver has at least one token available.voidinit(Token token)Set the initial value of the receiver.voidput(Token token)Put a token into this receiver.Tokenremove()Get the contained and available token, i.e., get the last token that has been put into the receiver before the last update and reset the _token only.voidreset()Reset the receiver by removing all tokens from the receiver.voidupdate()Update the receiver by making the last token that has been passed to put() available to get().- 
Methods inherited from class ptolemy.actor.AbstractReceivergetArray, getContainer, getCurrentTime, getModelTime, isKnown, putArray, putArrayToAll, putToAll, setContainer, toString
 
- 
 
- 
- 
- 
Constructor Detail- 
TDLReceiverpublic TDLReceiver() Construct an empty TDLReceiver with no container.
 - 
TDLReceiverpublic TDLReceiver(IOPort container) throws IllegalActionException Construct an empty TDLReceiver with the specified container.- Parameters:
- container- The container.
- Throws:
- IllegalActionException- If the container does not accept this receiver.
 
 
- 
 - 
Method Detail- 
clearpublic void clear() Clear this receiver of any contained tokens. FIXME. Should rename and replace all the reset() with clear().- Specified by:
- clearin interface- Receiver
- Overrides:
- clearin class- AbstractReceiver
 
 - 
elementListpublic java.util.List<Token> elementList() Return a list with the token currently in the receiver, or an empty list if there is no such token.- Specified by:
- elementListin interface- Receiver
- Overrides:
- elementListin class- AbstractReceiver
- Returns:
- A list of instances of Token.
 
 - 
getpublic Token get() throws NoTokenException Get the contained and available token, i.e., get the last token that has been put into the receiver before the last update.- Specified by:
- getin interface- Receiver
- Specified by:
- getin class- AbstractReceiver
- Returns:
- A token.
- Throws:
- NoTokenException- If no token is available.
 
 - 
hasRoompublic boolean hasRoom() Return true, since writing to this receiver is always allowed.- Specified by:
- hasRoomin interface- Receiver
- Specified by:
- hasRoomin class- AbstractReceiver
- Returns:
- True.
 
 - 
hasRoompublic final boolean hasRoom(int numberOfTokens) Return true, since writing to this receiver is always allowed.- Specified by:
- hasRoomin interface- Receiver
- Specified by:
- hasRoomin class- AbstractReceiver
- Parameters:
- numberOfTokens- The size of tokens to be written to the receiver.
- Returns:
- True.
 
 - 
hasTokenpublic boolean hasToken() Return true if there is a token available. A token is available whenever put() has been called at least once followed by a call to the update() method.- Specified by:
- hasTokenin interface- Receiver
- Specified by:
- hasTokenin class- AbstractReceiver
- Returns:
- True if there is a token available.
 
 - 
hasTokenpublic final boolean hasToken(int numberOfTokens) Return true if the receiver has at least one token available. Any number of calls to get() is allowed and will return the same available token.- Specified by:
- hasTokenin interface- Receiver
- Specified by:
- hasTokenin class- AbstractReceiver
- Parameters:
- numberOfTokens- The number of tokens available in this receiver.
- Returns:
- True if there is a token available.
 
 - 
putpublic void put(Token token) throws NoRoomException Put a token into this receiver. Any token which has been put into the receiver before without calling update will be lost. The token becomes available to the get() method only after update() is called.Note that putting a null into this receiver will leave the receiver empty after update. The receiver does not check against this but expects that IOPort will always put non-null tokens into receivers. - Specified by:
- putin interface- Receiver
- Specified by:
- putin class- AbstractReceiver
- Parameters:
- token- The token to be put into this receiver.
- Throws:
- NoRoomException- Not thrown in this base class.
 
 - 
removepublic Token remove() throws NoTokenException Get the contained and available token, i.e., get the last token that has been put into the receiver before the last update and reset the _token only.- Returns:
- A token.
- Throws:
- NoTokenException- If no token is available.
 
 - 
resetpublic void reset() Reset the receiver by removing all tokens from the receiver.- Specified by:
- resetin interface- Receiver
- Overrides:
- resetin class- AbstractReceiver
 
 - 
updatepublic void update() Update the receiver by making the last token that has been passed to put() available to get().
 - 
initpublic void init(Token token) Set the initial value of the receiver.- Parameters:
- token- The initial token.
 
 - 
getTokpublic Token getTok() access method for the token, for testing purposes. TODO remove.- Returns:
- The token.
 
 - 
copyTokensTopublic void copyTokensTo(TDLReceiver newReceiver) Copy tokens to another receiver. This is used in a mode switch if the same task exists in the target mode.- Parameters:
- newReceiver- Receiver that gets the copied tokens.
 
 
- 
 
-