Class AbstractPathExpressionStateObject
- java.lang.Object
-
- org.eclipse.persistence.jpa.jpql.tools.model.query.AbstractStateObject
-
- org.eclipse.persistence.jpa.jpql.tools.model.query.AbstractPathExpressionStateObject
-
- All Implemented Interfaces:
ListHolderStateObject<String>,StateObject
- Direct Known Subclasses:
CollectionValuedPathExpressionStateObject,StateFieldPathExpressionStateObject
public abstract class AbstractPathExpressionStateObject extends AbstractStateObject implements ListHolderStateObject<String>
An identification variable followed by the navigation operator (.) and a state field or association field is a path expression. The type of the path expression is the type computed as the result of navigation; that is, the type of the state field or association field to which the expression navigates.- Since:
- 2.4
- Version:
- 2.5
- Author:
- Pascal Filion
- See Also:
AbstractPathExpression
-
-
Field Summary
Fields Modifier and Type Field Description static StringIDENTIFICATION_VARIABLE_PROPERTYNotifies the identification variable property has changed.static StringPATHS_LISTNotifies the content of the paths list has changed.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description StringaddItem(String item)Adds the givenStateObjectas a child of this one.voidaddItems(List<? extends String> items)Adds the given list ofStateObjectsas children of this one.voidaddListChangeListener(String listName, IListChangeListener<String> listener)Registers the givenIListChangeListenerfor the specified list.voidappend(String text)Appends the given sequence of characters to the path expression.booleancanMoveDown(String item)Determines whether the givenStateObjectcan be moved down by one position in the list owned by its parent.booleancanMoveUp(String item)Determines whether the givenStateObjectcan be moved up by one position in the list owned by its parent.AbstractPathExpressiongetExpression()Returns the actual parsed object if thisStateObjectrepresentation of the JPQL query was created by parsing an existing JPQL query.StateObjectgetIdentificationVariable()Returns theStateObjectrepresenting the identification variable that starts the path expression, which can be a sample identification variable, a map value, map key or map entry expression.StringgetItem(int index)Returns theStateObjectat the given positions from the listIManagedTypegetManagedType()ReturnsIMappinggetMapping()ReturnsIMappinggetMapping(int index)Retrieves theIMappingfor the path at the given position.StringgetPath()Returns the string representation of the path expression.ITypegetType()Returns theITypeof the field handled by this object.ITypeDeclarationgetTypeDeclaration()Returns theITypeDeclarationof the field handled by this object.booleanhasIdentificationVariable()Determines whether the identification variable is present.booleanhasItems()Determines whether thisStateObjecthas any children.booleanisEquivalent(StateObject stateObject)Determines whether the givenStateObjectis equivalent to this one, i.e.ListIterable<String>items()Returns anListIterableover the children.intitemsSize()Returns the number of children this list holder has.StringmoveDown(String item)Moves the givenStateObjectdown by one position in the list owned by its parent.StringmoveUp(String item)Moves the givenStateObjectup by one position in the list owned by its parent.voidremoveItem(int index)Removes the single path at the given index.voidremoveItem(String item)Removes the givenStateObjectfrom the list of children.voidremoveItems(Collection<String> items)Removes the givenStateObjectfrom the list of children.voidremoveListChangeListener(String listName, IListChangeListener<String> listener)Unregisters the givenIListChangeListenerthat was registered for the specified list.voidsetIdentificationVariable(StateObject identificationVariable)Sets theStateObjectrepresenting the identification variable that starts the path expression, which can be a sample identification variable, a map value, map key or map entry expression.voidsetPath(int index, String path)Replaces the existing path segment to become the given one.voidsetPath(CharSequence path)Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.voidsetPaths(String... paths)Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.voidsetPaths(List<String> paths)Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.voidsetPaths(ListIterator<String> paths)Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.-
Methods inherited from class org.eclipse.persistence.jpa.jpql.tools.model.query.AbstractStateObject
addPropertyChangeListener, children, decorate, equals, findIdentificationVariable, getDeclaration, getDecorator, getGrammar, getManagedTypeProvider, getParent, getQueryBuilder, getRoot, getType, getType, getTypeHelper, getTypeRepository, hashCode, isDecorated, removePropertyChangeListener, setExpression, setParent, toString, toString, toText
-
Methods inherited from interface org.eclipse.persistence.jpa.jpql.tools.model.query.StateObject
accept, addPropertyChangeListener, children, decorate, findIdentificationVariable, getDeclaration, getDecorator, getGrammar, getManagedTypeProvider, getParent, getQueryBuilder, getRoot, isDecorated, removePropertyChangeListener, setParent, toString, toText
-
-
-
-
Field Detail
-
IDENTIFICATION_VARIABLE_PROPERTY
public static final String IDENTIFICATION_VARIABLE_PROPERTY
Notifies the identification variable property has changed.- See Also:
- Constant Field Values
-
PATHS_LIST
public static final String PATHS_LIST
Notifies the content of the paths list has changed.- See Also:
- Constant Field Values
-
-
Method Detail
-
addItem
public String addItem(String item)
Adds the givenStateObjectas a child of this one.- Specified by:
addItemin interfaceListHolderStateObject<String>- Parameters:
item- The childStateObjectto become a child of this one return The given item
-
addItems
public void addItems(List<? extends String> items)
Adds the given list ofStateObjectsas children of this one.- Specified by:
addItemsin interfaceListHolderStateObject<String>- Parameters:
items- TheStateObjectsto become children of this one
-
addListChangeListener
public void addListChangeListener(String listName, IListChangeListener<String> listener)
Registers the givenIListChangeListenerfor the specified list. The listener will be notified only when items are added, removed, moved from the list.- Specified by:
addListChangeListenerin interfaceListHolderStateObject<String>- Parameters:
listName- The name of the list for which the listener will be notified when the content of the list has changedlistener- The listener to be notified upon changes
-
append
public void append(String text)
Appends the given sequence of characters to the path expression. If the sequence does not begin with a dot, then the first segment will be appended to the last segment and then new segments will be created.- Parameters:
text- The sequence of characters to append to the path expression
-
canMoveDown
public boolean canMoveDown(String item)
Determines whether the givenStateObjectcan be moved down by one position in the list owned by its parent.- Specified by:
canMoveDownin interfaceListHolderStateObject<String>- Parameters:
item- TheStateObjectthat could potentially be moved down- Returns:
trueif the object can be moved down by one unit;falseotherwise
-
canMoveUp
public boolean canMoveUp(String item)
Determines whether the givenStateObjectcan be moved up by one position in the list owned by its parent.- Specified by:
canMoveUpin interfaceListHolderStateObject<String>- Parameters:
item- TheStateObjectthat could potentially be moved up- Returns:
trueif the object can be moved up by one unit;falseotherwise
-
getExpression
public AbstractPathExpression getExpression()
Returns the actual parsed object if thisStateObjectrepresentation of the JPQL query was created by parsing an existing JPQL query.- Specified by:
getExpressionin interfaceStateObject- Overrides:
getExpressionin classAbstractStateObject- Returns:
- The parsed object when a JPQL query is parsed and converted into a
StateObjectornullwhen the JPQL query is manually created (i.e. not from a string)
-
getIdentificationVariable
public StateObject getIdentificationVariable()
Returns theStateObjectrepresenting the identification variable that starts the path expression, which can be a sample identification variable, a map value, map key or map entry expression.- Returns:
- The root of the path expression
-
getItem
public String getItem(int index)
Returns theStateObjectat the given positions from the list- Specified by:
getItemin interfaceListHolderStateObject<String>- Parameters:
index- The position of theStateObjectto retrieve- Returns:
- The
StateObjectat the given position
-
getManagedType
public IManagedType getManagedType()
Returns- Returns:
-
getMapping
public IMapping getMapping()
Returns- Returns:
-
getMapping
public IMapping getMapping(int index)
Retrieves theIMappingfor the path at the given position.- Parameters:
index- The index of the path for which itsIMappingshould be retrieved, which should start at 1 to skip the identification variable
-
getPath
public String getPath()
Returns the string representation of the path expression. If the identification variable is virtual, then it is not part of the result.- Returns:
- The path expression, which is never
null
-
getType
public IType getType()
Returns theITypeof the field handled by this object.- Returns:
- Either the
ITypethat was resolved by this state object or theITypeforIType.UNRESOLVABLE_TYPEif it could not be resolved
-
getTypeDeclaration
public ITypeDeclaration getTypeDeclaration()
Returns theITypeDeclarationof the field handled by this object.- Returns:
- Either the
ITypeDeclarationthat was resolved by this object or theITypeDeclarationforIType.UNRESOLVABLE_TYPEif it could not be resolved
-
hasIdentificationVariable
public boolean hasIdentificationVariable()
Determines whether the identification variable is present.- Returns:
truethe identification variable is present;falseotherwise
-
hasItems
public boolean hasItems()
Determines whether thisStateObjecthas any children.- Specified by:
hasItemsin interfaceListHolderStateObject<String>- Returns:
trueif thisStateObjecthas children;falseotherwise
-
isEquivalent
public boolean isEquivalent(StateObject stateObject)
Determines whether the givenStateObjectis equivalent to this one, i.e. the information of bothStateObjectis the same.- Specified by:
isEquivalentin interfaceStateObject- Overrides:
isEquivalentin classAbstractStateObject- Parameters:
stateObject- TheStateObjectto compare its content to this one- Returns:
trueif both object are equivalent;falseotherwise
-
items
public ListIterable<String> items()
Returns anListIterableover the children.- Specified by:
itemsin interfaceListHolderStateObject<String>- Returns:
- An
ListIterablethat is iterating over the children
-
itemsSize
public int itemsSize()
Returns the number of children this list holder has.- Specified by:
itemsSizein interfaceListHolderStateObject<String>- Returns:
- The count of
StateObjectsthat are children of this one
-
moveDown
public String moveDown(String item)
Moves the givenStateObjectdown by one position in the list owned by its parent.- Specified by:
moveDownin interfaceListHolderStateObject<String>- Parameters:
item- TheStateObjectto move down in the list- Returns:
- The given item
-
moveUp
public String moveUp(String item)
Moves the givenStateObjectup by one position in the list owned by its parent.- Specified by:
moveUpin interfaceListHolderStateObject<String>- Parameters:
item- TheStateObjectto move up in the list- Returns:
- The given item
-
removeItem
public void removeItem(int index)
Removes the single path at the given index.- Parameters:
index- The position of the single path to remove. If the index is 0, then the identification variable is nullified
-
removeItem
public void removeItem(String item)
Removes the givenStateObjectfrom the list of children.- Specified by:
removeItemin interfaceListHolderStateObject<String>- Parameters:
item- The childStateObjectto not longer be a child
-
removeItems
public void removeItems(Collection<String> items)
Removes the givenStateObjectfrom the list of children.- Specified by:
removeItemsin interfaceListHolderStateObject<String>- Parameters:
items- TheStateObjectsto remove from this one
-
removeListChangeListener
public void removeListChangeListener(String listName, IListChangeListener<String> listener)
Unregisters the givenIListChangeListenerthat was registered for the specified list. The listener will no longer be notified only when items are added, removed, moved from the list.- Specified by:
removeListChangeListenerin interfaceListHolderStateObject<String>- Parameters:
listName- The name of the list for which the listener was registeredlistener- The listener to unregister
-
setIdentificationVariable
public void setIdentificationVariable(StateObject identificationVariable)
Sets theStateObjectrepresenting the identification variable that starts the path expression, which can be a sample identification variable, a map value, map key or map entry expression.- Parameters:
identificationVariable- The root of the path expression
-
setPath
public void setPath(CharSequence path)
Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.- Parameters:
path- The new path expression
-
setPath
public void setPath(int index, String path)Replaces the existing path segment to become the given one.- Parameters:
index- The position of the path segment to replacepath- The replacement
-
setPaths
public void setPaths(List<String> paths)
Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.- Parameters:
paths- The new path expression
-
setPaths
public void setPaths(ListIterator<String> paths)
Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.- Parameters:
paths- The new path expression
-
setPaths
public void setPaths(String... paths)
Changes the path expression with the list of segments, the identification variable will also be updated with the first segment.- Parameters:
paths- The new path expression
-
-