Class DefaultConditionalNG
- All Implemented Interfaces:
Comparable<NamedBean>,PropertyChangeProvider,Base,ConditionalNG,FemaleSocketListener,NamedBean
-
Nested Class Summary
Nested classes/interfaces inherited from interface jmri.jmrit.logixng.Base
Base.PrintTreeSettings, Base.RunnableWithBase, Base.RunnableWithBaseThrowExceptionNested classes/interfaces inherited from interface jmri.NamedBean
NamedBean.BadNameException, NamedBean.BadSystemNameException, NamedBean.BadUserNameException, NamedBean.DisplayOptions, NamedBean.DuplicateSystemNameException -
Field Summary
Fields inherited from class jmri.jmrit.logixng.implementation.AbstractBase
_listenersAreRegisteredFields inherited from class jmri.implementation.AbstractNamedBean
listenerRefs, mSystemName, registerFields inherited from interface jmri.jmrit.logixng.Base
PRINT_LINE_NUMBERS_FORMAT, PROPERTY_CHILD_COUNT, PROPERTY_CHILD_REORDER, PROPERTY_LAST_RESULT_CHANGED, PROPERTY_SOCKET_CONNECTED, PROPERTY_SOCKET_DISCONNECTED, SEPARATOR, SOCKET_CONNECTED, SOCKET_DISCONNECTEDFields inherited from interface jmri.NamedBean
DISPLAY_NAME_FORMAT, INCONSISTENT, PROPERTY_COMMENT, PROPERTY_ENABLED, PROPERTY_KNOWN_STATE, PROPERTY_STATE, PROPERTY_USERNAME, QUOTED_NAME_FORMAT, UNKNOWN -
Constructor Summary
ConstructorsConstructorDescriptionDefaultConditionalNG(String sys, String user) DefaultConditionalNG(String sys, String user, int threadID) -
Method Summary
Modifier and TypeMethodDescriptionvoidconnected(FemaleSocket socket) The socket is connected.voiddisconnected(FemaleSocket socket) The socket is disconnected.final voidDispose this class.voidexecute()Execute the ConditionalNG.voidexecute(boolean allowRunDelayed) Execute the ConditionalNG.voidexecute(FemaleDigitalActionSocket socket) Execute the female socket.static voidexecuteModule(Module module, Map<String, Object> parameters) Executes a LogixNG Module.booleanDoes this item exists in the tree?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.Get the category.getChild(int index) Get a child of this itemintGet the number of children.Get the thread that this conditionalNG executes on.Create a deep copy of myself and my children The item needs to try to lookup itself in both systemNames and userNames to see if the user has given a new system name and/or a new user name.If no new system name is given, an auto system name is used.Get the female socket of this ConditionalNG.getLongDescription(Locale locale) Get a long description of this item.Get the parent.booleanGet whenether execute() should run on the LogixNG thread at once or should dispatch the call until later.getShortDescription(Locale locale) Get a short description of this item.getStack()Get the stackintGet the thread id that this conditionalNG should execute on when JMRI starts next time.intgetState()Provide generic access to internal state.Get the current symbol tablebooleanDetermines whether this ConditionalNG is enabled.booleanDetermines whenether this ConditionalNG should be executed at startup or at panel load.booleanAre listeners registered?voidRegister listeners if this object needs that.voidsetCurrentConditionalNG(ConditionalNG conditionalNG) Set the current ConditionalNG.voidsetEnabled(boolean enable) Set whenether this ConditionalNG is enabled or disabled.voidsetExecuteAtStartup(boolean value) Set whenether this ConditionalNG should be executed at startup or at panel load.voidSet the parent.voidsetRunDelayed(boolean value) Set whenether execute() should run on the LogixNG thread at once or should dispatch the call until later.voidsetSocketSystemName(String systemName) voidsetStartupThreadId(int threadId) Set the thread id that this conditionalNG should execute on when JMRI starts next time.voidsetState(int s) Provide generic access to internal state.voidsetSymbolTable(SymbolTable symbolTable) Set the current symbol tablefinal voidsetup()Setup this object and its children.voidUnregister listeners if this object needs that.Methods inherited from class jmri.jmrit.logixng.implementation.AbstractBase
assertListenersAreNotRegistered, compareSystemNameSuffix, deepCopyChildren, dispose, getConditionalNG, getListenerRefsIncludingChildren, getLogixNG, getRoot, getUsageDetail, getUsageTree, isActive, printTree, printTree, printTree, printTreeRow, registerListeners, setParentForAllChildren, unregisterListenersMethods inherited from class jmri.implementation.AbstractNamedBean
addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, describeState, equals, firePropertyChange, getComment, getDisplayName, getDisplayName, getListenerRef, getListenerRefs, getNumPropertyChangeListeners, getProperty, getPropertyChangeListeners, getPropertyChangeListeners, getPropertyChangeListenersByReference, getPropertyKeys, getSystemName, getUserName, hashCode, removeProperty, removePropertyChangeListener, removePropertyChangeListener, setComment, setProperty, setUserName, toString, toStringSuffix, updateListenerRef, vetoableChangeMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface jmri.jmrit.logixng.Base
addPropertyChangeListener, addPropertyChangeListener, deepCopyChildren, dispose, doSocketOperation, forEntireTree, forEntireTreeWithException, getComment, getConditionalNG, getListenerRef, getListenerRefs, getListenerRefsIncludingChildren, getLogixNG, getLongDescription, getModule, getNumPropertyChangeListeners, getPropertyChangeListenersByReference, getRoot, getShortDescription, getSystemName, getUsageDetail, getUsageTree, getUserName, hasChild, isActive, isSocketOperationAllowed, printTree, printTree, printTree, printTree, printTree, registerListeners, setComment, setParentForAllChildren, setUserName, unregisterListeners, updateListenerRef, vetoableChangeMethods inherited from interface jmri.jmrit.logixng.FemaleSocketListener
socketNameChangedMethods inherited from interface jmri.NamedBean
addPropertyChangeListener, addPropertyChangeListener, compareSystemNameSuffix, compareTo, describeState, dispose, getComment, getDisplayName, getDisplayName, getListenerRef, getListenerRefs, getNumPropertyChangeListeners, getProperty, getPropertyChangeListenersByReference, getPropertyKeys, getRecommendedToolTip, getSystemName, getUsageReport, getUserName, removeProperty, setComment, setProperty, setUserName, toString, updateListenerRef, vetoableChangeMethods inherited from interface jmri.beans.PropertyChangeProvider
addPropertyChangeListener, addPropertyChangeListener, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
-
Constructor Details
-
DefaultConditionalNG
public DefaultConditionalNG(String sys, String user) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException -
DefaultConditionalNG
public DefaultConditionalNG(String sys, String user, int threadID) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException
-
-
Method Details
-
getCurrentThread
Get the thread that this conditionalNG executes on.- Specified by:
getCurrentThreadin interfaceConditionalNG- Returns:
- the thread
-
getStartupThreadId
Get the thread id that this conditionalNG should execute on when JMRI starts next time. It's not currently possible to move a ConditionalNG from one thread to another without restarting JMRI.- Specified by:
getStartupThreadIdin interfaceConditionalNG- Returns:
- the thread ID
-
setStartupThreadId
Set the thread id that this conditionalNG should execute on when JMRI starts next time. It's not currently possible to move a ConditionalNG from one thread to another without restarting JMRI.- Specified by:
setStartupThreadIdin interfaceConditionalNG- Parameters:
threadId- the thread ID
-
getParent
Get the parent.The following rules apply
- LogixNGs has no parent. The method throws an UnsupportedOperationException if called.
- Expressions and actions has the male socket that they are connected to as their parent.
- Male sockets has the female socket that they are connected to as their parent.
- The parent of a female sockets is the LogixNG, expression or action that has this female socket.
- The parent of a male sockets is the same parent as the expression or action that it contains.
-
setParent
Set the parent.The following rules apply
- ExecutionGroups has no parent. The method throws an UnsupportedOperationException if called.
- LogixNGs has the execution group as its parent.
- Expressions and actions has the male socket that they are connected to as their parent.
- Male sockets has the female socket that they are connected to as their parent.
- The parent of a female sockets is the LogixNG, expression or action that has this female socket.
- The parent of a male sockets is the same parent as the expression or action that it contains.
-
getFemaleSocket
Get the female socket of this ConditionalNG.- Specified by:
getFemaleSocketin interfaceConditionalNG- Returns:
- the female socket
-
setRunDelayed
Set whenether execute() should run on the LogixNG thread at once or should dispatch the call until later. Most tests turns off the delay to simplify the tests.- Specified by:
setRunDelayedin interfaceConditionalNG- Parameters:
value- true if execute() should run on LogixNG thread delayed, false otherwise.
-
getRunDelayed
Get whenether execute() should run on the LogixNG thread at once or should dispatch the call until later. Most tests turns off the delay to simplify the tests.- Specified by:
getRunDelayedin interfaceConditionalNG- Returns:
- true if execute() should run on LogixNG thread delayed, false otherwise.
-
execute
Execute the ConditionalNG.- Specified by:
executein interfaceConditionalNG
-
execute
Execute the ConditionalNG.- Specified by:
executein interfaceConditionalNG- Parameters:
allowRunDelayed- true if it's ok to run delayed, false otherwise
-
execute
Execute the female socket.- Specified by:
executein interfaceConditionalNG- Parameters:
socket- the female socket
-
executeModule
public static void executeModule(Module module, Map<String, Object> parameters) throws IllegalArgumentExceptionExecutes a LogixNG Module.- Parameters:
module- The module to be executedparameters- The parameters- Throws:
IllegalArgumentException- when needed
-
setCurrentConditionalNG
Set the current ConditionalNG.- Specified by:
setCurrentConditionalNGin interfaceConditionalNG- Parameters:
conditionalNG- the current ConditionalNG
-
getStack
Get the stack- Specified by:
getStackin interfaceConditionalNG- Returns:
- the stack
-
getSymbolTable
Get the current symbol table- Specified by:
getSymbolTablein interfaceConditionalNG- Returns:
- the symbol table
-
setSymbolTable
Set the current symbol table- Specified by:
setSymbolTablein interfaceConditionalNG- Parameters:
symbolTable- the symbol table
-
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 interfaceNamedBean- Returns:
- a string of the bean type, eg Turnout, Sensor etc
-
setState
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 interfaceNamedBean- Parameters:
s- the state- Throws:
JmriException- general error when setting the state fails
-
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.
-
connected
Description copied from interface:FemaleSocketListenerThe socket is connected.- Specified by:
connectedin interfaceFemaleSocketListener- Parameters:
socket- the socket
-
disconnected
Description copied from interface:FemaleSocketListenerThe socket is disconnected.- Specified by:
disconnectedin interfaceFemaleSocketListener- Parameters:
socket- the socket
-
getShortDescription
Description copied from interface:BaseGet a short description of this item.- Specified by:
getShortDescriptionin interfaceBase- Parameters:
locale- The locale to be used- Returns:
- a short description
-
getLongDescription
Description copied from interface:BaseGet a long description of this item.- Specified by:
getLongDescriptionin interfaceBase- Parameters:
locale- The locale to be used- Returns:
- a long description
-
getChild
public FemaleSocket getChild(int index) throws IllegalArgumentException, UnsupportedOperationException Description copied from class:AbstractBaseGet a child of this item- Specified by:
getChildin interfaceBase- Overrides:
getChildin classAbstractBase- Parameters:
index- the index of the child to get- Returns:
- the child
- Throws:
IllegalArgumentException- if the index is less than 0 or greater or equal with the value returned by getChildCount()UnsupportedOperationException- when needed
-
getChildCount
Description copied from class:AbstractBaseGet the number of children.- Specified by:
getChildCountin interfaceBase- Overrides:
getChildCountin classAbstractBase- Returns:
- the number of children
-
getCategory
Description copied from class:AbstractBaseGet the category.- Specified by:
getCategoryin interfaceBase- Overrides:
getCategoryin classAbstractBase- Returns:
- the category
-
setSocketSystemName
- Specified by:
setSocketSystemNamein interfaceConditionalNG
-
getSocketSystemName
- Specified by:
getSocketSystemNamein interfaceConditionalNG
-
setup
Setup this object and its children. This method is used to lookup system names for child sockets, turnouts, sensors, and so on. -
disposeMe
Dispose this class. Listeners do not need to be unregistered by this method since they are unregistered by dispose().- Overrides:
disposeMein classAbstractBase
-
setEnabled
Set whenether this ConditionalNG is enabled or disabled.This method must call registerListeners() / unregisterListeners().
- Specified by:
setEnabledin interfaceConditionalNG- Parameters:
enable- true if this ConditionalNG should be enabled, false otherwise
-
isEnabled
Determines whether this ConditionalNG is enabled.- Specified by:
isEnabledin interfaceBase- Specified by:
isEnabledin interfaceConditionalNG- Returns:
- true if the ConditionalNG is enabled, false otherwise
-
setExecuteAtStartup
Set whenether this ConditionalNG should be executed at startup or at panel load.- Specified by:
setExecuteAtStartupin interfaceConditionalNG- Parameters:
value- true if this ConditionalNG should be executed at startup or at panel load.
-
isExecuteAtStartup
Determines whenether this ConditionalNG should be executed at startup or at panel load.- Specified by:
isExecuteAtStartupin interfaceConditionalNG- Returns:
- true if this ConditionalNG should be executed at startup or at panel load.
-
isListenersRegistered
Are listeners registered?- Specified by:
isListenersRegisteredin interfaceConditionalNG- Returns:
- true if listeners are registered, otherwise return false
-
registerListenersForThisClass
Register listeners if this object needs that.Important: This method may be called more than once. Methods overriding this method must ensure that listeners are not registered more than once.
- Overrides:
registerListenersForThisClassin classAbstractBase
-
unregisterListenersForThisClass
Unregister listeners if this object needs that.Important: This method may be called more than once. Methods overriding this method must ensure that listeners are not unregistered more than once.
- Overrides:
unregisterListenersForThisClassin classAbstractBase
-
getDeepCopy
Description copied from interface:BaseCreate a deep copy of myself and my children The item needs to try to lookup itself in both systemNames and userNames to see if the user has given a new system name and/or a new user name.If no new system name is given, an auto system name is used. If no user name is given, a null user name is used.- Specified by:
getDeepCopyin interfaceBase- Parameters:
systemNames- a map of old and new system nameuserNames- a map of old system name and new user name- Returns:
- a deep copy
-
existsInTree
Description copied from interface:BaseDoes this item exists in the tree?- Specified by:
existsInTreein interfaceBase- Returns:
- true if the item exists in the tree, false otherwise
-