Class DefaultLogixNG
- All Implemented Interfaces:
Comparable<NamedBean>,PropertyChangeProvider,Base,LogixNG,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.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.jmrit.logixng.LogixNG
PROPERTY_INLINEFields 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
ConstructorsConstructorDescriptionDefaultLogixNG(String sys, String user) DefaultLogixNG(String sys, String user, boolean inline) -
Method Summary
Modifier and TypeMethodDescriptionvoidactivate()Activates this LogixNG.booleanaddConditionalNG(ConditionalNG conditionalNG) Add a child ConditionalNG to the parent LogixNG.voidClear the startup flag.Do a deep copy of children from the original to me.voiddeleteConditionalNG(ConditionalNG conditionalNG) Delete a ConditionalNG from this LogixNG.voidexecute()Execute all ConditionalNGs if the LogixNG is enabled and activated.voidexecute(boolean allowRunDelayed) Execute all ConditionalNGs if the LogixNG is enabled and activated.voidexecute(boolean allowRunDelayed, boolean isStartup) Execute all ConditionalNGs if the LogixNG is enabled and activated.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 ConditionalNG of this item.getConditionalNG(int order) Returns the conditionalNG that will calculate in the specified order.getConditionalNG(String systemName) Get a ConditionalNG belonging to this LogixNG.getConditionalNG_SystemName(int index) Set the system name for the conditionalNG at the specified position in this listgetConditionalNGByUserName(String userName) Get a ConditionalNG belonging to this LogixNG.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 InlineLogixNG that owns this LogixNG, if the LogixNG is inline.voidReturns a list of all the listeners references for this object and all its children.Get the LogixNG of this item.getLongDescription(Locale locale) Get a long description of this item.intGet number of ConditionalNGs for this LogixNG.Get the parent.final BasegetRoot()Get the root of the tree that this item belongs to.getShortDescription(Locale locale) Get a short description of this item.intgetState()Provide generic access to internal state.voidgetUsageDetail(int level, NamedBean bean, List<NamedBeanUsageReport> report, NamedBean cdl) Add a new NamedBeanUsageReport to the report list if there are any matches in this action or expresssion.getUsageReport(NamedBean bean) Get a list of references for the specified bean.voidgetUsageTree(int level, NamedBean bean, List<NamedBeanUsageReport> report, NamedBean cdl) Navigate the LogixNG tree.booleanIs this item active?booleanisActive()Is this item active?booleanDetermines whether this LogixNG is enabled.booleanisInline()Determines whether this LogixNG is inline or not.booleanDetermines whether this LogixNG is currently during startup.voidprintTree(Base.PrintTreeSettings settings, PrintWriter writer, String indent, MutableInt lineNumber) Print the tree to a stream.voidprintTree(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String indent, String currentIndent, MutableInt lineNumber) Print the tree to a stream.voidprintTree(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String indent, MutableInt lineNumber) Print the tree to a stream.protected voidprintTreeRow(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String currentIndent, MutableInt lineNumber) voidRegister listeners if this object needs that.voidsetActive(boolean active) Activates/deactivates this LogixNG.voidsetConditionalNG_SystemName(int index, String systemName) Set the system name for the conditionalNG at the specified position in this listvoidsetEnabled(boolean enable) Set whenether this LogixNG is enabled or disabled.voidsetInline(boolean inline) Sets whether this LogixNG is inline or not.voidsetInlineLogixNG(InlineLogixNG inlineLogixNG) Set the InlineLogixNG that owns this LogixNG, if the LogixNG is inline.voidSet the parent.booleansetParentForAllChildren(List<String> errors) Set the parent for all the children.voidsetState(int s) Provide generic access to internal state.final voidsetup()Setup this object and its children.voidswapConditionalNG(int nextInOrder, int row) Move 'row' to 'nextInOrder' and shift all between 'nextInOrder' and 'row' up one position.voidUnregister listeners if this object needs that.Methods inherited from class jmri.implementation.AbstractNamedBean
addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, compareSystemNameSuffix, describeState, dispose, 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, dispose, doSocketOperation, existsInTree, forEntireTree, forEntireTreeWithException, getComment, getListenerRef, getListenerRefs, getLongDescription, getModule, getNumPropertyChangeListeners, getPropertyChangeListenersByReference, getShortDescription, getSystemName, getUserName, hasChild, isSocketOperationAllowed, printTree, printTree, setComment, setUserName, updateListenerRef, vetoableChangeMethods inherited from interface jmri.NamedBean
addPropertyChangeListener, addPropertyChangeListener, compareSystemNameSuffix, compareTo, describeState, dispose, getComment, getDisplayName, getDisplayName, getListenerRef, getListenerRefs, getNumPropertyChangeListeners, getProperty, getPropertyChangeListenersByReference, getPropertyKeys, getRecommendedToolTip, getSystemName, getUserName, removeProperty, setComment, setProperty, setUserName, toString, updateListenerRef, vetoableChangeMethods inherited from interface jmri.beans.PropertyChangeProvider
addPropertyChangeListener, addPropertyChangeListener, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
-
Constructor Details
-
DefaultLogixNG
public DefaultLogixNG(String sys, String user) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException -
DefaultLogixNG
public DefaultLogixNG(String sys, String user, boolean inline) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException
-
-
Method Details
-
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.
-
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.
-
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 interface:BaseGet a child of this item- Specified by:
getChildin interfaceBase- 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 interface:BaseGet the number of children.- Specified by:
getChildCountin interfaceBase- Returns:
- the number of children
-
getCategory
Description copied from interface:BaseGet the category.- Specified by:
getCategoryin interfaceBase- Returns:
- the category
-
setup
Setup this object and its children. This method is used to lookup system names for child sockets, turnouts, sensors, and so on. -
clearStartup
Clear the startup flag.- Specified by:
clearStartupin interfaceLogixNG
-
isStartup
Determines whether this LogixNG is currently during startup. -
setInline
Sets whether this LogixNG is inline or not. -
isInline
Determines whether this LogixNG is inline or not. -
setInlineLogixNG
Set the InlineLogixNG that owns this LogixNG, if the LogixNG is inline.- Specified by:
setInlineLogixNGin interfaceLogixNG- Parameters:
inlineLogixNG- the InlineLogixNG that owns this LogixNG, if the LogixNG is inline.
-
getInlineLogixNG
Get the InlineLogixNG that owns this LogixNG, if the LogixNG is inline.- Specified by:
getInlineLogixNGin interfaceLogixNG- Returns:
- the InlineLogixNG
-
setEnabled
Set whenether this LogixNG is enabled or disabled.This method must call registerListeners() / unregisterListeners() and also call execute() if enable is true.
- Specified by:
setEnabledin interfaceLogixNG- Parameters:
enable- true if this LogixNG should be enabled, false otherwise
-
activate
Activates this LogixNG.This method is called by the LogixNG manager during initialization of the LogixNGs.
-
setActive
Activates/deactivates this LogixNG.This method is used by the LogixNG action EnableLogixNG to temporary activate or deactivate a LogixNG.
-
isEnabled
Determines whether this LogixNG is enabled. -
getConditionalNG_SystemName
Set the system name for the conditionalNG at the specified position in this list- Specified by:
getConditionalNG_SystemNamein interfaceLogixNG- Parameters:
index- index of the element to set the system name- Returns:
- the system name
-
setConditionalNG_SystemName
Set the system name for the conditionalNG at the specified position in this list- Specified by:
setConditionalNG_SystemNamein interfaceLogixNG- Parameters:
index- index of the element to set the system namesystemName- the new system name
-
getNumConditionalNGs
Get number of ConditionalNGs for this LogixNG.- Specified by:
getNumConditionalNGsin interfaceLogixNG- Returns:
- the number of conditionals
-
swapConditionalNG
Move 'row' to 'nextInOrder' and shift all between 'nextInOrder' and 'row' up one position. Requiresrow > nextInOrder.- Specified by:
swapConditionalNGin interfaceLogixNG- Parameters:
nextInOrder- target order for ConditionalNG at rowrow- position of ConditionalNG to move
-
getConditionalNG
Returns the conditionalNG that will calculate in the specified order. This is also the order the ConditionalNG is listed in the Add/Edit LogixNG dialog. If 'order' is greater than the number of ConditionalNGs for this LogixNG, null is returned.- Specified by:
getConditionalNGin interfaceLogixNG- Parameters:
order- order in which the ConditionalNG calculates- Returns:
- the conditionalNG or null
-
addConditionalNG
Add a child ConditionalNG to the parent LogixNG.The first part handles adding conditionalNGs to the LogixNG list during file loading.
The second part handles normal additions using the GUI, Logix imports or tests.
- Specified by:
addConditionalNGin interfaceLogixNG- Parameters:
conditionalNG- The ConditionalNG object.- Returns:
- true if the ConditionalNG was added, false otherwise.
-
getConditionalNG
Get a ConditionalNG belonging to this LogixNG.- Specified by:
getConditionalNGin interfaceLogixNG- Parameters:
systemName- The name of the ConditionalNG object.- Returns:
- the ConditionalNG object or null if not found.
-
getConditionalNGByUserName
Get a ConditionalNG belonging to this LogixNG.- Specified by:
getConditionalNGByUserNamein interfaceLogixNG- Parameters:
userName- The name of the ConditionalNG object.- Returns:
- the ConditionalNG object or null if not found.
-
deleteConditionalNG
Delete a ConditionalNG from this LogixNG.Note: Since each LogixNG must have at least one ConditionalNG, the last ConditionalNG will not be deleted.
Returns An array of names used in an error message explaining why ConditionalNG should not be deleted.
- Specified by:
deleteConditionalNGin interfaceLogixNG- Parameters:
conditionalNG- The ConditionalNG to delete
-
isActive
Is this item active? If this item is enabled and all the parents are enabled, this item is active. -
isActivated
Is this item active? This method returns true if the the LogixNG is active but not enabled, while the methodBase.isActive()only returns true if the LogixNG is both active and enabled.- Specified by:
isActivatedin interfaceLogixNG- Returns:
- true if active, false otherwise.
-
execute
Execute all ConditionalNGs if the LogixNG is enabled and activated. -
execute
Execute all ConditionalNGs if the LogixNG is enabled and activated. -
execute
Execute all ConditionalNGs if the LogixNG is enabled and activated. -
getConditionalNG
Get the ConditionalNG of this item.- Specified by:
getConditionalNGin interfaceBase- Returns:
- the ConditionalNG that owns this item
-
getLogixNG
Get the LogixNG of this item.- Specified by:
getLogixNGin interfaceBase- Returns:
- the LogixNG that owns this item
-
getRoot
Get the root of the tree that this item belongs to. -
setParentForAllChildren
Set the parent for all the children.- Specified by:
setParentForAllChildrenin interfaceBase- Parameters:
errors- a list of potential errors- Returns:
- true if success, false otherwise
-
registerListeners
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.
- Specified by:
registerListenersin interfaceBase
-
unregisterListeners
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.
- Specified by:
unregisterListenersin interfaceBase
-
printTreeRow
protected void printTreeRow(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String currentIndent, MutableInt lineNumber) -
printTree
public void printTree(Base.PrintTreeSettings settings, PrintWriter writer, String indent, MutableInt lineNumber) Print the tree to a stream. -
printTree
public void printTree(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String indent, MutableInt lineNumber) Print the tree to a stream. -
printTree
public void printTree(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String indent, String currentIndent, MutableInt lineNumber) Print the tree to a stream. -
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
-
deepCopyChildren
public Base deepCopyChildren(Base original, Map<String, String> systemNames, Map<String, throws JmriExceptionString> userNames) Description copied from interface:BaseDo a deep copy of children from the original to me.- Specified by:
deepCopyChildrenin interfaceBase- Parameters:
original- the item to copy fromsystemNames- a map of old and new system nameuserNames- a map of old system name and new user name- Returns:
- myself
- Throws:
JmriException- in case of an error
-
getUsageReport
Get a list of references for the specified bean.- Specified by:
getUsageReportin interfaceNamedBean- Parameters:
bean- The bean to be checked.- Returns:
- a list of NamedBeanUsageReports or an empty ArrayList.
-
getUsageTree
public void getUsageTree(int level, NamedBean bean, List<NamedBeanUsageReport> report, NamedBean cdl) Navigate the LogixNG tree.- Specified by:
getUsageTreein interfaceBase- Parameters:
level- The current recursion level for debugging.bean- The named bean that is the object of the search.report- A list of NamedBeanUsageReport usage reports.cdl- The current ConditionalNG bean. Null for Module searches since there is no conditional
-
getUsageDetail
public void getUsageDetail(int level, NamedBean bean, List<NamedBeanUsageReport> report, NamedBean cdl) Add a new NamedBeanUsageReport to the report list if there are any matches in this action or expresssion.NamedBeanUsageReport Usage keys:
- LogixNGAction
- LogixNGExpression
- Specified by:
getUsageDetailin interfaceBase- Parameters:
level- The current recursion level for debugging.bean- The named bean that is the object of the search.report- A list of NamedBeanUsageReport usage reports.cdl- The current ConditionalNG bean. Null for Module searches since there is no conditional
-
getListenerRefsIncludingChildren
Returns a list of all the listeners references for this object and all its children.- Specified by:
getListenerRefsIncludingChildrenin interfaceBase- Parameters:
list- a list of textual references
-