Class SerialTurnout

All Implemented Interfaces:
PropertyChangeListener, Comparable<NamedBean>, EventListener, PropertyChangeProvider, DigitalIO, NamedBean, Turnout

public class SerialTurnout
extends AbstractTurnout
Extend jmri.AbstractTurnout for SECSI serial layouts. This object doesn't listen to the SECSI serial communications. This is because it should be the only object that is sending messages for this turnout; more than one Turnout object pointing to a single device is not allowed.
  • Field Details

  • Constructor Details

    • SerialTurnout

      public SerialTurnout​(String systemName, String userName, SecsiSystemConnectionMemo _memo)
      Create a Turnout object, with both system and user names.

      'systemName' was previously validated in SerialTurnoutManager.

      systemName - turnout system name
      userName - turnout user name
      _memo - system connection
  • Method Details

    • forwardCommandChangeToLayout

      protected void forwardCommandChangeToLayout​(int newState)
      Handle a request to change state, typically by sending a message to the layout in some child class. Public version (used by TurnoutOperator) sends the current commanded state without changing it. Implementing classes will typically check the value of s and send a system specific sendMessage command. Sends a Secsi command
      Specified by:
      forwardCommandChangeToLayout in class AbstractTurnout
      newState - new state value
    • turnoutPushbuttonLockout

      protected void turnoutPushbuttonLockout​(boolean _pushButtonLockout)
      Specified by:
      turnoutPushbuttonLockout in class AbstractTurnout
    • dispose

      public void dispose()
      Description copied from class: AbstractTurnout
      Deactivate this object, so that it releases as many resources as possible and no longer effects others.

      For example, if this object has listeners, after a call to this method it should no longer notify those listeners. Any native or system-wide resources it maintains should be released, including threads, files, etc.

      It is an error to invoke any other methods on this object once dispose() has been called. Note, however, that there is no guarantee about behavior in that case.

      Afterwards, references to this object may still exist elsewhere, preventing its garbage collection. But it's formally dead, and shouldn't be keeping any other objects alive. Therefore, this method should null out any references to other objects that this NamedBean contained.

      Specified by:
      dispose in interface NamedBean
      dispose in class AbstractTurnout
    • sendMessage

      protected void sendMessage​(boolean closed)