Class SerialLightManager
- java.lang.Object
- 
- jmri.beans.PropertyChangeSupport
- 
- jmri.beans.VetoableChangeSupport
- 
- jmri.managers.AbstractManager<Light>
- 
- jmri.managers.AbstractLightManager
- 
- jmri.jmrix.powerline.SerialLightManager
 
 
 
 
 
- 
- All Implemented Interfaces:
- java.beans.PropertyChangeListener,- java.beans.VetoableChangeListener,- java.util.EventListener,- PropertyChangeFirer,- PropertyChangeProvider,- SilenceablePropertyChangeProvider,- VetoableChangeFirer,- VetoableChangeProvider,- LightManager,- Manager<Light>,- NameIncrementingManager,- ProvidingManager<Light>
 - Direct Known Subclasses:
- SpecificLightManager,- SpecificLightManager,- SpecificLightManager,- SpecificLightManager,- SpecificLightManager
 
 public abstract class SerialLightManager extends AbstractLightManager Implement LightManager for Powerline serial systems.System names are "PLnnn", where P is the user configurable system prefix, nnn is the bit number without padding. 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface jmri.ManagerManager.ManagerDataEvent<E extends NamedBean>, Manager.ManagerDataListener<E extends NamedBean>, Manager.NameValidity
 
- 
 - 
Field SummaryFields Modifier and Type Field Description (package private) SerialTrafficControllertc- 
Fields inherited from class jmri.managers.AbstractManager_beans, _tsys, _tuser, memo, silenceableProperties, silencedProperties
 - 
Fields inherited from class jmri.beans.VetoableChangeSupportvetoableChangeSupport
 - 
Fields inherited from class jmri.beans.PropertyChangeSupportpropertyChangeSupport
 - 
Fields inherited from interface jmri.ManagerANALOGIOS, AUDIO, BLOCKBOSS, BLOCKS, CONDITIONALS, CTCDATA, ENTRYEXIT, IDTAGS, LAYOUTBLOCKS, LIGHTS, LOGIXNG_ANALOG_ACTIONS, LOGIXNG_ANALOG_EXPRESSIONS, LOGIXNG_CONDITIONALNGS, LOGIXNG_DIGITAL_ACTIONS, LOGIXNG_DIGITAL_BOOLEAN_ACTIONS, LOGIXNG_DIGITAL_EXPRESSIONS, LOGIXNG_GLOBAL_VARIABLES, LOGIXNG_MODULES, LOGIXNG_STRING_ACTIONS, LOGIXNG_STRING_EXPRESSIONS, LOGIXNG_TABLES, LOGIXNGS, LOGIXS, MEMORIES, METERFRAMES, METERS, OBLOCKS, PANELFILES, PROPERTY_BEANS, PROPERTY_CAN_DELETE, PROPERTY_DISPLAY_LIST_NAME, PROPERTY_DO_DELETE, PROPERTY_DO_NOT_DELETE, PROPERTY_LENGTH, REPORTERS, ROUTES, SECTIONS, SENSORGROUPS, SENSORS, SIGNALGROUPS, SIGNALHEADS, SIGNALMASTLOGICS, SIGNALMASTS, STRINGIOS, TIMEBASE, TRANSITS, TURNOUTS, WARRANTS
 
- 
 - 
Constructor SummaryConstructors Constructor Description SerialLightManager(SerialTrafficController tc)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description booleanallowMultipleAdditions(java.lang.String systemName)Determines if it is possible to add a range of NamedBeans in numerical order for a particular system implementation.protected LightcreateNewLight(java.lang.String systemName, java.lang.String userName)Method to create a new Light based on the system name Returns null if the system name is not in a valid format Assumes calling method has checked that a Light with this system name does not already existprotected abstract LightcreateNewSpecificLight(java.lang.String systemName, java.lang.String userName)Create light of a specific type for the interfacejava.lang.StringgetEntryToolTip()Get a manager-specific tool tip for adding an entry to the manager.SerialSystemConnectionMemogetMemo()Get the system connection for this manager.booleansupportsVariableLights(java.lang.String systemName)Test if system in the given name can support a variable light.java.lang.StringvalidateSystemNameFormat(java.lang.String name, java.util.Locale locale)Validate the format of name, returning it unchanged if valid.booleanvalidSystemNameConfig(java.lang.String systemName)Public method to validate system name for configurationManager.NameValidityvalidSystemNameFormat(java.lang.String systemName)Test if parameter is a properly formatted system name.- 
Methods inherited from class jmri.managers.AbstractLightManageractivateAllLights, convertSystemNameToAlternate, getBeanTypeHandled, getLight, getNamedBeanClass, getXMLOrder, newLight, provideLight, typeLetter
 - 
Methods inherited from class jmri.managers.AbstractManageraddDataListener, checkNumeric, createSystemName, deleteBean, deregister, dispose, fireDataListenersAdded, fireDataListenersRemoved, fireVetoableChange, getAutoSystemName, getBySystemName, getBySystemName, getByUserName, getKnownBeanProperties, getNamedBean, getNamedBeanSet, getObjectCount, getOuterBean, getSystemPrefix, handleUserNameUniqueness, makeSystemName, propertyChange, register, registerSelf, registerUserName, removeDataListener, setDataListenerMute, setPropertyChangesSilenced, updateAutoNumber, vetoableChange
 - 
Methods inherited from class jmri.beans.VetoableChangeSupportaddVetoableChangeListener, addVetoableChangeListener, fireVetoableChange, fireVetoableChange, fireVetoableChange, getVetoableChangeListeners, getVetoableChangeListeners, removeVetoableChangeListener, removeVetoableChangeListener
 - 
Methods inherited from class jmri.beans.PropertyChangeSupportaddPropertyChangeListener, addPropertyChangeListener, fireIndexedPropertyChange, fireIndexedPropertyChange, fireIndexedPropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface jmri.LightManagercreateSystemName, dispose, getBySystemName, getByUserName, provide
 - 
Methods inherited from interface jmri.ManageraddDataListener, deleteBean, deregister, getBeanTypeHandled, getKnownBeanProperties, getNamedBean, getNamedBeanSet, getObjectCount, getSubSystemNamePrefix, getSystemNamePrefix, getSystemPrefix, isValidSystemNameFormat, makeSystemName, makeSystemName, makeSystemName, register, removeDataListener, setDataListenerMute, validateBadCharsInSystemNameFormat, validateIntegerSystemNameFormat, validateNmraAccessorySystemNameFormat, validateSystemNameFormat, validateSystemNameFormatOnlyNumeric, validateSystemNamePrefix, validateTrimmedMin1NumberSystemNameFormat, validateTrimmedSystemNameFormat, validateUppercaseTrimmedSystemNameFormat
 - 
Methods inherited from interface jmri.NameIncrementingManagergetNextValidSystemName
 - 
Methods inherited from interface jmri.beans.PropertyChangeProvideraddPropertyChangeListener, addPropertyChangeListener, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
 - 
Methods inherited from interface jmri.beans.SilenceablePropertyChangeProvidersetPropertyChangesSilenced
 - 
Methods inherited from interface jmri.beans.VetoableChangeProvideraddVetoableChangeListener, addVetoableChangeListener, getVetoableChangeListeners, getVetoableChangeListeners, removeVetoableChangeListener, removeVetoableChangeListener
 
- 
 
- 
- 
- 
Constructor Detail- 
SerialLightManagerpublic SerialLightManager(SerialTrafficController tc) 
 
- 
 - 
Method Detail- 
getMemo@Nonnull public SerialSystemConnectionMemo getMemo() Get the system connection for this manager.
 - 
allowMultipleAdditionspublic boolean allowMultipleAdditions(@Nonnull java.lang.String systemName) Description copied from interface:NameIncrementingManagerDetermines if it is possible to add a range of NamedBeans in numerical order for a particular system implementation.Default is not providing this service. Systems should override this method if they do provide the service. - Parameters:
- systemName- the system name to check against; appears to be ignored in all implementations
- Returns:
- true if possible; false otherwise
 
 - 
createNewLight@Nonnull protected Light createNewLight(@Nonnull java.lang.String systemName, java.lang.String userName) throws java.lang.IllegalArgumentException Method to create a new Light based on the system name Returns null if the system name is not in a valid format Assumes calling method has checked that a Light with this system name does not already exist- Specified by:
- createNewLightin class- AbstractLightManager
- Parameters:
- systemName- the system name to use for this light
- userName- the user name to use for this light
- Returns:
- the new light or null if unsuccessful
- Throws:
- java.lang.IllegalArgumentException- something failed in the names
 
 - 
createNewSpecificLightprotected abstract Light createNewSpecificLight(java.lang.String systemName, java.lang.String userName) Create light of a specific type for the interface- Parameters:
- systemName- name encoding device
- userName- user name
- Returns:
- light object
 
 - 
validateSystemNameFormat@Nonnull public java.lang.String validateSystemNameFormat(@Nonnull java.lang.String name, @Nonnull java.util.Locale locale) Validate the format of name, returning it unchanged if valid.Although further restrictions may be added by system-specific implementations, at a minimum, the implementation must consider a name that does not start with the System Name prefix for this manager to be invalid, and must consider a name that is the same as the System Name prefix to be invalid. Overriding implementations may rely on Manager.validSystemNameFormat(java.lang.String), however they must provide an actionable message in the thrown exception if that method does not returnManager.NameValidity.VALID. When overriding implementations of this method rely on validSystemNameFormat(), implementations of that method must not throw an exception, log an error, or otherwise disrupt the user.- Parameters:
- name- the system name to validate
- locale- the locale for a localized exception; this is needed for the JMRI web server, which supports multiple locales
- Returns:
- the unchanged value of the name parameter
 
 - 
validSystemNameFormatpublic Manager.NameValidity validSystemNameFormat(@Nonnull java.lang.String systemName) Test if parameter is a properly formatted system name. Implementations of this method must not throw an exception, log an error, or otherwise disrupt the user.- Specified by:
- validSystemNameFormatin interface- Manager<Light>
- Overrides:
- validSystemNameFormatin class- AbstractManager<Light>
- Parameters:
- systemName- the system name
- Returns:
- Manager.NameValidity.INVALIDif system name does not start with- Manager.getSystemNamePrefix();- Manager.NameValidity.VALID_AS_PREFIX_ONLYif system name equals- Manager.getSystemNamePrefix(); otherwise- Manager.NameValidity.VALIDto allow Managers that do not perform more specific validation to be considered valid.
 
 - 
validSystemNameConfigpublic boolean validSystemNameConfig(@Nonnull java.lang.String systemName) Public method to validate system name for configuration- Parameters:
- systemName- the system name
- Returns:
- 'true' if system name has a valid format, else return 'false'
 
 - 
getEntryToolTippublic java.lang.String getEntryToolTip() Get a manager-specific tool tip for adding an entry to the manager.- Specified by:
- getEntryToolTipin interface- Manager<Light>
- Overrides:
- getEntryToolTipin class- AbstractLightManager
- Returns:
- the tool tip or null to disable the tool tip
 
 - 
supportsVariableLightspublic boolean supportsVariableLights(@Nonnull java.lang.String systemName) Description copied from class:AbstractLightManagerTest if system in the given name can support a variable light.- Specified by:
- supportsVariableLightsin interface- LightManager
- Overrides:
- supportsVariableLightsin class- AbstractLightManager
- Parameters:
- systemName- the system name
- Returns:
- 'true' to indicate this system can support variable lights
 
 
- 
 
-