изключение при завършване на персонализиран съветник за нов файл в RCP проект

Работя с персонализиран „съветник за нов файл“. когато натисна бутона за завършване, очаквам eclipse да добави нов файл и да го покаже правилно, но вместо това възниква изключение и не мога да отворя създадения файл. Но ако използвам този съветник за втори път, изключението не се появява и файлът се отваря правилно. защо?

изключението възниква, когато този ред getContainer().run(true, false, op) се изпълни.

и е част от изключението:

!ENTRY org.eclipse.e4.ui.workbench 4 0 2012-07-28 16:15:01.239
!MESSAGE Unable to create class 'org.eclipse.ui.internal.e4.compatibility.CompatibilityEditor' from bundle '33'
!STACK 0
org.eclipse.e4.core.di.InjectionException: java.lang.IllegalArgumentException: can't find IDfind.ext
    at org.eclipse.e4.core.internal.di.MethodRequestor.execute(MethodRequestor.java:63)
    at org.eclipse.e4.core.internal.di.InjectorImpl.processAnnotated(InjectorImpl.java:857)
    at org.eclipse.e4.core.internal.di.InjectorImpl.processAnnotated(InjectorImpl.java:837)
    at org.eclipse.e4.core.internal.di.InjectorImpl.inject(InjectorImpl.java:111)
    at org.eclipse.e4.core.internal.di.InjectorImpl.internalMake(InjectorImpl.java:318)
    at org.eclipse.e4.core.internal.di.InjectorImpl.make(InjectorImpl.java:240)
    at org.eclipse.e4.core.contexts.ContextInjectionFactory.make(ContextInjectionFactory.java:161)
    at org.eclipse.e4.ui.internal.workbench.ReflectionContributionFactory.createFromBundle(ReflectionContributionFactory.java:102)
    at org.eclipse.e4.ui.internal.workbench.ReflectionContributionFactory.doCreate(ReflectionContributionFactory.java:71)
    at org.eclipse.e4.ui.internal.workbench.ReflectionContributionFactory.create(ReflectionContributionFactory.java:53)
    at org.eclipse.e4.ui.workbench.renderers.swt.ContributedPartRenderer.createWidget(ContributedPartRenderer.java:141)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.createWidget(PartRenderingEngine.java:889)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.safeCreateGui(PartRenderingEngine.java:623)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.safeCreateGui(PartRenderingEngine.java:725)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.access$2(PartRenderingEngine.java:696)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$7.run(PartRenderingEngine.java:690)
.
.
.

person pashiman    schedule 28.07.2012    source източник


Отговори (1)


Така че проблемът е, че един от плъгините, които имате в приложението си, изисква маркер с име find.ext. Регистърът за грешки показва IDfind.ext, тъй като съобщението за грешка е свързано без интервал.

Това се случва, ако имате персонализирано приложение. Решението е доста лесно: Намерете вашия WindowActionBarAdvisor, който разширява ActionBarAdvisor и дефинира началните менюта и ленти с инструменти на вашето приложение като File, Help и т.н. и т.н.

Добавете този ред: menu.add(new GroupMarker(IWorkbenchActionConstants.FIND_EXT)); е.е. към метода createEditMenu. или към всеки друг запис в менюто.

person Chris    schedule 10.01.2013