Package jmri.jmrix.lenz.xnetsimulator
Class XNetSimulatorAdapter
- java.lang.Object
- 
- jmri.jmrix.AbstractPortController
- 
- jmri.jmrix.AbstractSerialPortController
- 
- jmri.jmrix.lenz.XNetSimulatorPortController
- 
- jmri.jmrix.lenz.xnetsimulator.XNetSimulatorAdapter
 
 
 
 
- 
- All Implemented Interfaces:
- java.lang.Runnable,- XNetPortController,- PortAdapter,- SerialPortAdapter
 
 public class XNetSimulatorAdapter extends XNetSimulatorPortController implements java.lang.Runnable Provide access to a simulated XpressNet system.Currently, the XNetSimulator reacts to commands sent from the user interface with messages an appropriate reply message. NOTE: Most XpressNet commands are still unsupported in this implementation. Normally controlled by the lenz.XNetSimulator.XNetSimulatorFrame class. NOTE: Some material in this file was modified from other portions of the support infrastructure. 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class jmri.jmrix.AbstractSerialPortControllerAbstractSerialPortController.Blocking, AbstractSerialPortController.FlowControl
 - 
Nested classes/interfaces inherited from class jmri.jmrix.AbstractPortControllerAbstractPortController.Option
 
- 
 - 
Field Summary- 
Fields inherited from class jmri.jmrix.AbstractSerialPortControllercurrentSerialPort, mBaudRate, mPort
 - 
Fields inherited from class jmri.jmrix.AbstractPortControllerallowConnectionRecovery, manufacturerName, opened, option1Name, option2Name, option3Name, option4Name, options, reconnectinterval, reconnectMaxAttempts, reconnectMaxInterval
 
- 
 - 
Constructor SummaryConstructors Constructor Description XNetSimulatorAdapter()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected XNetReplyaccInfoReply(int dccTurnoutAddress)Creates a reply for the specific turnout dcc address.protected XNetReplyaccInfoReply(int baseAddress, boolean nibble)Creates a reply packet for a turnout/accessory.protected XNetReplyaccInfoReply(XNetMessage m)protected XNetReplyaccReqReply(XNetMessage m)voidconfigure()Set up all of the other objects to operate with an XNetSimulator connected to this port.protected voidconfigure(XNetTrafficController packets)protected XNetReplyfeedbackInfoReply(XNetMessage m)protected XNetReplygenerateAccRequestReply(int address, int output, boolean state, boolean previousAccessoryState)Generate reply to accessory request command.protected intgetAccessoryStateBits(int a)Returns accessory state, in the Operation Info Reply bit format.java.io.DataInputStreamgetInputStream()Get the InputStream from the port.java.io.DataOutputStreamgetOutputStream()Get the outputStream to the port.protected intgetTurnoutFeedbackType()Return the turnout feedback type.protected XNetMessageloadChars()Get characters from the input source, and file a message.booleanokToSend()Can the port accept additional characters?java.lang.StringopenPort(java.lang.String portName, java.lang.String appName)Open a specified port.protected bytereadByteProtected(java.io.DataInputStream istream)Read a single byte, protecting against various timeouts, etc.voidrun()voidsetOutputBufferEmpty(boolean s)Tell if the output buffer is empty or full.booleanstatus()Check that this object is ready to operate.- 
Methods inherited from class jmri.jmrix.lenz.XNetSimulatorPortControllergetSystemConnectionMemo, hasTimeSlot, setTimeSlot, validBaudNumbers, validBaudRates
 - 
Methods inherited from class jmri.jmrix.AbstractSerialPortControlleractivatePort, activatePort, activatePort, closeConnection, closeSerialPort, configureBaudRate, configureBaudRateFromIndex, configureBaudRateFromNumber, configureLeads, configureLeadsAndFlowControl, configureLeadsAndFlowControl, connect, currentBaudNumber, defaultBaudIndex, getActualPortNames, getCurrentBaudIndex, getCurrentBaudNumber, getCurrentBaudRate, getCurrentPortName, getFlowControl, getPortSettingsString, handlePortBusy, handlePortNotFound, handlePortNotFound, isPortOpen, replacePortWithFakePort, reportPortStatus, resetupConnection, setBaudRate, setComPortTimeouts, setDataListener, setFlowControl, setPort
 - 
Methods inherited from class jmri.jmrix.AbstractPortControllerconfigureOption1, configureOption2, configureOption3, configureOption4, dispose, getDisabled, getManufacturer, getOption1Name, getOption2Name, getOption3Name, getOption4Name, getOptionChoices, getOptionDisplayName, getOptions, getOptionState, getReconnectMaxAttempts, getReconnectMaxInterval, getSystemPrefix, getUserName, isDirty, isOptionAdvanced, isOptionTypePassword, isOptionTypeText, isRestartRequired, purgeStream, reconnect, reconnectFromLoop, recover, safeSleep, setClosed, setDisabled, setManufacturer, setOpened, setOptionState, setReconnectMaxAttempts, setReconnectMaxInterval, setSystemConnectionMemo, setSystemPrefix, setUserName
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface jmri.jmrix.PortAdapterconnect, dispose, getDisabled, getOption1Name, getOption2Name, getOption3Name, getOption4Name, getOptionChoices, getOptionDisplayName, getOptions, getOptionState, getReconnectMaxAttempts, getReconnectMaxInterval, getSystemPrefix, getUserName, isDirty, isOptionAdvanced, isOptionTypePassword, isOptionTypeText, isRestartRequired, recover, setDisabled, setOptionState, setReconnectMaxAttempts, setReconnectMaxInterval, setSystemConnectionMemo, setSystemPrefix, setUserName
 - 
Methods inherited from interface jmri.jmrix.SerialPortAdapterconfigureOption1, configureOption2, configureOption3, configureOption4, getManufacturer, getPortNames, setManufacturer
 
- 
 
- 
- 
- 
Constructor Detail- 
XNetSimulatorAdapterpublic XNetSimulatorAdapter() 
 
- 
 - 
Method Detail- 
openPortpublic java.lang.String openPort(java.lang.String portName, java.lang.String appName) Description copied from interface:SerialPortAdapterOpen a specified port.- Specified by:
- openPortin interface- SerialPortAdapter
- Parameters:
- portName- name tu use for this port
- appName- provided to the underlying OS during startup so that it can show on status displays, etc.
- Returns:
- null indicates OK return, else error message.
 
 - 
setOutputBufferEmptypublic void setOutputBufferEmpty(boolean s) Tell if the output buffer is empty or full. This should only be set to false by external processes.- Specified by:
- setOutputBufferEmptyin interface- XNetPortController
- Specified by:
- setOutputBufferEmptyin class- XNetSimulatorPortController
- Parameters:
- s- true if the buffer is empty; false otherwise
 
 - 
okToSendpublic boolean okToSend() Can the port accept additional characters? The state of CTS determines this, as there seems to be no way to check the number of queued bytes and buffer length. This might go false for short intervals, but it might also stick off if something goes wrong.- Specified by:
- okToSendin interface- XNetPortController
- Overrides:
- okToSendin class- XNetSimulatorPortController
- Returns:
- true if OK to send, else false.
 
 - 
configurepublic void configure() Set up all of the other objects to operate with an XNetSimulator connected to this port.- Specified by:
- configurein interface- PortAdapter
- Specified by:
- configurein interface- SerialPortAdapter
 
 - 
configureprotected void configure(XNetTrafficController packets) 
 - 
getInputStreampublic java.io.DataInputStream getInputStream() Description copied from class:AbstractPortControllerGet the InputStream from the port.- Specified by:
- getInputStreamin interface- PortAdapter
- Specified by:
- getInputStreamin class- XNetSimulatorPortController
- Returns:
- the InputStream from the port
 
 - 
getOutputStreampublic java.io.DataOutputStream getOutputStream() Description copied from class:AbstractPortControllerGet the outputStream to the port.- Specified by:
- getOutputStreamin interface- PortAdapter
- Specified by:
- getOutputStreamin class- XNetSimulatorPortController
- Returns:
- the outputStream to the port
 
 - 
statuspublic boolean status() Description copied from class:XNetSimulatorPortControllerCheck that this object is ready to operate. This is a question of configuration, not transient hardware status.- Specified by:
- statusin interface- PortAdapter
- Specified by:
- statusin interface- SerialPortAdapter
- Specified by:
- statusin interface- XNetPortController
- Specified by:
- statusin class- XNetSimulatorPortController
- Returns:
- true if OK, at least as far as known
 
 - 
runpublic void run() - Specified by:
- runin interface- java.lang.Runnable
 
 - 
getTurnoutFeedbackTypeprotected int getTurnoutFeedbackType() Return the turnout feedback type.- 0x00 - turnout without feedback, ie DR5000
- 0x01 - turnout with feedback, ie NanoX
- 0x10 - feedback module
 - Returns:
- the turnout type reported by this station.
 
 - 
getAccessoryStateBitsprotected int getAccessoryStateBits(int a) Returns accessory state, in the Operation Info Reply bit format. If the accessory has not been operated yet, returns 00 (not operated).- Parameters:
- a- accessory number
- Returns:
- two bits representing the accessory state.
 
 - 
accInfoReplyprotected XNetReply accInfoReply(XNetMessage m) 
 - 
feedbackInfoReplyprotected XNetReply feedbackInfoReply(XNetMessage m) 
 - 
accInfoReplyprotected XNetReply accInfoReply(int baseAddress, boolean nibble) Creates a reply packet for a turnout/accessory.- Parameters:
- baseAddress- base address for the feedback, the 4-turnout block; numbered from 0
- nibble- lower or upper nibble (2 turnout block) delivered in the reply
- Returns:
- constructed reply.
 
 - 
generateAccRequestReplyprotected XNetReply generateAccRequestReply(int address, int output, boolean state, boolean previousAccessoryState) Generate reply to accessory request command. The returned XNetReply is the first to be returned by this simulated command station.- Parameters:
- address- the accessory address
- output- the output to be manipulated
- state- true if output should be on, false for off
- previousAccessoryState- the previous accessory state
- Returns:
- the reply instance.
 
 - 
accInfoReplyprotected XNetReply accInfoReply(int dccTurnoutAddress) Creates a reply for the specific turnout dcc address.- Parameters:
- dccTurnoutAddress- the turnout address
- Returns:
- a reply packet
 
 - 
accReqReplyprotected XNetReply accReqReply(XNetMessage m) 
 - 
loadCharsprotected XNetMessage loadChars() throws java.io.IOException Get characters from the input source, and file a message.Returns only when the message is complete. Only used in the Receive thread. - Returns:
- filled message
- Throws:
- java.io.IOException- when presented by the input source.
 
 - 
readByteProtectedprotected byte readByteProtected(java.io.DataInputStream istream) throws java.io.IOException Read a single byte, protecting against various timeouts, etc.When a port is set to have a receive timeout (via the enableReceiveTimeout() method), some will return zero bytes or an EOFException at the end of the timeout. In that case, the read should be repeated to get the next real character. - Parameters:
- istream- the input data source
- Returns:
- the next byte, waiting for it to become available
- Throws:
- java.io.IOException- from the underlying operations
 
 
- 
 
-