Package org.eclipse.jface.text.rules
Class DefaultDamagerRepairer
java.lang.Object
org.eclipse.jface.text.rules.DefaultDamagerRepairer
- All Implemented Interfaces:
IPresentationDamager
,IPresentationRepairer
- Direct Known Subclasses:
RuleBasedDamagerRepairer
public class DefaultDamagerRepairer
extends Object
implements IPresentationDamager, IPresentationRepairer
A standard implementation of a syntax driven presentation damager
and presentation repairer. It uses a token scanner to scan
the document and to determine its damage and new text presentation.
The tokens returned by the scanner are supposed to return text attributes
as their data.
- Since:
- 2.0
- See Also:
-
Field Summary
Modifier and TypeFieldDescriptionprotected TextAttribute
The default text attribute if non is returned as data by the current tokenprotected IDocument
The document this object works onprotected ITokenScanner
The scanner it uses -
Constructor Summary
ConstructorDescriptionDefaultDamagerRepairer
(ITokenScanner scanner) Creates a damager/repairer that uses the given scanner.DefaultDamagerRepairer
(ITokenScanner scanner, TextAttribute defaultTextAttribute) Deprecated.use DefaultDamagerRepairer(ITokenScanner) instead -
Method Summary
Modifier and TypeMethodDescriptionprotected void
addRange
(TextPresentation presentation, int offset, int length, TextAttribute attr) Adds style information to the given text presentation.void
createPresentation
(TextPresentation presentation, ITypedRegion region) Fills the given presentation with the style ranges which when applied to the presentation reconciler's text viewer repair the presentation damage described by the given region.protected int
endOfLineOf
(int offset) Returns the end offset of the line that contains the specified offset or if the offset is inside a line delimiter, the end offset of the next line.getDamageRegion
(ITypedRegion partition, DocumentEvent e, boolean documentPartitioningChanged) Returns the damage in the document's presentation caused by the given document change.protected TextAttribute
getTokenTextAttribute
(IToken token) Returns a text attribute encoded in the given token.void
setDocument
(IDocument document) Tells the presentation damager on which document it will work.
-
Field Details
-
fDocument
The document this object works on -
fScanner
The scanner it uses -
fDefaultTextAttribute
The default text attribute if non is returned as data by the current token
-
-
Constructor Details
-
DefaultDamagerRepairer
@Deprecated public DefaultDamagerRepairer(ITokenScanner scanner, TextAttribute defaultTextAttribute) Deprecated.use DefaultDamagerRepairer(ITokenScanner) insteadCreates a damager/repairer that uses the given scanner and returns the given default text attribute if the current token does not carry a text attribute.- Parameters:
scanner
- the token scanner to be useddefaultTextAttribute
- the text attribute to be returned if non is specified by the current token, may not benull
-
DefaultDamagerRepairer
Creates a damager/repairer that uses the given scanner. The scanner may not benull
and is assumed to return only token that carry text attributes.- Parameters:
scanner
- the token scanner to be used, may not benull
-
-
Method Details
-
setDocument
Description copied from interface:IPresentationDamager
Tells the presentation damager on which document it will work.- Specified by:
setDocument
in interfaceIPresentationDamager
- Specified by:
setDocument
in interfaceIPresentationRepairer
- Parameters:
document
- the damager's working document
-
endOfLineOf
Returns the end offset of the line that contains the specified offset or if the offset is inside a line delimiter, the end offset of the next line.- Parameters:
offset
- the offset whose line end offset must be computed- Returns:
- the line end offset for the given offset
- Throws:
BadLocationException
- if offset is invalid in the current document
-
getDamageRegion
public IRegion getDamageRegion(ITypedRegion partition, DocumentEvent e, boolean documentPartitioningChanged) Returns the damage in the document's presentation caused by the given document change. The damage is restricted to the specified partition for which the presentation damager is responsible. The damage may also depend on whether the document change also caused changes of the document's partitioning.This implementation damages entire lines unless clipped by the given partition.
- Specified by:
getDamageRegion
in interfaceIPresentationDamager
- Parameters:
partition
- the partition inside which the damage must be determinede
- the event describing the change whose damage must be determineddocumentPartitioningChanged
- indicates whether the given change changed the document's partitioning- Returns:
- the full lines containing the document changes described by the document event, clipped by the given partition. If there was a partitioning change then the whole partition is returned.
-
createPresentation
Description copied from interface:IPresentationRepairer
Fills the given presentation with the style ranges which when applied to the presentation reconciler's text viewer repair the presentation damage described by the given region.- Specified by:
createPresentation
in interfaceIPresentationRepairer
- Parameters:
presentation
- the text presentation to be filled by this repairerregion
- the damage to be repaired
-
getTokenTextAttribute
Returns a text attribute encoded in the given token. If the token's data is notnull
and a text attribute it is assumed that it is the encoded text attribute. It returns the default text attribute if there is no encoded text attribute found.- Parameters:
token
- the token whose text attribute is to be determined- Returns:
- the token's text attribute
-
addRange
Adds style information to the given text presentation.- Parameters:
presentation
- the text presentation to be extendedoffset
- the offset of the range to be styledlength
- the length of the range to be styledattr
- the attribute describing the style of the range to be styled
-