public abstract class RelatedItemLineMarkerProvider extends LineMarkerProviderDescriptor
codeInsight.lineMarkerProvider
extension to provide both line marker and
'Go to related symbol' targets.GutterIconDescriptor.Option
Constructor and Description |
---|
RelatedItemLineMarkerProvider() |
Modifier and Type | Method and Description |
---|---|
void |
collectNavigationMarkers(java.util.List<? extends PsiElement> elements,
java.util.Collection<? super RelatedItemLineMarkerInfo<?>> result,
boolean forNavigation) |
protected void |
collectNavigationMarkers(PsiElement element,
java.util.Collection<? super RelatedItemLineMarkerInfo<?>> result) |
void |
collectSlowLineMarkers(java.util.List<? extends PsiElement> elements,
java.util.Collection<? super LineMarkerInfo<?>> result) |
RelatedItemLineMarkerInfo<?> |
getLineMarkerInfo(PsiElement element)
Get line markers for this PsiElement.
|
java.lang.String |
getName()
Human-readable provider name for UI.
|
getIcon, getId, getOptions, isEnabledByDefault, toString
public RelatedItemLineMarkerInfo<?> getLineMarkerInfo(PsiElement element)
LineMarkerProvider
PsiMethod
,
create the marker for the PsiIdentifier
which is a name of this method.
More technical details:Highlighting (specifically, LineMarkersPass) queries all LineMarkerProviders in two passes (for performance reasons):
LineMarkerProvider
which (incorrectly) written like this:
class MyBadLineMarkerProvider implements LineMarkerProvider {
public LineMarkerInfo getLineMarkerInfo(PsiElement element) {
if (element instanceof PsiMethod) { // ACTUALLY DONT!
return new LineMarkerInfo(element, element.getTextRange(), icon, null,null, alignment);
}
else {
return null;
}
}
...
}
Note that it create LineMarkerInfo for the whole method body.
Following will happen when this method is half-visible (e.g. its name is visible but a part of its body isn't):
class MyGoodLineMarkerProvider implements LineMarkerProvider {
public LineMarkerInfo getLineMarkerInfo(PsiElement element) {
if (element instanceof PsiIdentifier &&
(parent = element.getParent()) instanceof PsiMethod &&
((PsiMethod)parent).getMethodIdentifier() == element)) { // aha, we are at method name
return new LineMarkerInfo(element, element.getTextRange(), icon, null,null, alignment);
}
else {
return null;
}
}
...
}
public final void collectSlowLineMarkers(java.util.List<? extends PsiElement> elements, java.util.Collection<? super LineMarkerInfo<?>> result)
public void collectNavigationMarkers(java.util.List<? extends PsiElement> elements, java.util.Collection<? super RelatedItemLineMarkerInfo<?>> result, boolean forNavigation)
protected void collectNavigationMarkers(PsiElement element, java.util.Collection<? super RelatedItemLineMarkerInfo<?>> result)
public java.lang.String getName()
GutterIconDescriptor
getName
in class GutterIconDescriptor