Package com.nomagic.magicdraw.uml
Interface BaseElement
-
- All Superinterfaces:
java.lang.Cloneable,java.lang.Comparable
- All Known Subinterfaces:
Abstraction,AbstractRefObject,AcceptCallAction,AcceptEventAction,Action,ActionExecutionSpecification,ActionInputPin,Activity,ActivityEdge,ActivityFinalNode,ActivityGroup,ActivityNode,ActivityParameterNode,ActivityPartition,Actor,AddStructuralFeatureValueAction,AddVariableValueAction,AnyReceiveEvent,Artifact,Association,AssociationClass,Behavior,BehavioralFeature,BehavioredClassifier,BehaviorExecutionSpecification,BooleanTaggedValue,BroadcastSignalAction,CallAction,CallBehaviorAction,CallEvent,CallOperationAction,CentralBufferNode,ChangeEvent,Class,Classifier,ClassifierTemplateParameter,Clause,ClearAssociationAction,ClearStructuralFeatureAction,ClearVariableAction,Collaboration,CollaborationUse,CombinedFragment,Comment,CommunicationPath,Component,ComponentRealization,ConditionalNode,ConnectableElement,ConnectableElementTemplateParameter,ConnectionPointReference,Connector,ConnectorEnd,ConsiderIgnoreFragment,Constraint,Continuation,ControlFlow,ControlNode,CreateLinkAction,CreateLinkObjectAction,CreateObjectAction,DataStoreNode,DataType,DecisionNode,Dependency,DeployedArtifact,Deployment,DeploymentSpecification,DeploymentTarget,DestroyLinkAction,DestroyObjectAction,DestructionOccurrenceSpecification,Device,Diagram,DirectedRelationship,Duration,DurationConstraint,DurationInterval,DurationObservation,Element,ElementImport,ElementTaggedValue,ElementValue,EncapsulatedClassifier,Enumeration,EnumerationLiteral,Event,ExceptionHandler,ExecutableNode,ExecutionEnvironment,ExecutionOccurrenceSpecification,ExecutionSpecification,ExpansionNode,ExpansionRegion,Expression,Extend,Extension,ExtensionEnd,ExtensionPoint,Feature,FinalNode,FinalState,FlowFinalNode,ForkNode,FunctionBehavior,Gate,Generalization,GeneralizationSet,GeneralOrdering,Image,Include,InformationFlow,InformationItem,InitialNode,InputPin,InstanceSpecification,InstanceValue,IntegerTaggedValue,Interaction,InteractionConstraint,InteractionFragment,InteractionOperand,InteractionUse,Interface,InterfaceRealization,InterruptibleActivityRegion,Interval,IntervalConstraint,InvocationAction,JoinNode,Lifeline,LinkAction,LinkEndCreationData,LinkEndData,LinkEndDestructionData,LiteralBoolean,LiteralInteger,LiteralNull,LiteralReal,LiteralSpecification,LiteralString,LiteralUnlimitedNatural,LoopNode,Manifestation,MDElement,MDObject,MergeNode,Message,MessageEnd,MessageEvent,MessageOccurrenceSpecification,Model,ModelObject,MultiplicityElement,NamedElement,Namespace,Node,ObjectFlow,ObjectNode,Observation,OccurrenceSpecification,OpaqueAction,OpaqueBehavior,OpaqueExpression,Operation,OperationTemplateParameter,OutputPin,Package,PackageableElement,PackageImport,PackageMerge,Parameter,ParameterableElement,ParameterSet,PartDecomposition,Pin,Port,PrimitiveType,Profile,ProfileApplication,Property,ProtocolConformance,ProtocolStateMachine,ProtocolTransition,Pseudostate,QualifierValue,RaiseExceptionAction,ReadExtentAction,ReadIsClassifiedObjectAction,ReadLinkAction,ReadLinkObjectEndAction,ReadLinkObjectEndQualifierAction,ReadSelfAction,ReadStructuralFeatureAction,ReadVariableAction,Realization,RealTaggedValue,Reception,ReclassifyObjectAction,RedefinableElement,RedefinableTemplateSignature,ReduceAction,Region,Relationship,RemoveStructuralFeatureValueAction,RemoveVariableValueAction,ReplyAction,SendObjectAction,SendSignalAction,SequenceNode,Signal,SignalEvent,Slot,StartClassifierBehaviorAction,StartObjectBehaviorAction,State,StateInvariant,StateMachine,Stereotype,StringExpression,StringTaggedValue,StructuralFeature,StructuralFeatureAction,StructuredActivityNode,StructuredClassifier,Substitution,TaggedValue,TemplateableElement,TemplateBinding,TemplateParameter,TemplateParameterSubstitution,TemplateSignature,TestIdentityAction,TimeConstraint,TimeEvent,TimeExpression,TimeInterval,TimeObservation,Transition,Trigger,Type,TypedElement,UnmarshallAction,Usage,UseCase,ValuePin,ValueSpecification,ValueSpecificationAction,Variable,VariableAction,Vertex,WriteLinkAction,WriteStructuralFeatureAction,WriteVariableAction
- All Known Implementing Classes:
com.nomagic.magicdraw.uml.symbols.shapes.AbstractHeaderShapeView,com.nomagic.magicdraw.uml.symbols.shapes.AbstractImageShapeView,ActionView,ActivationView,com.nomagic.magicdraw.uml.symbols.shapes.ActivityGroupView,ActorView,ArtifactView,AssociationClassView,AssociationView,BarView,com.nomagic.magicdraw.uml.symbols.paths.BaseFlowView,com.nomagic.magicdraw.uml.symbols.shapes.BaseLifelineView,com.nomagic.magicdraw.uml.symbols.paths.BaseRealizationView,CallBehaviorActionView,CallOperationActionView,ClassifierView,ClassView,CollaborationUseView,CollaborationView,CombinedFragmentView,CommentView,CommunicationPathView,ComponentView,ConditionalNodeView,ConnectorToSelfView,ConnectorView,ConstraintLinkView,com.nomagic.magicdraw.uml.symbols.paths.ContainerLinkView,com.nomagic.magicdraw.uml.symbols.shapes.ContainerShapeView,ContainmentLinkView,ContentShape,ControlFlowView,DataTypeView,DecisionView,DependencyView,DeploymentView,DiagramFrameView,DiagramLegendShape,DiagramPresentationElement,DiagramPropertiesShape,DiagramShape,DurationConstraintView,ElementImpl,ElementImportView,EnumerationView,ExceptionHandlerView,ExpansionNodeView,ExpansionRegionView,ExtendView,ExtensionView,FlowConnectorView,FoundMessageView,com.nomagic.magicdraw.uml.symbols.shapes.FragmentView,com.nomagic.magicdraw.uml.symbols.shapes.FrameView,GeneralizationSetView,GeneralizationView,GenericView,com.nomagic.magicdraw.uml.symbols.shapes.HeaderShapeView,ImageShapeView,IncludeView,InformationFlowView,InformationItemView,InstanceSpecificationView,InteractionUseOverviewView,InteractionUseView,InterfaceRealizationView,InterfaceView,InterruptibleActivityRegionView,LifeLineLineView,LifelineView,LinkAttributeView,LinkView,com.nomagic.magicdraw.uml.symbols.paths.LinkWithEndsView,com.nomagic.magicdraw.uml.symbols.paths.LinkWithRolesView,com.nomagic.magicdraw.uml.symbols.paths.LinkWithStereotype,LoopNodeView,com.nomagic.magicdraw.uml.symbols.paths.LostFoundMessageView,LostMessageView,com.nomagic.magicdraw.uml.MDElementImpl,MessageView,NNaryAssociationView,NodeInstanceSpecificationView,NodeView,NoteAnchorView,NoteView,ObjectFlowView,ObjectNodeView,OpaqueActionView,PackageImportView,PackageMergeView,PackageView,PartView,PathConnector,PathElement,com.nomagic.magicdraw.uml.symbols.shapes.PathToSelfShape,PinView,PortView,PresentationElement,PrimitiveTypeView,ProfileApplicationView,Project,ProjectOptions,PseudoNodeView,PseudoStateView,RealizationView,RectangularShape,RoleBindingView,SeparatorView,com.nomagic.magicdraw.uml.symbols.paths.SeqBaseMessageView,SeqMessageView,SeqSelfMessageView,SequenceLifelineView,SequenceNodeView,ShapeElement,com.nomagic.magicdraw.uml.symbols.shapes.ShapeWithLabels,SignalActionView,SignalView,StateInvariantView,StateView,StereotypeView,StructuredActivityNodeView,SwimlaneCellView,SwimlaneView,TemplateBindingView,TextBoxView,com.nomagic.magicdraw.uml.symbols.shapes.TextShapeView,TimeConstraintView,TransitionToSelfView,TransitionView,TreeView,com.nomagic.magicdraw.uml.symbols.shapes.TypedElementView,com.nomagic.magicdraw.uml.symbols.shapes.TypedElementWithLabels,UsageView,UseCaseView,VirtualRelationView
@OpenApi public interface BaseElement extends java.lang.Comparable, java.lang.Cloneable
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description voidaccept(AbstractVisitor visitor)Method accepts visitor, and calls method visit < class name > ( this ) of visitor .voidaddPropertyChangeListener(java.beans.PropertyChangeListener listener)Registers the listener to the element.voidatInsert()This method is called then this element is added into the project.booleancanAdd(BaseElement element)Checks if this element can add given element.booleancanAdd(BaseElement element, boolean checkPermissions)Checks if this element can add given element.booleancanAddChild()Checks if new elements can be added to this elementbooleancanAddInstance(BaseElement o)Checks if this object can add element of given type.booleancanBeDeleted()Checks if element can be deleted from project.booleancanChangeParent(java.util.Collection elements, BaseElement newParent)Returns true, if element can change parent.booleancanDeleteChild(BaseElement child)Checks if given element can be deleted from this element.java.lang.Objectclone()voiddispose()This method is called when element is removed from the project.voidfirePropertyChange(java.lang.String propertyName, java.lang.Object oldValue, java.lang.Object newValue)DelegatesfirePropertyChangeto thePropertyChangeSupport, the member of this class, which reports a bound property update to any registered listeners.java.lang.ClassgetClassType()Gets the type of the element class.java.lang.StringgetHumanName()Returns human representation of the element.java.lang.StringgetHumanType()Returns human representation of the element type.java.lang.StringgetID()Returns the ID of theElement.BaseElementgetObjectParent()Returns the element parent.booleanisEditable()Checks if element can be edited.booleanisParentOf(BaseElement obj)Returns true, if current element is parent of given element.voidremoveAllPropertyChangeListeners()Removes all property change listeners from this element.voidremovePropertyChangeListener(java.beans.PropertyChangeListener listener)Unregisters the given listener from the element.voidsetID(java.lang.String id)Sets the specified ID to theElement.java.lang.StringsGetID()Returns the actual ID of theElement.
-
-
-
Method Detail
-
getID
@OpenApi java.lang.String getID()
Returns the ID of theElement. If the ID isnull, new id for element is generated. Element id is persistence and do not changes during project save/load.- Returns:
- the ID of the
Element.
-
sGetID
@OpenApi java.lang.String sGetID()
Returns the actual ID of theElement. May return null if ID was not generated or set for this element.- Returns:
- the ID of the
Element. - See Also:
getID()
-
setID
@OpenApi void setID(java.lang.String id)
Sets the specified ID to theElement.- Parameters:
id- the id to be set.
-
getClassType
@OpenApi java.lang.Class getClassType()
Gets the type of the element class. Every element has its own ClassType. Usually this class type is class of element or class interface of element. All types are registered in ClassTypes.- Returns:
- the type of the element.
-
addPropertyChangeListener
@OpenApi void addPropertyChangeListener(java.beans.PropertyChangeListener listener)
Registers the listener to the element. The given listener will get notifications about property changes in this element.- Parameters:
listener- thePropertyChangeListenerto be added.- See Also:
PropertyChangeSupport
-
removePropertyChangeListener
@OpenApi void removePropertyChangeListener(java.beans.PropertyChangeListener listener)
Unregisters the given listener from the element. The given listener will not get any notifications about property changes in this element.- Parameters:
listener- the PropertyChangeListener to be removed.- See Also:
PropertyChangeSupport
-
removeAllPropertyChangeListeners
void removeAllPropertyChangeListeners()
Removes all property change listeners from this element.
-
firePropertyChange
@OpenApi void firePropertyChange(java.lang.String propertyName, java.lang.Object oldValue, java.lang.Object newValue)DelegatesfirePropertyChangeto thePropertyChangeSupport, the member of this class, which reports a bound property update to any registered listeners. No event is fired if old and new values are equal or null.- Parameters:
propertyName- the programmatic name of the property that was changed.oldValue- the old value of the propertynewValue- the new value of the property- See Also:
PropertyChangeSupport
-
atInsert
void atInsert()
This method is called then this element is added into the project.
-
dispose
void dispose()
This method is called when element is removed from the project.
-
accept
@OpenApi void accept(AbstractVisitor visitor) throws java.lang.Exception
Method accepts visitor, and calls method visit < class name > ( this ) of visitor . (see Visitor pattern for more details).- Parameters:
visitor- which visits this element.- Throws:
java.lang.Exception
-
getHumanName
@OpenApi java.lang.String getHumanName()
Returns human representation of the element. Usually human name is constructed from element class type and name.- Returns:
- the human name of the element.
-
getHumanType
@OpenApi java.lang.String getHumanType()
Returns human representation of the element type. Contains only element type without element name.- Returns:
- the human type of the element.
-
canAdd
@OpenApi boolean canAdd(BaseElement element)
Checks if this element can add given element.- Parameters:
element- the given element.- Returns:
- true if this element can add given element.
- See Also:
canAdd(BaseElement, boolean)
-
canAdd
@OpenApi boolean canAdd(BaseElement element, boolean checkPermissions)
Checks if this element can add given element.
Following rules must be true in order to have result true:
1.if checkTeamworkLock == true, this element must be locked for edit.
2.element can add given element as instance (class types are checked).
3.element can add given element as child (given element is not a parent of current element and etc).- Parameters:
element- the element to add.checkPermissions- check or not permissions.- Returns:
- true if element can add given element as child.
-
canDeleteChild
boolean canDeleteChild(BaseElement child)
Checks if given element can be deleted from this element. Follofing rules must be true in order to have result true: 1.this element must be editable. 2.project must be editable. 3.the type of given child must be valid for teamwork lock for edit operation (for example class, package and etc, not Attribute).- Parameters:
child- a given child- Returns:
- true, if given element can be deleted from current element.
-
canBeDeleted
@OpenApi boolean canBeDeleted()
Checks if element can be deleted from project. Element cannot be deleted if it is not isEditable(), parent is not set or parent does not allow to remove this element.- Returns:
- true, if element can be deleted from project.
- See Also:
isEditable()
-
canAddInstance
boolean canAddInstance(BaseElement o)
Checks if this object can add element of given type. Current implementation returns false.- Returns:
- true if this object can elements of given type.
-
isEditable
@OpenApi boolean isEditable()
Checks if element can be edited. Element can not be edited in teamwork project, or it is used "by reference" from module.- Returns:
- true, if element can be edited.
-
canAddChild
@OpenApi boolean canAddChild()
Checks if new elements can be added to this element- Returns:
- true, if new sub elements can be added.
-
getObjectParent
@OpenApi BaseElement getObjectParent()
Returns the element parent. This implementation returns null. Should be overridden in subclasses.- Returns:
- the parent of the element.
-
isParentOf
boolean isParentOf(BaseElement obj)
Returns true, if current element is parent of given element. Return false in this implementation.- Parameters:
obj- the given element(possible child).- Returns:
- true if obj is parent of this object.
-
canChangeParent
boolean canChangeParent(java.util.Collection elements, BaseElement newParent)Returns true, if element can change parent.- Parameters:
elements- collection of the elements, whose will change the parent together with this.newParent- new parent object.- Returns:
- true if element can change parent.
-
clone
java.lang.Object clone() throws java.lang.CloneNotSupportedException- Throws:
java.lang.CloneNotSupportedException
-
-