Bug 323189 - [Markers] NPE from MarkerContentGenerator if "absolute" id is used in marker definition
Summary: [Markers] NPE from MarkerContentGenerator if "absolute" id is used in marker ...
Status: NEW
Alias: None
Product: Platform
Classification: Eclipse Project
Component: UI (show other bugs)
Version: 4.0   Edit
Hardware: PC Linux
: P3 enhancement (vote)
Target Milestone: ---   Edit
Assignee: Platform UI Triaged CLA
QA Contact:
URL:
Whiteboard:
Keywords:
Depends on:
Blocks:
 
Reported: 2010-08-19 15:49 EDT by Miwako Tokugawa CLA
Modified: 2019-09-06 16:18 EDT (History)
0 users

See Also:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
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.