2013-08-12 3 views
1

Несколько дней назад мы решили начать использовать Guava в нашем приложении RCP Eclipse. Я загрузил guava-14.0.1.jar от http://central.maven.org/maven2/com/google/guava/guava/14.0.1/.Приложение Eclipse RCP начинается только с администратора

После того, как я запустил eclipse.exe, приложение разбилось. .metadata/.log файл содержал следующие ошибки:

!ENTRY org.eclipse.osgi 4 0 2013-08-12 15:56:32.033 
!MESSAGE Application error 
!STACK 1 
java.lang.NoClassDefFoundError: com/google/common/base/Optional 
    at com.treeage.treeagepro.license.LicenseLevel.<clinit>(Unknown Source) 
    at com.treeage.treeagepro.license.LicenseInfo.<init>(Unknown Source) 
    at com.treeage.treeagepro.license.LicenseManager.<init>(Unknown Source) 
    at com.treeage.treeagepro.license.LicenseManager.getManager(Unknown Source) 
    at com.treeage.treeagepro.app.ApplicationWorkbenchAdvisor.initialize(Unknown Source) 
    at org.eclipse.ui.application.WorkbenchAdvisor.internalBasicInitialize(WorkbenchAdvisor.java:188) 
    at org.eclipse.ui.internal.Workbench$28.runWithException(Workbench.java:1541) 
    at org.eclipse.ui.internal.StartupThreading$StartupRunnable.run(StartupThreading.java:31) 
    at org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35) 
    at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:135) 
    at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:4144) 
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3761) 
    at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2609) 
    at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2499) 
    at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:679) 
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332) 
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:668) 
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149) 
    at com.treeage.treeagepro.app.Application.start(Unknown Source) 
    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:353) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:180) 
    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:629) 
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:584) 
    at org.eclipse.equinox.launcher.Main.run(Main.java:1438) 
Caused by: java.lang.ClassNotFoundException: com.google.common.base.Optional 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:501) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:421) 
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:412) 
    at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.loadClass(DefaultClassLoader.java:107) 
    at java.lang.ClassLoader.loadClass(Unknown Source) 
    ... 31 more 

Там нет ошибки, если приложение работает в качестве администратора.

Приложение является 64-разрядным, поэтому это не проблема виртуализации UAC. Но похоже, что проблема связана с разрешениями.


гуавы-14.0.1.jar кажется действительным OSGi расслоения: https://code.google.com/p/guava-libraries/issues/detail?id=688 (По крайней мере, я нашел все необходимые заголовки в MANIFEST.MF)

Любые предложения?

+1

как вы импортируете свою библиотеку guava? –

+0

Источник проблемы полностью изменился. Я обновил свой вопрос – ZhekaKozlov

+1

Создает ли ваш собственный пакет (тот, который содержит класс LicenseLevel) пакет 'com.google.common.base'? –

ответ

1

Я исправил свою проблему, уничтожив C:\Users\<user_name>\.eclipse папку. Похоже, что проблема связана с временными каталогами OSGi (Equinox).

0

Двойная проверка, если вы включили пакет в функцию, которая используется в конфигурации продукта вашего RCP. Двойная проверка, если вы используете правильное символическое имя, и если вам требуется правильная версия. У меня была проблема, подобная вашей, потому что баня гуавы не была правильно скопирована на целевую платформу во время сборки.

В моем случае я должен был добавить следующее в feature.xml для обеспечения версии 0.14.1 был копируется, так как Eclipse, XText и других компонентов использует более старый:

<requires> 
    <import plugin="com.google.guava" version="0.14.1"/> 
    .... 
</requires> 
<plugin 
    id="com.google.guava" 
    download-size="0" 
    install-size="0" 
    version="0.0.0" 
    unpack="false"/> 
0

на основе вашего последнего комментарий, я думаю, это не связанный с Java или OSGi, но, вероятно, только вопрос о разрешении файловой системы.

Вы можете:

  • проверка конкретной папки и ее подпапок и файлов для unusal требований разрешений (щелчок правой кнопкой мыши, свойства, вкладка безопасность),
  • удалить всю папку, создать его заново, и попробуйте еще раз проверить другой результат.
Смежные вопросы