Class DefaultModule
java.lang.Object
jmri.implementation.AbstractNamedBean
jmri.jmrit.logixng.implementation.AbstractBase
jmri.jmrit.logixng.implementation.DefaultModule
- All Implemented Interfaces:
Comparable<NamedBean>,PropertyChangeProvider,Base,FemaleSocketListener,Module,NamedBean
The default implementation of Module.
-
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.jmrit.logixng.Module
Module.Parameter, Module.ParameterData, Module.ReturnValueTypeNested 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
ConstructorsConstructorDescriptionDefaultModule(String sys, String user, FemaleSocketManager.SocketType socketType) DefaultModule(String sys, String user, FemaleSocketManager.SocketType socketType, boolean isVisible, boolean storeIfEmpty) -
Method Summary
Modifier and TypeMethodDescriptionvoidaddLocalVariable(String name, SymbolTable.InitialValueType initialValueType, String initialValueData) voidaddParameter(String name, boolean isInput, boolean isOutput) voidaddParameter(Module.Parameter parameter) voidconnected(FemaleSocket socket) The socket is connected.voiddisconnected(FemaleSocket socket) The socket is disconnected.final voidDispose this class.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 ConditionalNG of this item.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 parent.Get the root socket of the module.Get the type of the root socket of the module.getShortDescription(Locale locale) Get a short description of this item.intgetState()Provide generic access to internal state.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 the module stored in the tables and panels file if the module is empty?booleanIs the module visible to the user?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 voidRegister listeners if this object needs that.voidsetCurrentConditionalNG(ConditionalNG conditionalNG) Set the current ConditionalNG of the module.voidSet the parent.voidsetSocketSystemName(String systemName) voidsetState(int s) Provide generic access to internal state.voidsetStoreIfEmpty(boolean value) Set whenether the module should be stored in the tables and panels file if the module is empty.final voidsetup()Setup this object and its children.voidsetVisible(boolean value) Makes the module visible or not visible to the user.protected voidUnregister listeners if this object needs that.Methods inherited from class jmri.jmrit.logixng.implementation.AbstractBase
assertListenersAreNotRegistered, compareSystemNameSuffix, deepCopyChildren, dispose, getListenerRefsIncludingChildren, getLogixNG, getRoot, getUsageDetail, isActive, 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, getListenerRef, getListenerRefs, getListenerRefsIncludingChildren, getLogixNG, getLongDescription, getModule, getNumPropertyChangeListeners, getPropertyChangeListenersByReference, getRoot, getShortDescription, getSystemName, getUsageDetail, getUserName, hasChild, isActive, isEnabled, isSocketOperationAllowed, 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, getUserName, removeProperty, setComment, setProperty, setUserName, toString, updateListenerRef, vetoableChangeMethods inherited from interface jmri.beans.PropertyChangeProvider
addPropertyChangeListener, addPropertyChangeListener, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
-
Constructor Details
-
DefaultModule
public DefaultModule(String sys, String user, FemaleSocketManager.SocketType socketType) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException -
DefaultModule
public DefaultModule(String sys, String user, FemaleSocketManager.SocketType socketType, boolean isVisible, boolean storeIfEmpty) throws NamedBean.BadUserNameException, NamedBean.BadSystemNameException
-
-
Method Details
-
isVisible
Description copied from interface:ModuleIs the module visible to the user? -
setVisible
Description copied from interface:ModuleMakes the module visible or not visible to the user.- Specified by:
setVisiblein interfaceModule- Parameters:
value- true to make the module visible, false to make it invisible
-
isStoreIfEmpty
Description copied from interface:ModuleIs the module stored in the tables and panels file if the module is empty?- Specified by:
isStoreIfEmptyin interfaceModule- Returns:
- true if it's always stored, false if it's not stored if empty
-
setStoreIfEmpty
Description copied from interface:ModuleSet whenether the module should be stored in the tables and panels file if the module is empty.- Specified by:
setStoreIfEmptyin interfaceModule- Parameters:
value- true if it's always stored, false if it's not stored if empty
-
setCurrentConditionalNG
Description copied from interface:ModuleSet the current ConditionalNG of the module. This method is called on all modules before a ConditionalNG is executed to let the modules know which ConditionalNG is running in which thread.- Specified by:
setCurrentConditionalNGin interfaceModule- Parameters:
conditionalNG- the ConditionalNG
-
getConditionalNG
Description copied from class:AbstractBaseGet the ConditionalNG of this item.- Specified by:
getConditionalNGin interfaceBase- Overrides:
getConditionalNGin classAbstractBase- Returns:
- the ConditionalNG that owns this item
-
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 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
-
printTree
public void printTree(Base.PrintTreeSettings settings, PrintWriter writer, String indent, MutableInt lineNumber) Print the tree to a stream.- Specified by:
printTreein interfaceBase- Overrides:
printTreein classAbstractBase- Parameters:
settings- settings for what to printwriter- the stream to print the tree toindent- the indentation of each levellineNumber- the line number
-
printTree
public void printTree(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String indent, MutableInt lineNumber) Print the tree to a stream.- Specified by:
printTreein interfaceBase- Overrides:
printTreein classAbstractBase- Parameters:
settings- settings for what to printlocale- The locale to be usedwriter- the stream to print the tree toindent- the indentation of each levellineNumber- the line number
-
printTree
public void printTree(Base.PrintTreeSettings settings, Locale locale, PrintWriter writer, String indent, String currentIndent, MutableInt lineNumber) Print the tree to a stream.- Specified by:
printTreein interfaceBase- Overrides:
printTreein classAbstractBase- Parameters:
settings- settings for what to printlocale- The locale to be usedwriter- the stream to print the tree toindent- the indentation of each levelcurrentIndent- the current indentationlineNumber- the line number
-
getRootSocketType
Description copied from interface:ModuleGet the type of the root socket of the module.- Specified by:
getRootSocketTypein interfaceModule- Returns:
- the type
-
getRootSocket
Description copied from interface:ModuleGet the root socket of the module.- Specified by:
getRootSocketin interfaceModule- Returns:
- the root socket
-
addParameter
- Specified by:
addParameterin interfaceModule
-
addParameter
- Specified by:
addParameterin interfaceModule
-
addLocalVariable
public void addLocalVariable(String name, SymbolTable.InitialValueType initialValueType, String initialValueData) - Specified by:
addLocalVariablein interfaceModule
-
getParameters
- Specified by:
getParametersin interfaceModule
-
getLocalVariables
- Specified by:
getLocalVariablesin interfaceModule
-
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
-
setSocketSystemName
-
getSocketSystemName
-
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
-
registerListenersForThisClass
Description copied from class:AbstractBaseRegister 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
Description copied from class:AbstractBaseUnregister 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
-
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- Overrides:
getUsageTreein 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
-
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
-