gov.nasa.arc.brahms.common.data
Class ConceptualClass

java.lang.Object
  extended by gov.nasa.arc.brahms.common.data.BrahmsObject
      extended by gov.nasa.arc.brahms.common.data.ModelElement
          extended by gov.nasa.arc.brahms.common.data.NamedModelElement
              extended by gov.nasa.arc.brahms.common.data.Concept
                  extended by gov.nasa.arc.brahms.common.data.ConceptualConcept
                      extended by gov.nasa.arc.brahms.common.data.ConceptualClass
All Implemented Interfaces:
IConceptClass, Type, gov.nasa.arc.brahms.common.IConstants, java.io.Serializable
Direct Known Subclasses:
VMConceptualClass

public class ConceptualClass
extends ConceptualConcept
implements IConceptClass

A conceptual object class defines a type of conceptual objects used in a model. For the definition of conceptual objects see the section on conceptual objects.

Version:
$Revision: 1.2 $ $Date: 2008/09/04 13:51:05 $ $Author: rvhoof $
Author:
Ron van Hoof
See Also:
Serialized Form

Field Summary
 
Fields inherited from class gov.nasa.arc.brahms.common.data.Concept
ATTRIBUTES_PROPERTY, RELATIONS_PROPERTY
 
Fields inherited from class gov.nasa.arc.brahms.common.data.NamedModelElement
NAME_PROPERTY
 
Fields inherited from interface gov.nasa.arc.brahms.common.IConstants
ABORT, ACTIVECLASS, ACTIVECONCEPT, ACTIVEINSTANCE, AGENT, ANONYMOUS, ANYAGENT, AREA, AREADEF, ASSIGNED, ATTRIBUTE, BASEAREADEF, BASECLASS, BASECONCEPTUALCLASS, BASEGROUP, BASELIBRARY, BOOLEAN, BROADCAST, BUILDING, BYTE, CCLOCK, CDATE, CHAR, CITY, CLASS, CLOCK, COLLECTALL, COMMUNICATE, COMPLETE, COMPOSITE, COMPUTER, CONCEPT, CONCEPTUALCLASS, CONCEPTUALCONCEPT, CONCEPTUALOBJECT, CONTINUE, COPY, CREATEAGENT, CREATEAREA, CREATEOBJECT, current, CURRENT, DATAFRAME, DATE, DB, DETECTABLE, DIV, DOUBLE, EMAIL, EMPTY_STRING, END, ENDACTIVITY, ENTAGENT, EQ, EXCEPTION, EXPR, FACE2FACE, FACTFRAME, FALSE, FAX, FLOAT, FOREACH, FORONE, G2, GE, GEOGRAPHYCONCEPT, GESTURE, GET, GROUP, GT, IMPASSE, INT, INVALID, JAVA, JAVA_TYPE, KNOWN_MODIFIER, KNOWNVAL_MODIFIER, LE, LOCAL, LONG, LT, MAP, MINUS, MOD, MOVE, MULT, NE, NEW, NONE, NOT_MODIFIER, NOWORK, O, OA, OBJECT, ONTOLOGY, PAGER, PARAMETER, PATH, PHONE, PLUS, PRIMITIVE, PRIVATE, PROAGENT, PROTECTED, PRSAGENT, PUBLIC, PUT, RECEIVE, RELATION, sACTIVECLASS, sACTIVECONCEPT, sACTIVEINSTANCE, sAGENT, sARCHIVE, sAREA, sAREADEF, sBOOLEAN, sBYTE, sBYTECODEEXT, sCHAR, sCLASS, sCOMPUTER, sCONCEPT, sCONCEPTUALCLASS, sCONCEPTUALCONCEPT, sCONCEPTUALOBJECT, sCOPY, sCURRENT, sDETECTABLE, sDOUBLE, sEMAIL, sEND, SEND, sFACE2FACE, sFAX, sFILEEXT, sFLOAT, sGEOGRAPHYCONCEPT, sGROUP, SHORT, SIMAGENT, sINT, sJAVA_TYPE, sLONG, sMAP, sNEW, sNONE, sNOWORK, sOBJECT, SOURCECODE, sPAGER, sPARAMETER, sPATH, sPHONE, sPRIVATE, sPROJECTEXT, sPROTECTED, sPUBLIC, sSHORT, sSTART, sSTRING, sSYMBOL, START, STRING, sUNKNOWN, sVOID, SYMBOL, TRUE, UDT, UML, UNASSIGNED, UNDEFINED, unknown, UNKNOWN, UNKNOWN_MODIFIER, V, VARIABLE, VOID, WHENEVER, WORKFRAME, WORLD, XML
 
Constructor Summary
ConceptualClass()
           
ConceptualClass(java.lang.String name)
           
ConceptualClass(java.lang.String file, int line)
           
ConceptualClass(java.lang.String name, java.lang.String file, int line)
           
 
Method Summary
 boolean addMember(ConceptualInstance concept)
           
 boolean addSubClass(ConceptualClass concept)
           
 boolean addSuperClass(ConceptualClass concept)
           
 void delete()
          Deletes this element from the model and removes all references to this element in other model elements.
protected  Attribute getAttributeRecursive(java.lang.String name, boolean includeThis)
          Searches for the attribute with the specified name through the concept hierarchy breadth first.
protected  java.util.LinkedList<Attribute> getAttributesRecursive(boolean includeThis)
          Returns the conceptual class' attributes including the attributes inherited from its parent class and their parent super classes.
 ConceptualInstance getMember(java.lang.String name)
           
 java.util.Enumeration getMembers()
           
 java.util.List<ConceptualInstance> getMembers(boolean includeSubClasses)
          Returns a list of all the members of this class.
 void getMembersRecursive(java.util.HashMap<java.lang.String,ConceptualInstance> members, boolean includeSubClasses, java.util.HashMap<java.lang.String,ConceptualClass> classes)
          Returns a list of all the members of this class.
protected  Relation getRelationRecursive(java.lang.String name, boolean includeThis)
          Searches for the relation with the specified name through the concept hierarchy breadth first.
protected  java.util.LinkedList<Relation> getRelationsRecursive(boolean includeThis)
          Returns the conceptual class' relations including the relations inherited from its parent class and their parent super classes.
 ConceptualClass getSubClass(java.lang.String name)
           
 java.util.Enumeration getSubClasses()
           
 ConceptualClass getSuperClass(java.lang.String name)
           
 java.util.Enumeration getSuperClasses()
           
 java.util.LinkedList<ConceptualClass> getSuperClasses(boolean includeParents)
          Returns all superclasses for this concept, if includeParents is true it will include all superclasses, direct and indirect, breadth first.
 boolean hasMembers()
           
 boolean hasSubClasses()
           
 boolean hasSuperClasses()
           
 boolean isSubClassOf(Concept concept)
          Checks whether this conceptual class is a sub class of the specified concept.
protected  boolean isSubClassOf(Concept concept, java.util.Hashtable checked)
          Checks recursively whether this conceptual class is a sub class of the specified concept, checking the concept hierarchy.
 boolean removeMember(java.lang.String name)
           
 boolean removeSubClass(java.lang.String name)
           
 boolean removeSuperClass(java.lang.String name)
           
protected  void setID()
          Sets the unique identifier.
 
Methods inherited from class gov.nasa.arc.brahms.common.data.ConceptualConcept
getAttribute, getAttributes, getRelation, getRelations
 
Methods inherited from class gov.nasa.arc.brahms.common.data.Concept
addAttribute, addRelation, compareTypes, createContext, equals, getAttribute, getAttributes, getContext, getFullyQualifiedName, getIcon, getModel, getName, getPackage, getRelation, getRelations, getType, hasAttributes, hasRelations, isLocal, isSerializable, removeAttribute, removeRelation, setContext, setIcon, setLocal, setModel, setPackage, setSerializable, toString
 
Methods inherited from class gov.nasa.arc.brahms.common.data.NamedModelElement
getDisplayText, getOwner, setDisplayText, setFullyQualifiedName, setName, setOwner
 
Methods inherited from class gov.nasa.arc.brahms.common.data.BrahmsObject
export, getFile, getID, getLine, getSerialNumber, isBCC, isDynamic, isLoaded, isResolved, setBCC, setDynamic, setFile, setID, setLine, setLoaded, setResolved, setSerialNumber
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 
Methods inherited from interface gov.nasa.arc.brahms.common.data.Type
getSerialNumber
 

Constructor Detail

ConceptualClass

public ConceptualClass()

ConceptualClass

public ConceptualClass(java.lang.String name)

ConceptualClass

public ConceptualClass(java.lang.String file,
                       int line)

ConceptualClass

public ConceptualClass(java.lang.String name,
                       java.lang.String file,
                       int line)
Method Detail

setID

protected void setID()
Sets the unique identifier.

Overrides:
setID in class BrahmsObject

addSuperClass

public boolean addSuperClass(ConceptualClass concept)

removeSuperClass

public boolean removeSuperClass(java.lang.String name)

getSuperClass

public ConceptualClass getSuperClass(java.lang.String name)
                              throws java.util.NoSuchElementException
Throws:
java.util.NoSuchElementException

hasSuperClasses

public boolean hasSuperClasses()

getSuperClasses

public java.util.Enumeration getSuperClasses()

getSuperClasses

public java.util.LinkedList<ConceptualClass> getSuperClasses(boolean includeParents)
Returns all superclasses for this concept, if includeParents is true it will include all superclasses, direct and indirect, breadth first.

Parameters:
includeParents - true if also indirect superclasses are to be included in the list, false if only th direct superclasses are to be returned
Returns:
LinkedList the list of superclasses.

addSubClass

public boolean addSubClass(ConceptualClass concept)

removeSubClass

public boolean removeSubClass(java.lang.String name)

getSubClass

public ConceptualClass getSubClass(java.lang.String name)
                            throws java.util.NoSuchElementException
Throws:
java.util.NoSuchElementException

hasSubClasses

public boolean hasSubClasses()

getSubClasses

public java.util.Enumeration getSubClasses()

addMember

public boolean addMember(ConceptualInstance concept)

removeMember

public boolean removeMember(java.lang.String name)

getMember

public ConceptualInstance getMember(java.lang.String name)
                             throws java.util.NoSuchElementException
Throws:
java.util.NoSuchElementException

hasMembers

public boolean hasMembers()

getMembers

public java.util.Enumeration getMembers()

getMembers

public java.util.List<ConceptualInstance> getMembers(boolean includeSubClasses)
Returns a list of all the members of this class. If includeSubClasses is true it will also include all of the members of the subclasses.

Parameters:
includeSubClasses - true to include members of subclasses, false for only the direct members
Returns:
List the list of members, empty list if none found

getMembersRecursive

public void getMembersRecursive(java.util.HashMap<java.lang.String,ConceptualInstance> members,
                                boolean includeSubClasses,
                                java.util.HashMap<java.lang.String,ConceptualClass> classes)
Returns a list of all the members of this class. If includeSubClasses is true it will also include all of the members of the subclasses.

Parameters:
members - the map to which to add the members
includeSubClasses - true to include members of subclasses, false for only the direct members
classes - the map with classes for which members were already retrieved

delete

public void delete()
Deletes this element from the model and removes all references to this element in other model elements.

Overrides:
delete in class BrahmsObject

getAttributeRecursive

protected Attribute getAttributeRecursive(java.lang.String name,
                                          boolean includeThis)
Searches for the attribute with the specified name through the concept hierarchy breadth first. If the attribute with the specified name is found it is returned, otherwise null is returned.

Specified by:
getAttributeRecursive in class ConceptualConcept
Parameters:
name - the name of the attribute to be found
includeThis - flag indicating whether to search for the attribute in this concept or only to search in the parents
Returns:
Attribute the attribute if it was found, null otherwise

getAttributesRecursive

protected java.util.LinkedList<Attribute> getAttributesRecursive(boolean includeThis)
Returns the conceptual class' attributes including the attributes inherited from its parent class and their parent super classes. The attributes are retrieved recursively breadth first.

Note:When processing this list in other methods and an attribute with the same name occurs more then once, then only the last occurrence is to be used by the conceptual concept. The list contains the attibutes starting with the attributes highest in the class hierarchy.

Specified by:
getAttributesRecursive in class ConceptualConcept
Parameters:
includeThis - flag indicating whether to include the attibutes for this concept or only to return the parent attributes
Returns:
LinkedList the conceptual concept's (parent) attributes

getRelationRecursive

protected Relation getRelationRecursive(java.lang.String name,
                                        boolean includeThis)
Searches for the relation with the specified name through the concept hierarchy breadth first. If the relation with the specified name is found it is returned, otherwise null is returned.

Specified by:
getRelationRecursive in class ConceptualConcept
Parameters:
name - the name of the relation to be found
includeThis - flag indicating whether to search for the relation in this concept or only to search in the parents
Returns:
Relation the relation if it was found, null otherwise

getRelationsRecursive

protected java.util.LinkedList<Relation> getRelationsRecursive(boolean includeThis)
Returns the conceptual class' relations including the relations inherited from its parent class and their parent super classes. The relations are retrieved recursively breadth first.

Note:When processing this list in other methods and an relation with the same name occurs more then once, then only the last occurrence is to be used by the conceptual concept. The list contains the relations starting with the relations highest in the class hierarchy.

Specified by:
getRelationsRecursive in class ConceptualConcept
Parameters:
includeThis - flag indicating whether to include the relations for this concept or only to return the parent relations
Returns:
LinkedList the conceptual concept's (parent) relations

isSubClassOf

public boolean isSubClassOf(Concept concept)
Checks whether this conceptual class is a sub class of the specified concept.

Parameters:
concept - the concept to be checked to see if it is a parent of this conceptual class.
Returns:
true if this conceptual class is a sub class of the concept, false otherwise

isSubClassOf

protected boolean isSubClassOf(Concept concept,
                               java.util.Hashtable checked)
Checks recursively whether this conceptual class is a sub class of the specified concept, checking the concept hierarchy.

Parameters:
concept - the concept to be checked to see if it is a parent of this conceptual class.
checked - the table with parents already checked in the hierarchy to prevent circular loops
Returns:
true if this conceptual class is a sub class of the concept, false otherwise


Copyright © 1997-2012 All Rights Reserved.