use of org.eclipse.jface.text.source.IAnnotationModel in project eclipse.platform.text by eclipse.
the class SelectMarkerRulerAction method gotoMarker.
private void gotoMarker(IMarker marker) {
// Use the provided adapter if any
IGotoMarker gotoMarkerAdapter = fTextEditor.getAdapter(IGotoMarker.class);
if (gotoMarkerAdapter != null) {
gotoMarkerAdapter.gotoMarker(marker);
return;
}
int start = MarkerUtilities.getCharStart(marker);
int end = MarkerUtilities.getCharEnd(marker);
boolean selectLine = start < 0 || end < 0;
IDocumentProvider documentProvider = fTextEditor.getDocumentProvider();
IEditorInput editorInput = fTextEditor.getEditorInput();
// look up the current range of the marker when the document has been edited
IAnnotationModel model = documentProvider.getAnnotationModel(editorInput);
if (model instanceof AbstractMarkerAnnotationModel) {
AbstractMarkerAnnotationModel markerModel = (AbstractMarkerAnnotationModel) model;
Position pos = markerModel.getMarkerPosition(marker);
if (pos != null && !pos.isDeleted()) {
// use position instead of marker values
start = pos.getOffset();
end = pos.getOffset() + pos.getLength();
}
if (pos != null && pos.isDeleted()) {
// do nothing if position has been deleted
return;
}
}
IDocument document = documentProvider.getDocument(editorInput);
if (selectLine) {
int line;
try {
if (start >= 0)
line = document.getLineOfOffset(start);
else {
line = MarkerUtilities.getLineNumber(marker);
// Marker line numbers are 1-based
--line;
}
end = start + document.getLineLength(line) - 1;
} catch (BadLocationException e) {
return;
}
}
int length = document.getLength();
if (end - 1 < length && start < length)
fTextEditor.selectAndReveal(start, end - start);
}
use of org.eclipse.jface.text.source.IAnnotationModel in project eclipse.platform.text by eclipse.
the class SpellingCorrectionProcessor method computeQuickAssistProposals.
/*
* @see IContentAssistProcessor#computeCompletionProposals(ITextViewer, int)
*/
@Override
public ICompletionProposal[] computeQuickAssistProposals(IQuickAssistInvocationContext quickAssistContext) {
ISourceViewer viewer = quickAssistContext.getSourceViewer();
int documentOffset = quickAssistContext.getOffset();
int length = viewer != null ? viewer.getSelectedRange().y : -1;
TextInvocationContext context = new TextInvocationContext(viewer, documentOffset, length);
IAnnotationModel model = viewer.getAnnotationModel();
if (model == null)
return fgNoSuggestionsProposal;
List<ICompletionProposal> proposals = computeProposals(context, model);
if (proposals.isEmpty())
return fgNoSuggestionsProposal;
return proposals.toArray(new ICompletionProposal[proposals.size()]);
}
use of org.eclipse.jface.text.source.IAnnotationModel in project eclipse.platform.text by eclipse.
the class SpellingProblem method removeAllInActiveEditor.
/**
* Removes all spelling problems that are reported
* for the given <code>word</code> in the active editor.
* <p>
* <em>This a workaround to fix bug https://bugs.eclipse.org/bugs/show_bug.cgi?id=134338
* for 3.2 at the time where spelling still resides in JDT Text.
* Once we move the spell check engine along with its quick fixes
* down to Platform Text we need to provide the proposals with
* a way to access the annotation model.</em>
* </p>
*
* @param editor the text editor, if <code>null</code> this method does nothing
* @param word the word for which to remove the problems or <code>null</code> to remove all
* @since 3.3
* @deprecated As of 3.4, replaced by {@link #removeAll(ISourceViewer, String)}
*/
@Deprecated
public static void removeAllInActiveEditor(ITextEditor editor, String word) {
if (editor == null)
return;
IDocumentProvider documentProvider = editor.getDocumentProvider();
if (documentProvider == null)
return;
IEditorInput editorInput = editor.getEditorInput();
if (editorInput == null)
return;
IAnnotationModel model = documentProvider.getAnnotationModel(editorInput);
if (model == null)
return;
IDocument document = documentProvider.getDocument(editorInput);
if (document == null)
return;
boolean supportsBatchReplace = (model instanceof IAnnotationModelExtension);
List<Annotation> toBeRemovedAnnotations = new ArrayList<>();
Iterator<Annotation> iter = model.getAnnotationIterator();
while (iter.hasNext()) {
Annotation annotation = iter.next();
if (SpellingAnnotation.TYPE.equals(annotation.getType())) {
boolean doRemove = word == null;
if (word == null)
doRemove = true;
else {
String annotationWord = null;
Position pos = model.getPosition(annotation);
try {
annotationWord = document.get(pos.getOffset(), pos.getLength());
} catch (BadLocationException e) {
continue;
}
doRemove = word.equals(annotationWord);
}
if (doRemove) {
if (supportsBatchReplace)
toBeRemovedAnnotations.add(annotation);
else
model.removeAnnotation(annotation);
}
}
}
if (supportsBatchReplace && !toBeRemovedAnnotations.isEmpty()) {
Annotation[] annotationArray = toBeRemovedAnnotations.toArray(new Annotation[toBeRemovedAnnotations.size()]);
((IAnnotationModelExtension) model).replaceAnnotations(annotationArray, null);
}
}
use of org.eclipse.jface.text.source.IAnnotationModel in project eclipse.platform.text by eclipse.
the class HighlightTest method checkHighlightForCaretOffset.
private void checkHighlightForCaretOffset(int pos, String expectedHighlight, int expectedHighlightCount) throws Exception {
clearAnnotations();
editor.selectAndReveal(pos, 0);
waitForAnnotations(expectedHighlightCount);
List<Annotation> annotations = getAnnotationsFromAnnotationModel();
IAnnotationModel annotationModel = getAnnotationModel();
IDocument document = editor.getDocumentProvider().getDocument(editor.getEditorInput());
for (int i = 0; i < annotations.size(); i++) {
Annotation annotation = annotations.get(i);
Position position = annotationModel.getPosition(annotation);
String highlight = document.get(position.offset, position.length);
assertEquals("Wrong highlight " + i + " at position " + position.offset, expectedHighlight, highlight);
}
Assert.assertEquals("Wrong number of highlights", expectedHighlightCount, annotations.size());
}
use of org.eclipse.jface.text.source.IAnnotationModel in project eclipse.platform.text by eclipse.
the class DefaultWordHighlightStrategy method applyHighlights.
private void applyHighlights(int offset) {
if (sourceViewer == null || !enabled) {
removeOccurrenceAnnotations();
return;
}
String text = document.get();
offset = ((ITextViewerExtension5) sourceViewer).widgetOffset2ModelOffset(offset);
String word = findCurrentWord(text, offset);
if (word == null) {
removeOccurrenceAnnotations();
return;
}
Matcher m = WORD_PATTERN.matcher(text);
Map<Annotation, Position> annotationMap = new HashMap<>();
while (m.find()) {
if (m.group().equals(word)) {
annotationMap.put(new Annotation(ANNOTATION_TYPE, false, NLS.bind(Messages.DefaultWordHighlightStrategy_OccurrencesOf, word)), new Position(m.start(), m.end() - m.start()));
}
}
if (annotationMap.size() < 2) {
removeOccurrenceAnnotations();
return;
}
IAnnotationModel annotationModel = sourceViewer.getAnnotationModel();
synchronized (getLockObject(annotationModel)) {
if (annotationModel instanceof IAnnotationModelExtension) {
((IAnnotationModelExtension) annotationModel).replaceAnnotations(fOccurrenceAnnotations, annotationMap);
} else {
removeOccurrenceAnnotations();
Iterator<Entry<Annotation, Position>> iter = annotationMap.entrySet().iterator();
while (iter.hasNext()) {
Entry<Annotation, Position> mapEntry = iter.next();
annotationModel.addAnnotation(mapEntry.getKey(), mapEntry.getValue());
}
}
fOccurrenceAnnotations = annotationMap.keySet().toArray(new Annotation[annotationMap.keySet().size()]);
}
}
Aggregations