Class ElementDelta
- All Implemented Interfaces:
IElementDelta
,IElementDeltaImpl
IElementDeltaImpl
.
To create a delta tree, use ElementDelta.Builder
.
Note that, despite having a dependency on IResourceDelta
and IMarkerDelta
, this class can be used even when
org.eclipse.core.resources
bundle is not available.
This is based on the "outward impression" of late resolution of
symbolic references a JVM must provide according to the JVMS.
Clients can use this class as it stands or subclass it as circumstances
warrant. Clients that subclass this class should consider registering
an appropriate ElementDelta.Factory
in the model context.
Subclasses that introduce new fields should consider extending
the copyFrom_
method.
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
Builds a tree ofElementDelta
objects based on elementary changes.static interface
Represents a factory for creating instances ofElementDelta
. -
Constructor Summary
ConstructorDescriptionElementDelta
(IElement element) Constructs an initially empty delta for the given element. -
Method Summary
Modifier and TypeMethodDescriptionprotected void
addAffectedChild_
(ElementDelta child) Adds the given delta as an affected child of this delta if permitted by the current state of this delta.protected void
addResourceDelta_
(org.eclipse.core.resources.IResourceDelta resourceDelta) Adds the given resource delta to the collection of resource deltas of this delta if permitted by the current state of this delta.protected void
copyFrom_
(ElementDelta delta, boolean init) Copies data from the given delta to this delta; the given delta is not modified in any way.final ElementDelta
findDelta_
(IElement element) Finds and returns the delta for the given element in this delta subtree (subtree root included), ornull
if no such delta can be found.final ElementDelta[]
Returns element deltas for the immediate children that have been added.final ElementDelta[]
Returns element deltas for all affected (added, removed, or changed) immediate children.final ElementDelta[]
Returns element deltas for the immediate children that have been changed.final IElement
Returns the element that this delta describes a change to.final long
Returns flags which describe in more detail how an element has changed.final int
getKind_()
Returns the kind of this element delta.final org.eclipse.core.resources.IMarkerDelta[]
Returns the changes to markers on the corresponding resource of this delta's element.final IElement
Returns an element describing this delta's element before it was moved to its current location, ornull
if theF_MOVED_FROM
change flag is not set.final IElement
Returns an element describing this delta's element in its new location, ornull
if theF_MOVED_TO
change flag is not set.final ElementDelta[]
Returns element deltas for the immediate children that have been removed.final org.eclipse.core.resources.IResourceDelta[]
Returns the changes to children of the element's corresponding resource that cannot be described in terms of element deltas.protected void
insertSubTree_
(ElementDelta delta) Based on the given delta, creates a delta tree that can be directly parented by this delta andadds
the created tree as an affected child of this delta.protected void
mergeWith_
(ElementDelta delta) Merges this delta with the given delta; the given delta is not modified in any way.protected boolean
Returns whether an index needs to be used for child lookup.protected ElementDelta
Returns a new, initially empty delta for the given element.protected void
setAffectedChildren_
(ElementDelta[] children) Sets the affected children for this delta.protected void
setFlags_
(long flags) Sets the flags for this delta.protected void
setKind_
(int kind) Sets the kind of this delta.protected void
setMarkerDeltas_
(org.eclipse.core.resources.IMarkerDelta[] markerDeltas) Sets the marker deltas for this delta.protected void
setMovedFromElement_
(IElement movedFromElement) Sets an element describing this delta's element before it was moved to its current location.protected void
setMovedToElement_
(IElement movedToElement) Sets an element describing this delta's element in its new location.protected void
setResourceDeltas_
(org.eclipse.core.resources.IResourceDelta[] resourceDeltas) Sets the resource deltas for this delta.toString()
Returns a string representation of this element delta in a form suitable for debugging purposes.protected void
toStringChildren_
(StringBuilder builder, IContext context) protected boolean
toStringFlags_
(StringBuilder builder, IContext context) Appends a string representation for this delta's flags to the given string builder.protected void
toStringKind_
(StringBuilder builder, IContext context) protected void
toStringResourceDeltas_
(StringBuilder builder, IContext context) Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.eclipse.handly.model.impl.IElementDeltaImpl
isEmpty_
-
Constructor Details
-
ElementDelta
Constructs an initially empty delta for the given element.- Parameters:
element
- notnull
- See Also:
-
-
Method Details
-
getElement_
Description copied from interface:IElementDeltaImpl
Returns the element that this delta describes a change to.- Specified by:
getElement_
in interfaceIElementDeltaImpl
- Returns:
- the element that this delta describes a change to
(never
null
)
-
getKind_
public final int getKind_()Description copied from interface:IElementDeltaImpl
Returns the kind of this element delta. Normally, one ofADDED
,REMOVED
, orCHANGED
. ReturnsNO_CHANGE
if, and only if, the delta is empty.- Specified by:
getKind_
in interfaceIElementDeltaImpl
- Returns:
- the kind of this element delta
-
getFlags_
public final long getFlags_()Description copied from interface:IElementDeltaImpl
Returns flags which describe in more detail how an element has changed. Such flags should be tested using the&
operator. For example:if ((flags & F_CONTENT) != 0) // a content change
Some change flags make sense for most models and are predefined in
IElementDeltaConstants
, while others are model-specific and are defined by the model implementor. The range for model-specific change flags starts from1L << 32
and includes the upper 32 bits of thelong
value. The lower 32 bits are reserved for predefined generic change flags.Move operations are indicated by special change flags. If an element is moved from A to B (with no other changes to A or B), then A will have kind
REMOVED
, with flagF_MOVED_TO
, andIElementDeltaImpl.getMovedToElement_()
on A will return the handle for B. B will have kindADDED
, with flagF_MOVED_FROM
, andIElementDeltaImpl.getMovedFromElement_()
on B will return the handle for A. (Note that the handle for A in this case represents an element that no longer exists.)- Specified by:
getFlags_
in interfaceIElementDeltaImpl
- Returns:
- flags that describe how an element has changed
-
findDelta_
Description copied from interface:IElementDeltaImpl
Finds and returns the delta for the given element in this delta subtree (subtree root included), ornull
if no such delta can be found.This is a convenience method to avoid manual traversal of the delta tree in cases where the listener is only interested in changes to particular elements. Calling this method will generally be faster than manually traversing the delta to a particular descendant.
- Specified by:
findDelta_
in interfaceIElementDeltaImpl
- Parameters:
element
- the element of the desired delta (may benull
, in which casenull
will be returned)- Returns:
- the delta for the given element, or
null
if no such delta can be found
-
getAffectedChildren_
Returns element deltas for all affected (added, removed, or changed) immediate children.This implementation returns an array of exactly the same runtime type as the array given in the most recent call to
setAffectedChildren_
.- Specified by:
getAffectedChildren_
in interfaceIElementDeltaImpl
- Returns:
- element deltas for all affected immediate children
(never
null
). Clients must not modify the returned array.
-
getAddedChildren_
Returns element deltas for the immediate children that have been added.This implementation returns an array of exactly the same runtime type as the array given in the most recent call to
setAffectedChildren_
.- Specified by:
getAddedChildren_
in interfaceIElementDeltaImpl
- Returns:
- element deltas for the immediate children that have been added
(never
null
). Clients must not modify the returned array.
-
getRemovedChildren_
Returns element deltas for the immediate children that have been removed.This implementation returns an array of exactly the same runtime type as the array given in the most recent call to
setAffectedChildren_
.- Specified by:
getRemovedChildren_
in interfaceIElementDeltaImpl
- Returns:
- element deltas for the immediate children that have been removed
(never
null
). Clients must not modify the returned array.
-
getChangedChildren_
Returns element deltas for the immediate children that have been changed.This implementation returns an array of exactly the same runtime type as the array given in the most recent call to
setAffectedChildren_
.- Specified by:
getChangedChildren_
in interfaceIElementDeltaImpl
- Returns:
- element deltas for the immediate children that have been changed
(never
null
). Clients must not modify the returned array.
-
getMovedFromElement_
Description copied from interface:IElementDeltaImpl
Returns an element describing this delta's element before it was moved to its current location, ornull
if theF_MOVED_FROM
change flag is not set.- Specified by:
getMovedFromElement_
in interfaceIElementDeltaImpl
- Returns:
- an element describing this delta's element before it was moved
to its current location, or
null
if theF_MOVED_FROM
change flag is not set - See Also:
-
getMovedToElement_
Description copied from interface:IElementDeltaImpl
Returns an element describing this delta's element in its new location, ornull
if theF_MOVED_TO
change flag is not set.- Specified by:
getMovedToElement_
in interfaceIElementDeltaImpl
- Returns:
- an element describing this delta's element in its new location,
or
null
if theF_MOVED_TO
change flag is not set - See Also:
-
getMarkerDeltas_
public final org.eclipse.core.resources.IMarkerDelta[] getMarkerDeltas_()Description copied from interface:IElementDeltaImpl
Returns the changes to markers on the corresponding resource of this delta's element.Returns
null
if no markers changed. Note that this is an exception to the general convention of returning an empty array rather thannull
. This makes the method safe to call even whenorg.eclipse.core.resources
bundle is not available.Note that marker deltas, like element deltas, are generally only valid for the dynamic scope of change notification. Clients must not hang on to these objects.
- Specified by:
getMarkerDeltas_
in interfaceIElementDeltaImpl
- Returns:
- the marker deltas, or
null
if none. Clients must not modify the returned array.
-
getResourceDeltas_
public final org.eclipse.core.resources.IResourceDelta[] getResourceDeltas_()Description copied from interface:IElementDeltaImpl
Returns the changes to children of the element's corresponding resource that cannot be described in terms of element deltas.Returns
null
if there were no such changes. Note that this is an exception to the general convention of returning an empty array rather thannull
. This makes the method safe to call even whenorg.eclipse.core.resources
bundle is not available.Note that resource deltas, like element deltas, are generally only valid for the dynamic scope of change notification. Clients must not hang on to these objects.
- Specified by:
getResourceDeltas_
in interfaceIElementDeltaImpl
- Returns:
- the resource deltas, or
null
if none. Clients must not modify the returned array.
-
toString
-
toString_
Description copied from interface:IElementDeltaImpl
Returns a string representation of this element delta in a form suitable for debugging purposes. Clients can influence the result with format options specified in the given context; unrecognized options are ignored and an empty context is permitted.Implementations are encouraged to support common options defined in
ToStringOptions
and interpret theFORMAT_STYLE
as follows:- Specified by:
toString_
in interfaceIElementDeltaImpl
- Parameters:
context
- notnull
- Returns:
- a string representation of this element delta
(never
null
)
-
toStringChildren_
-
toStringResourceDeltas_
-
toStringKind_
-
toStringFlags_
Appends a string representation for this delta's flags to the given string builder.- Parameters:
builder
- a string builder to append the delta flags tocontext
- notnull
- Returns:
true
if a flag was appended to the builder, andfalse
if the builder was not modified by this method- See Also:
-
newDelta_
Returns a new, initially empty delta for the given element.This implementation uses
ElementDelta.Factory
registered in the element's model context. If no delta factory is registered in the model context, a new instance of this class (i.e.,ElementDelta
) is returned.- Parameters:
element
- notnull
- Returns:
- a new, initially empty delta for the given element
(never
null
)
-
needsChildIndex_
protected boolean needsChildIndex_()Returns whether an index needs to be used for child lookup.- Returns:
true
if the child index needs to be used, andfalse
otherwise
-
setKind_
protected void setKind_(int kind) Sets the kind of this delta.This is a low-level mutator method. In particular, it is the caller's responsibility to ensure validity of the given value.
- Parameters:
kind
- the delta kind- See Also:
-
setFlags_
protected void setFlags_(long flags) Sets the flags for this delta.This is a low-level mutator method. In particular, it is the caller's responsibility to ensure validity of the given value.
- Parameters:
flags
- the delta flags- See Also:
-
setMovedFromElement_
Sets an element describing this delta's element before it was moved to its current location.This is a low-level mutator method. In particular, it is the caller's responsibility to set appropriate kind and flags for this delta.
- Parameters:
movedFromElement
- an element describing this delta's element before it was moved to its current location- See Also:
-
setMovedToElement_
Sets an element describing this delta's element in its new location.This is a low-level mutator method. In particular, it is the caller's responsibility to set appropriate kind and flags for this delta.
- Parameters:
movedToElement
- an element describing this delta's element in its new location- See Also:
-
setMarkerDeltas_
protected void setMarkerDeltas_(org.eclipse.core.resources.IMarkerDelta[] markerDeltas) Sets the marker deltas for this delta. Clients must not modify the given array afterwards.This is a low-level mutator method. In particular, it is the caller's responsibility to set appropriate kind and flags for this delta.
- Parameters:
markerDeltas
- the marker deltas- See Also:
-
setResourceDeltas_
protected void setResourceDeltas_(org.eclipse.core.resources.IResourceDelta[] resourceDeltas) Sets the resource deltas for this delta. Clients must not modify the given array afterwards.This is a low-level mutator method. In particular, it is the caller's responsibility to set appropriate kind and flags for this delta.
- Parameters:
resourceDeltas
- the resource deltas- See Also:
-
addResourceDelta_
protected void addResourceDelta_(org.eclipse.core.resources.IResourceDelta resourceDelta) Adds the given resource delta to the collection of resource deltas of this delta if permitted by the current state of this delta. Note that in contrast tosetResourceDeltas_
, this method can change this delta's kind and flags as appropriate.If the kind of this delta is
ADDED
orREMOVED
, this implementation returns without adding the given resource delta; otherwise, it sets the kind of this delta toCHANGED
and adds theF_CONTENT
change flag.- Parameters:
resourceDelta
- the resource delta to add (notnull
)- See Also:
-
insertSubTree_
Based on the given delta, creates a delta tree that can be directly parented by this delta andadds
the created tree as an affected child of this delta.Note that after calling
insertSubTree_(delta)
there is no guarantee thatfindDelta_(d.getElement_()) == d
or even that
findDelta_(d.getElement_()) != null
for any delta
d
in the subtreedelta
(subtree root included). For example, if this delta tree already contains a delta ford.getElement_()
, that delta will bemerged
withd
, which may even result in a logically empty delta, i.e., no delta for the element.- Parameters:
delta
- the delta to insert (notnull
)- Throws:
IllegalArgumentException
- if the given delta cannot be rooted in this delta
-
addAffectedChild_
Adds the given delta as an affected child of this delta if permitted by the current state of this delta. If this delta already contains a child delta for the same element as the given delta,merges
the existing child delta with the given delta. Note that in contrast tosetAffectedChildren_
, this method can change this delta's kind and flags as appropriate.It is the caller's responsibility to ensure that the given delta can be directly parented by this delta.
Note that after calling
addAffectedChild_(delta)
there is no guarantee thatfindDelta_(d.getElement_()) == d
or even that
findDelta_(d.getElement_()) != null
for any delta
d
in the subtreedelta
(subtree root included).If the kind of this delta is
ADDED
orREMOVED
, this implementation returns without adding the given delta; otherwise, it sets the kind of this delta toCHANGED
and adds theF_CHILDREN
change flag and, if this delta's element is anISourceElement
, theF_FINE_GRAINED
change flag.- Parameters:
child
- the delta to add as an affected child (notnull
)- See Also:
-
mergeWith_
Merges this delta with the given delta; the given delta is not modified in any way.It is the caller's responsibility to ensure that the given delta pertains to the same element as this delta.
This implementation implements merge semantics in terms of calls to
copyFrom_
.- Parameters:
delta
- the delta to merge with (notnull
)
-
copyFrom_
Copies data from the given delta to this delta; the given delta is not modified in any way.It is the caller's responsibility to ensure that the given delta pertains to the same element as this delta.
Subclasses that introduce new fields should consider extending this method.
- Parameters:
delta
- the delta to copy data from (notnull
)init
-true
if this delta needs to be completely (re-)initialized with data from the given delta;false
if this delta needs to be augmented with data from the given delta
-
setAffectedChildren_
Sets the affected children for this delta. Clients must not modify the given array afterwards.This is a low-level mutator method. In particular, it is the caller's responsibility to set appropriate kind and flags for this delta.
- Parameters:
children
- the affected children (notnull
)- See Also:
-