Some Eclipse Foundation services are deprecated, or will be soon. Please ensure you've read this important communication.

Bug 323189

Summary: [Markers] NPE from MarkerContentGenerator if "absolute" id is used in marker definition
Product: [Eclipse Project] Platform Reporter: Miwako Tokugawa <miwako.tokugawa>
Component: UIAssignee: Platform UI Triaged <platform-ui-triaged>
Status: NEW --- QA Contact:
Severity: enhancement    
Priority: P3    
Version: 4.0   
Target Milestone: ---   
Hardware: PC   
OS: Linux   
Whiteboard:

Description Miwako Tokugawa CLA 2010-08-19 15:49:40 EDT
Build Identifier: I20100603-1500

I have the following in my plugin.xml.
Everything seems to work ok.. till I refer to a non-built in (inherited) marker type in markerContentGenerator.
If I do that, I get a NPE from, and it doesn¡¦t seem to if I close the view and reopen it from Wndow->Show View.

<extension point="org.eclipse.ui.views">
        <view class="com.intel.compiler.cdt.managedbuilder.ui.GAPMarkersView"
        id="com.intel.compiler.cdt.managedbuilder.ui.GAPMarker"
        name="GAP View">
        </view>
 </extension>
<extension point="org.eclipse.core.resources.markers¡¨
        id="com.intel.compiler.cdt.managedbuilder.ui.GAPMarkerType">
        <super type="org.eclipse.core.resources.problemmarker"/>
        <super type="org.eclipse.core.resources.textmarker"/>
        <attribute name="description"/>^M
        <persistent value="true"/>
 </extension>
      <extension point="org.eclipse.ui.ide.markerSupport">
        <markerContentGenerator id="com.intel.compiler.cdt.managedbuilder.ui.GAPMarkerGenerator"
        name="dum">
<!¡Xthe following causes NPE „³
        <markerTypeReference id="com.intel.compiler.cdt.managedbuilder.ui.GAPMarkerType"/>
<!¡Xthe following doesn¡¦t „³
        <!--markerTypeReference id="org.eclipse.core.resources.problemmarker"/-->
        <markerFieldReference id="org.eclipse.ui.ide.descriptionField"/>
        </markerContentGenerator>
        </extension>


java.lang.NullPointerException
        at org.eclipse.ui.views.markers.internal.ContentGeneratorDescriptor.getMarkerTypes(ContentGeneratorDescriptor.java:223)
        at org.eclipse.ui.internal.views.markers.MarkerContentGenerator.getMarkerTypes(MarkerContentGenerator.java:717)
        at org.eclipse.ui.internal.views.markers.MarkerContentGenerator.getTypes(MarkerContentGenerator.java:726)
        at org.eclipse.ui.internal.views.markers.CachedMarkerBuilder.registerTypesToListener(CachedMarkerBuilder.java:537)
        at org.eclipse.ui.internal.views.markers.CachedMarkerBuilder.start(CachedMarkerBuilder.java:116)
        at org.eclipse.ui.internal.views.markers.ExtendedMarkersView.startView(ExtendedMarkersView.java:382)
        at org.eclipse.ui.internal.views.markers.ExtendedMarkersView.createPartControl(ExtendedMarkersView.java:366)
        at org.eclipse.ui.internal.ViewReference.createPartHelper(ViewReference.java:375)
        at org.eclipse.ui.internal.ViewReference.createPart(ViewReference.java:229)
        at org.eclipse.ui.internal.WorkbenchPartReference.getPart(WorkbenchPartReference.java:595)
        at org.eclipse.ui.internal.PartPane.setVisible(PartPane.java:313)
        at org.eclipse.ui.internal.ViewPane.setVisible(ViewPane.java:529)
        at org.eclipse.ui.internal.presentations.PresentablePart.setVisible(PresentablePart.java:180)
        at org.eclipse.ui.internal.presentations.util.PresentablePartFolder.select(PresentablePartFolder.java:270)
        at org.eclipse.ui.internal.presentations.util.LeftToRightTabOrder.select(LeftToRightTabOrder.java:65)
        at org.eclipse.ui.internal.presentations.util.TabbedStackPresentation.selectPart(TabbedStackPresentation.java:473)
        at org.eclipse.ui.internal.PartStack.refreshPresentationSelection(PartStack.java:1254)
        at org.eclipse.ui.internal.PartStack.setSelection(PartStack.java:1207)
        at org.eclipse.ui.internal.PartStack.presentationSelectionChanged(PartStack.java:841)
        at org.eclipse.ui.internal.PartStack.access$1(PartStack.java:827)
        at org.eclipse.ui.internal.PartStack$1.selectPart(PartStack.java:137)
        at org.eclipse.ui.internal.presentations.util.TabbedStackPresentation$1.handleEvent(TabbedStackPresentation.java:133)
        at org.eclipse.ui.internal.presentations.util.AbstractTabFolder.fireEvent(AbstractTabFolder.java:269)
        at org.eclipse.ui.internal.presentations.util.AbstractTabFolder.fireEvent(AbstractTabFolder.java:278)
        at org.eclipse.ui.internal.presentations.defaultpresentation.DefaultTabFolder.access$1(DefaultTabFolder.java:1)
        at org.eclipse.ui.internal.presentations.defaultpresentation.DefaultTabFolder$2.handleEvent(DefaultTabFolder.java:88)
        at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
        at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1258)
        at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1282)
        at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1267)
        at org.eclipse.swt.widgets.Widget.notifyListeners(Widget.java:1061)
        at org.eclipse.swt.custom.CTabFolder.setSelection(CTabFolder.java:2743)
        at org.eclipse.swt.custom.CTabFolder.onMouse(CTabFolder.java:1429)
        at org.eclipse.swt.custom.CTabFolder$1.handleEvent(CTabFolder.java:257)
        at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
        at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1258)
        at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3552)
        at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3171)
        at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2629)
        at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2593)
        at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2427)
        at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:670)
        at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
        at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:663)
        at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
        at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:115)
        at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
        at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
        at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
        at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:369)
        at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
        at java.lang.reflect.Method.invoke(Unknown Source)
        at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:619)
        at org.eclipse.equinox.launcher.Main.basicRun(Main.java:574)


Reproducible: Always
Comment 1 Miwako Tokugawa CLA 2010-08-21 00:45:18 EDT
Sorry I should have mentioned this plugin.xml belongs to
com.intel.compiler.cdt.managedbuilder.ui.

And, it seems that this problem is resolved if I use 
"id=GAPMarkerType"
instead of
id="com.intel.compiler.cdt.managedbuilder.ui.GAPMarkerType"
in the marker definition.
<extension point="org.eclipse.core.resources.markers¡¨
        id="com.intel.compiler.cdt.managedbuilder.ui.GAPMarkerType">
        <super type="org.eclipse.core.resources.problemmarker"/>
        <super type="org.eclipse.core.resources.textmarker"/>
        <attribute name="description"/>^M
        <persistent value="true"/>
 </extension>

I'm keeping this open in case someone wants to add to the documentation that you don't need the "whole name" in the definition ID.
Comment 2 Miwako Tokugawa CLA 2010-08-24 17:19:18 EDT
Slight correction.
<attribute name="description"/>^M
shouldn't be there
Comment 3 Eclipse Webmaster CLA 2019-09-06 16:18:35 EDT
This bug hasn't had any activity in quite some time. Maybe the problem got resolved, was a duplicate of something else, or became less pressing for some reason - or maybe it's still relevant but just hasn't been looked at yet.

If you have further information on the current state of the bug, please add it. The information can be, for example, that the problem still occurs, that you still want the feature, that more information is needed, or that the bug is (for whatever reason) no longer relevant.