Package jmri.jmrit.logixng.actions
Class ActionCreateBeansFromTable
java.lang.Object
jmri.implementation.AbstractNamedBean
jmri.jmrit.logixng.implementation.AbstractBase
jmri.jmrit.logixng.actions.AbstractDigitalAction
jmri.jmrit.logixng.actions.ActionCreateBeansFromTable
- All Implemented Interfaces:
PropertyChangeListener,VetoableChangeListener,Comparable<NamedBean>,EventListener,PropertyChangeProvider,Base,DigitalAction,DigitalActionBean,NamedBean
public class ActionCreateBeansFromTable
extends AbstractDigitalAction
implements PropertyChangeListener, VetoableChangeListener
This action listens on some beans and runs the ConditionalNG on property change.
-
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
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidDispose this class.voidexecute()Execute this DigitalActionBean.Get the category.getChild(int index) Get a child of this itemintGet the number of children.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.getLongDescription(Locale locale) Get a long description of this item.Get the type of the named beansGet name of row or columnGet name of row or columngetShortDescription(Locale locale) Get a short description of this item.Get tableRowOrColumn.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.booleanGet whenever to include cells that doesn't have a header.booleanGet whenever to move the user name to the new bean.booleanGet whenever to show only types that can be created with this action.booleanGet whenever to remove the old bean.booleanGet whenever to use the user name for beans that already uses the system name.voidvoidRegister listeners if this object needs that.voidsetIncludeCellsWithoutHeader(boolean includeCellsWithoutHeader) Set whenever to include cells that doesn't have a header.voidsetMoveUserName(boolean isMoveUserName) Set whenever to move the user name to the new bean.voidsetNamedBeanType(NamedBeanType namedBeanType) Set the type of the named beansvoidsetOnlyCreatableTypes(boolean onlyCreatableTypes) Set whenever to show only types that can be created with this action.voidsetRemoveOldBean(boolean removeOldBean) Set whenever to remove the old bean.voidsetRowOrColumnSystemName(String rowOrColumnName) Set name of row or columnvoidsetRowOrColumnUserName(String rowOrColumnName) Set name of row or columnvoidsetTableRowOrColumn(TableRowOrColumn tableRowOrColumn) Set tableRowOrColumn.voidsetup()Setup this object and its children.voidsetUpdateToUserName(boolean updateToUserName) Set whenever to use the user name for beans that already uses the system name.voidUnregister listeners if this object needs that.Methods inherited from class jmri.jmrit.logixng.actions.AbstractDigitalAction
getBeanType, getNewSocketName, getNewSocketName, getParent, getPreferredSocketPrefix, getState, setParent, setStateMethods inherited from class jmri.jmrit.logixng.implementation.AbstractBase
assertListenersAreNotRegistered, compareSystemNameSuffix, deepCopyChildren, dispose, getConditionalNG, getListenerRefsIncludingChildren, getLogixNG, getRoot, 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, existsInTree, forEntireTree, forEntireTreeWithException, getComment, getConditionalNG, getListenerRef, getListenerRefs, getListenerRefsIncludingChildren, getLogixNG, getLongDescription, getModule, getNumPropertyChangeListeners, getPropertyChangeListenersByReference, getRoot, getShortDescription, getSystemName, getUsageTree, getUserName, hasChild, isActive, isEnabled, isSocketOperationAllowed, printTree, printTree, printTree, printTree, printTree, registerListeners, setComment, setParentForAllChildren, setUserName, unregisterListeners, updateListenerRef, vetoableChangeMethods 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, removePropertyChangeListenerMethods inherited from interface java.beans.VetoableChangeListener
vetoableChange
-
Constructor Details
-
ActionCreateBeansFromTable
public ActionCreateBeansFromTable(String sys, String user) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException
-
-
Method Details
-
getDeepCopy
public Base getDeepCopy(Map<String, String> systemNames, Map<String, throws ParserExceptionString> userNames) 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
- Throws:
ParserException
-
isOnlyCreatableTypes
Get whenever to show only types that can be created with this action.- Returns:
- true if show only types that can be created, false otherwise
-
setOnlyCreatableTypes
Set whenever to show only types that can be created with this action.- Parameters:
onlyCreatableTypes- true show only types that can be created, false otherwise
-
getNamedBeanType
Get the type of the named beans- Returns:
- the type of named beans
-
setNamedBeanType
Set the type of the named beans- Parameters:
namedBeanType- the type of the named beans
-
getSelectNamedBean
-
getTableRowOrColumn
Get tableRowOrColumn.- Returns:
- tableRowOrColumn
-
setTableRowOrColumn
Set tableRowOrColumn.- Parameters:
tableRowOrColumn- tableRowOrColumn
-
getRowOrColumnSystemName
Get name of row or column- Returns:
- name of row or column
-
setRowOrColumnSystemName
Set name of row or column- Parameters:
rowOrColumnName- name of row or column
-
getRowOrColumnUserName
Get name of row or column- Returns:
- name of row or column
-
setRowOrColumnUserName
Set name of row or column- Parameters:
rowOrColumnName- name of row or column
-
isIncludeCellsWithoutHeader
Get whenever to include cells that doesn't have a header. Cells without headers can be used to use some cells in the table as comments.- Returns:
- true if include cells that doesn't have a header, false otherwise
-
setIncludeCellsWithoutHeader
Set whenever to include cells that doesn't have a header. Cells without headers can be used to use some cells in the table as comments.- Parameters:
includeCellsWithoutHeader- true if include rows/columns that doesn't have a header, false otherwise
-
isMoveUserName
Get whenever to move the user name to the new bean.- Returns:
- true if username should be moved, false otherwise
-
setMoveUserName
Set whenever to move the user name to the new bean.- Parameters:
isMoveUserName- true if username should be moved, false otherwise
-
isUpdateToUserName
Get whenever to use the user name for beans that already uses the system name.- Returns:
- true if update beans to use user name, false otherwise
-
setUpdateToUserName
Set whenever to use the user name for beans that already uses the system name.- Parameters:
updateToUserName- true if update beans to use user name, false otherwise
-
isRemoveOldBean
Get whenever to remove the old bean.- Returns:
- true if remove old bean, false otherwise
-
setRemoveOldBean
Set whenever to remove the old bean.- Parameters:
removeOldBean- true if remove old bean, false otherwise
-
getCategory
Get the category.- Specified by:
getCategoryin interfaceBase- Overrides:
getCategoryin classAbstractBase- Returns:
- the category
-
execute
Execute this DigitalActionBean.- Specified by:
executein interfaceDigitalAction- Throws:
JmriException- when an exception occurs
-
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
-
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
-
setup
Setup this object and its children. This method is used to lookup system names for child sockets, turnouts, sensors, and so on. -
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
-
propertyChange
- Specified by:
propertyChangein interfacePropertyChangeListener
-
disposeMe
Dispose this class. Listeners do not need to be unregistered by this method since they are unregistered by dispose().- Overrides:
disposeMein classAbstractBase
-
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- Overrides:
getUsageDetailin classAbstractBase- 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
-