Class DefaultMaleDigitalExpressionSocket
- java.lang.Object
- 
- jmri.jmrit.logixng.implementation.AbstractMaleSocket
- 
- jmri.jmrit.logixng.implementation.DefaultMaleDigitalExpressionSocket
 
 
- 
- All Implemented Interfaces:
- java.lang.Comparable<NamedBean>,- PropertyChangeProvider,- Base,- Debugable,- DigitalExpression,- DigitalExpressionBean,- MaleDigitalExpressionSocket,- MaleSocket,- NamedBean
 
 public class DefaultMaleDigitalExpressionSocket extends AbstractMaleSocket implements MaleDigitalExpressionSocket Every DigitalExpressionBean has an DefaultMaleDigitalExpressionSocket as its parent.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classDefaultMaleDigitalExpressionSocket.DigitalExpressionDebugConfig- 
Nested classes/interfaces inherited from interface jmri.jmrit.logixng.BaseBase.PrintTreeSettings, Base.RunnableWithBase, Base.RunnableWithBaseThrowException
 - 
Nested classes/interfaces inherited from interface jmri.jmrit.logixng.DebugableDebugable.DebugConfig
 - 
Nested classes/interfaces inherited from interface jmri.jmrit.logixng.MaleSocketMaleSocket.ErrorHandlingType
 - 
Nested classes/interfaces inherited from interface jmri.NamedBeanNamedBean.BadNameException, NamedBean.BadSystemNameException, NamedBean.BadUserNameException, NamedBean.DisplayOptions, NamedBean.DuplicateSystemNameException
 
- 
 - 
Field Summary- 
Fields inherited from class jmri.jmrit.logixng.implementation.AbstractMaleSocket_localVariables
 - 
Fields inherited from interface jmri.jmrit.logixng.BasePRINT_LINE_NUMBERS_FORMAT, PROPERTY_CHILD_COUNT, PROPERTY_CHILD_REORDER, PROPERTY_LAST_RESULT_CHANGED, PROPERTY_SOCKET_CONNECTED, PROPERTY_SOCKET_DISCONNECTED, SEPARATOR, SOCKET_CONNECTED, SOCKET_DISCONNECTED
 - 
Fields inherited from interface jmri.jmrit.logixng.DigitalExpressionBeanFALSE, TRUE
 - 
Fields inherited from interface jmri.NamedBeanDISPLAY_NAME_FORMAT, INCONSISTENT, PROPERTY_COMMENT, PROPERTY_ENABLED, PROPERTY_KNOWN_STATE, PROPERTY_STATE, PROPERTY_USERNAME, QUOTED_NAME_FORMAT, UNKNOWN
 
- 
 - 
Constructor SummaryConstructors Constructor Description DefaultMaleDigitalExpressionSocket(BaseManager<? extends NamedBean> manager, DigitalExpressionBean expression)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description intcompareSystemNameSuffix(java.lang.String suffix1, java.lang.String suffix2, NamedBean n2)Compare the suffix of this NamedBean's name with the suffix of the argument NamedBean's name for theNamedBean.compareTo(jmri.NamedBean)operation.Debugable.DebugConfigcreateDebugConfig()Create a debug configuration for this male socket.java.lang.StringdescribeState(int state)Provide human-readable, localized version of state value.voiddisposeMe()Disposes this object.booleanevaluate()Evaluate this expression.java.lang.StringgetBeanType()For instances in the code where we are dealing with just a bean and a message needs to be passed to the user or in a log.Debugable.DebugConfiggetDebugConfig()Get the debug configuration for this male socket.java.lang.StringgetDisplayName()Get user name if it exists, otherwise return System name.booleangetLastResult()Get the last result of the evaluation.java.lang.ObjectgetProperty(java.lang.String key)Retrieve the value associated with a key.java.util.Set<java.lang.String>getPropertyKeys()Retrieve the complete current set of keys.intgetState()Provide generic access to internal state.booleanisEnabled()Determines whether this male socket is enabled.voidnotifyChangedResult(boolean oldResult, boolean newResult)Notify property change listeners that the result of the expression has changed.voidregisterListenersForThisClass()Register listeners if this object needs that.voidremoveProperty(java.lang.String key)Remove the key/value pair against the NamedBean.voidsetDebugConfig(Debugable.DebugConfig config)Set the debug configuration for this male socket.voidsetEnabled(boolean enable)Set whenether this male socket is enabled or disabled.voidsetEnabledFlag(boolean enable)Set whenether this male socket is enabled or disabled, without activating the male socket.voidsetProperty(java.lang.String key, java.lang.Object value)Attach a key/value pair to the NamedBean, which can be retrieved later.voidsetState(int s)Provide generic access to internal state.voidunregisterListenersForThisClass()Register listeners if this object needs that.- 
Methods inherited from class jmri.jmrit.logixng.implementation.AbstractMaleSocketaddLocalVariable, addLocalVariable, addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, clearLocalVariables, deepCopyChildren, dispose, executeErrorHandlingModule, getCatchAbortExecution, getCategory, getChild, getChildCount, getComment, getConditionalNG, getDeepCopy, getErrorHandlingModuleSocket, getErrorHandlingType, getListen, getListenerRef, getListenerRefs, getListenerRefsIncludingChildren, getLocalVariables, getLogixNG, getLongDescription, getManager, getNumPropertyChangeListeners, getObject, getParent, getPropertyChangeListeners, getPropertyChangeListeners, getPropertyChangeListenersByReference, getRoot, getShortDescription, getSystemName, getUsageDetail, getUsageTree, getUserName, handleError, handleError, handleError, hasChild, isActive, isErrorHandlingModuleEnabled, isLocked, isSystem, printLocalVariable, printTree, printTree, printTree, printTreeRow, registerListeners, removePropertyChangeListener, removePropertyChangeListener, setCatchAbortExecution, setComment, setErrorHandlingType, setListen, setLocked, setParent, setParentForAllChildren, setSystem, setUserName, toString, unregisterListeners, updateListenerRef, vetoableChange
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface jmri.jmrit.logixng.BaseaddPropertyChangeListener, addPropertyChangeListener, deepCopyChildren, dispose, doSocketOperation, existsInTree, forEntireTree, forEntireTreeWithException, getCategory, getChild, getChildCount, getComment, getConditionalNG, getDeepCopy, getListenerRef, getListenerRefs, getListenerRefsIncludingChildren, getLogixNG, getLongDescription, getLongDescription, getModule, getNumPropertyChangeListeners, getParent, getPropertyChangeListenersByReference, getRoot, getShortDescription, getShortDescription, getSystemName, getUsageDetail, getUsageTree, getUserName, hasChild, isActive, isSocketOperationAllowed, printTree, printTree, printTree, printTree, printTree, registerListeners, setComment, setParent, setParentForAllChildren, setUserName, unregisterListeners, updateListenerRef, vetoableChange
 - 
Methods inherited from interface jmri.jmrit.logixng.MaleSocketaddLocalVariable, addLocalVariable, clearLocalVariables, find, getCatchAbortExecution, getErrorHandlingType, getListen, getLocalVariables, getManager, getObject, handleError, handleError, handleError, isLocked, isSupportingLocalVariables, isSystem, setCatchAbortExecution, setErrorHandlingType, setListen, setLocked, setSystem, setup
 - 
Methods inherited from interface jmri.NamedBeanaddPropertyChangeListener, addPropertyChangeListener, compareTo, dispose, getComment, getDisplayName, getListenerRef, getListenerRefs, getNumPropertyChangeListeners, getPropertyChangeListenersByReference, getRecommendedToolTip, getSystemName, getUsageReport, getUserName, setComment, setUserName, toString, updateListenerRef, vetoableChange
 - 
Methods inherited from interface jmri.beans.PropertyChangeProvideraddPropertyChangeListener, addPropertyChangeListener, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
 
- 
 
- 
- 
- 
Constructor Detail- 
DefaultMaleDigitalExpressionSocketpublic DefaultMaleDigitalExpressionSocket(@Nonnull BaseManager<? extends NamedBean> manager, @Nonnull DigitalExpressionBean expression) 
 
- 
 - 
Method Detail- 
notifyChangedResultpublic void notifyChangedResult(boolean oldResult, boolean newResult) Notify property change listeners that the result of the expression has changed.- Specified by:
- notifyChangedResultin interface- DigitalExpressionBean
- Parameters:
- oldResult- the old last result
- newResult- the new last result
 
 - 
evaluatepublic boolean evaluate() throws JmriException Evaluate this expression.This method must ensure that the value is not a Double.NaN, negative infinity or positive infinity. If that is the case, it must throw an IllegalArgumentException before checking if an error has occured. - Specified by:
- evaluatein interface- DigitalExpression
- Specified by:
- evaluatein interface- MaleDigitalExpressionSocket
- Returns:
- the result of the evaluation
- Throws:
- JmriException- when an exception occurs
 
 - 
getLastResultpublic boolean getLastResult() Description copied from interface:MaleDigitalExpressionSocketGet the last result of the evaluation.- Specified by:
- getLastResultin interface- MaleDigitalExpressionSocket
- Returns:
- the last result
 
 - 
getStatepublic int getState() Description copied from interface:NamedBeanProvide generic access to internal state.This generally shouldn't be used by Java code; use the class-specific form instead (e.g. getCommandedState in Turnout). This is provided to make scripts easier to read. 
 - 
setStatepublic void setState(int s) throws JmriException Description copied from interface:NamedBeanProvide generic access to internal state.This generally shouldn't be used by Java code; use the class-specific form instead (e.g. setCommandedState in Turnout). This is provided to make scripts access easier to read. - Specified by:
- setStatein interface- NamedBean
- Parameters:
- s- the state
- Throws:
- JmriException- general error when setting the state fails
 
 - 
describeStatepublic java.lang.String describeState(int state) Description copied from interface:NamedBeanProvide human-readable, localized version of state value.This method is intended for use when presenting to a human operator. - Specified by:
- describeStatein interface- NamedBean
- Parameters:
- state- the state to describe
- Returns:
- the state in localized form
 
 - 
setPropertypublic void setProperty(java.lang.String key, java.lang.Object value) Description copied from interface:NamedBeanAttach a key/value pair to the NamedBean, which can be retrieved later. These are not bound properties as yet, and don't throw events on modification. Key must not be null.The key is constrained to String to make these behave like normal Java Beans. - Specified by:
- setPropertyin interface- NamedBean
- Parameters:
- key- the property to set
- value- the value of the property
 
 - 
getPropertypublic java.lang.Object getProperty(java.lang.String key) Description copied from interface:NamedBeanRetrieve the value associated with a key. If no value has been set for that key, returns null.- Specified by:
- getPropertyin interface- NamedBean
- Parameters:
- key- the property to get
- Returns:
- The value of the property or null.
 
 - 
removePropertypublic void removeProperty(java.lang.String key) Description copied from interface:NamedBeanRemove the key/value pair against the NamedBean.- Specified by:
- removePropertyin interface- NamedBean
- Parameters:
- key- the property to remove
 
 - 
getPropertyKeyspublic java.util.Set<java.lang.String> getPropertyKeys() Description copied from interface:NamedBeanRetrieve the complete current set of keys.- Specified by:
- getPropertyKeysin interface- NamedBean
- Returns:
- empty set if none
 
 - 
getBeanTypepublic java.lang.String getBeanType() Description copied from interface:NamedBeanFor instances in the code where we are dealing with just a bean and a message needs to be passed to the user or in a log.- Specified by:
- getBeanTypein interface- NamedBean
- Returns:
- a string of the bean type, eg Turnout, Sensor etc
 
 - 
compareSystemNameSuffixpublic int compareSystemNameSuffix(java.lang.String suffix1, java.lang.String suffix2, NamedBean n2) Description copied from interface:NamedBeanCompare the suffix of this NamedBean's name with the suffix of the argument NamedBean's name for theNamedBean.compareTo(jmri.NamedBean)operation. This is intended to be a system-specific comparison that understands the various formats, etc.- Specified by:
- compareSystemNameSuffixin interface- NamedBean
- Parameters:
- suffix1- The suffix for the 1st bean in the comparison
- suffix2- The suffix for the 2nd bean in the comparison
- n2- The other (second) NamedBean in the comparison
- Returns:
- -1,0,+1 for ordering if the names are well-formed; may not provide proper ordering if the names are not well-formed.
 
 - 
setDebugConfigpublic void setDebugConfig(Debugable.DebugConfig config) Set the debug configuration for this male socket.Each implementation of MaleSocket has their own implementation of DebugConfig. Use reflection to get the proper class <package-name>.debug.<ClassName>Debug that returns a JPanel that can configure debugging for this male socket. - Specified by:
- setDebugConfigin interface- Debugable
- Parameters:
- config- the new configuration or null to turn off debugging
 
 - 
getDebugConfigpublic Debugable.DebugConfig getDebugConfig() Get the debug configuration for this male socket.- Specified by:
- getDebugConfigin interface- Debugable
- Returns:
- the configuration or null if debugging is turned off for this male socket
 
 - 
createDebugConfigpublic Debugable.DebugConfig createDebugConfig() Create a debug configuration for this male socket.- Specified by:
- createDebugConfigin interface- Debugable
- Returns:
- the new configuration
 
 - 
setEnabledpublic void setEnabled(boolean enable) Set whenether this male socket is enabled or disabled.This method must call registerListeners() / unregisterListeners(). - Specified by:
- setEnabledin interface- MaleSocket
- Parameters:
- enable- true if this male socket should be enabled, false otherwise
 
 - 
setEnabledFlagpublic void setEnabledFlag(boolean enable) Set whenether this male socket is enabled or disabled, without activating the male socket. This is used when loading the xml file and when copying an item.This method must call registerListeners() / unregisterListeners(). - Specified by:
- setEnabledFlagin interface- MaleSocket
- Parameters:
- enable- true if this male socket should be enabled, false otherwise
 
 - 
isEnabledpublic boolean isEnabled() Determines whether this male socket is enabled.- Specified by:
- isEnabledin interface- Base
- Specified by:
- isEnabledin interface- MaleSocket
- Returns:
- true if the male socket is enabled, false otherwise
 
 - 
disposeMepublic void disposeMe() Description copied from class:AbstractMaleSocketDisposes this object. This must remove _all_ connections!- Specified by:
- disposeMein class- AbstractMaleSocket
 
 - 
registerListenersForThisClasspublic void registerListenersForThisClass() Register listeners if this object needs that.- Specified by:
- registerListenersForThisClassin class- AbstractMaleSocket
 
 - 
unregisterListenersForThisClasspublic void unregisterListenersForThisClass() Register listeners if this object needs that.- Specified by:
- unregisterListenersForThisClassin class- AbstractMaleSocket
 
 - 
getDisplayNamepublic java.lang.String getDisplayName() Description copied from interface:NamedBeanGet user name if it exists, otherwise return System name.- Specified by:
- getDisplayNamein interface- NamedBean
- Returns:
- the user name or system-specific name
 
 
- 
 
-