-->

NPE在HandledContributionItem.canExecuteItem(NPE in

2019-09-30 18:11发布

我有这个与贡献plugin.xml的工具栏小编辑:

public class MyEditor extends EditorPart {

    public static final String ID = "org.acme.project.MyEditor";

    @Override
    public void init(IEditorSite site, IEditorInput input) throws PartInitException {
        setSite(site);
        setInput(input);
    }

    @Override
    public void createPartControl(Composite parent) {
        final ToolBarManager localToolBarmanager = new ToolBarManager();
        final IMenuService menuService = PlatformUI.getWorkbench().getService(IMenuService.class);
        menuService.populateContributionManager(localToolBarmanager, "toolbar:org.acme.menu");
        localToolBarmanager.createControl(parent);

    }
}

当然,我的plugin.xml有贡献:

<extension point="org.eclipse.ui.menus">
  <menuContribution allPopups="false" locationURI="toolbar:org.acme.menu">
        <command commandId="org.eclipse.ui.file.saveAll" style="push" />
    </menuContribution>
</extension>

编辑器中打开,工具栏被促成,一切都很好。 当我关闭,这是积极的工作台部分,当我打开编辑器,我得到以下异常:

!ENTRY org.eclipse.e4.ui.workbench.renderers.swt 4 2 2017-10-30 15:12:53.110
!MESSAGE Problems occurred when invoking code from plug-in: "org.eclipse.e4.ui.workbench.renderers.swt".
!STACK 0
java.lang.NullPointerException
    at org.eclipse.e4.ui.workbench.renderers.swt.HandledContributionItem.canExecuteItem(HandledContributionItem.java:443)
    at org.eclipse.e4.ui.workbench.renderers.swt.AbstractContributionItem$4.run(AbstractContributionItem.java:524)
    at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
    at org.eclipse.e4.ui.workbench.renderers.swt.AbstractContributionItem.updateItemEnablement(AbstractContributionItem.java:564)
    at org.eclipse.e4.ui.workbench.renderers.swt.ToolItemUpdater.updateContributionItems(ToolItemUpdater.java:36)
    at org.eclipse.e4.ui.workbench.renderers.swt.ToolBarManagerRenderer.subscribeTopicUpdateToolbarEnablement(ToolBarManagerRenderer.java:295)
    at sun.reflect.GeneratedMethodAccessor32.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.eclipse.e4.core.internal.di.MethodRequestor.execute(MethodRequestor.java:55)
    at org.eclipse.e4.ui.internal.di.UIEventObjectSupplier$UIEventHandler$1.run(UIEventObjectSupplier.java:56)
    at org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35)
    at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:182)
    at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:4211)
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3827)

这真的只是获得焦点的一个组成部分。 我可以关闭其他地方就好了。 此异常导致处理工具栏被打破和工具栏不再工作。

我发现了一些错误与例外: 错误388516 & 错误394500

但这些所谓固定在4.2(我们使用的是4.6)。 其他然后,我无法找到任何可能导致这样奇怪的错误信息。

有没有人有一个想法如何解决我们的工具栏?

Answer 1:

那是愚蠢的错误E4之一。 大概前3我们。

WorkbenchMenuService.populateContributionManager(ContributionManager, String)取当前活动工作台部分进行注册,以便菜单。 由于工具栏在通常创建IWorkbenchPart.createPartControl(Composite) ,这意味着新的部分还没有完全建立,所以还不是积极参与。

所以,工具栏没有为所有的视图和编辑工作了!

我发现了一个解决方法(即真难看,但你会怎样做?)来解决这个巨大的E4错误。 要将呼叫populateContributionManager必须与以下行来代替:

    final MPart part = getSite().getService(MPart.class);
    String menuLocation = "toolbar:org.acme.menu";

    if (menuService instanceof WorkbenchMenuService) {
        ((WorkbenchMenuService) menuService).populateContributionManager(part, manager, menuLocation);
    } else if (menuService instanceof SlaveMenuService) {
        ((SlaveMenuService) menuService).populateContributionManager(part, manager, menuLocation);
    } else
        throw new UnsupportedOperationException("Do not know how to handle " + menuService); //$NON-NLS-1$


文章来源: NPE in HandledContributionItem.canExecuteItem