【问题标题】:Error while running Eclipse RCP application from command line从命令行运行 Eclipse RCP 应用程序时出错
【发布时间】:2014-11-16 01:06:14
【问题描述】:

我有一个 Eclipse 插件,我想在不启动 Eclipse 的情况下从命令行运行它。我使用 OSGi 命令实现了这一点:

/Library/Java/JavaVirtualMachines/jdk1.7.0_60.jdk/Contents/Home/bin/java 
  -XstartOnFirstThread
  -Dosgi.requiredJavaVersion=1.5
  -XX:MaxPermSize=256m
  -Xms40m
  -Xmx512m
  -Declipse.ignoreApp=false
  -Dosgi.noShutdown=true    
  -Declipse.pde.launch=true
  -Dfile.encoding=MacRoman
  "-Xbootclasspath/p:/Users/aneeshmohan/Movies/eclipse Indigo/plugins/org.eclipse.jdt.debug_3.7.1.v20110802_r371/jdi.jar" 
  -classpath "/Users/aneeshmohan/Movies/eclipse Indigo/plugins/org.eclipse.equinox.launcher_1.2.0.v20110502.jar"
  org.eclipse.equinox.launcher.Main
  -product org.talend.rcp.branding.tos.product 
  -data /Users/aneeshmohan/Desktop/MyWorkspace/../runtime-NewTalendCofiguration 
  -configuration file:/Users/aneeshmohan/Desktop/MyWorkspace/.metadata/.plugins/org.eclipse.pde.core/NewTalendCofiguration/ 
  -dev file:/Users/aneeshmohan/Desktop/MyWorkspace/.metadata/.plugins/org.eclipse.pde.core/NewTalendCofiguration/dev.properties 
  -os macosx 
  -ws cocoa 
  -arch x86_64 
  -nl en_US 
  -consoleLog 
  -console 
  -nosplash 
  --disableLoginDialog

这很好用,没有问题。 我现在将我的 eclipse 和工作区复制到另一台机器上,并对路径进行了必要的更改,但是当我运行它时,我得到了 osgi 控制台,但最终得到了错误:

!MESSAGE Error loading bundle datas.  Recalculating cache.
!STACK 0
java.lang.NullPointerException
    at org.eclipse.osgi.internal.baseadaptor.BaseStorage.getExtensionFiles(BaseStorage.java:1163)
    at org.eclipse.osgi.internal.baseadaptor.BaseStorage.addExtensionContent(BaseStorage.java:1087)
    at org.eclipse.osgi.internal.baseadaptor.BaseStorage.processFrameworkExtension(BaseStorage.java:1060)
    at org.eclipse.osgi.internal.baseadaptor.BaseStorage.processExtension(BaseStorage.java:1026)
    at org.eclipse.osgi.internal.baseadaptor.BaseStorage.readBundleDatas(BaseStorage.java:406)
    at org.eclipse.osgi.internal.baseadaptor.BaseStorage.getInstalledBundles(BaseStorage.java:354)
    at org.eclipse.osgi.baseadaptor.BaseAdaptor.getInstalledBundles(BaseAdaptor.java:179)
    at org.eclipse.osgi.framework.internal.core.Framework.initialize(Framework.java:236)
    at org.eclipse.osgi.framework.internal.core.Framework.<init>(Framework.java:162)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.startup(EclipseStarter.java:261)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:175)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:622)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:577)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1410)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1386)

谁能指出我正确的方向来解决这个错误?

【问题讨论】:

  • 这是什么版本的 Eclipse?

标签: eclipse eclipse-plugin osgi eclipse-rcp


【解决方案1】:

只是猜测:我看到您正在尝试使用 Windows 路径在 Mac 上盯着您的东西。您在路径中使用空格和引号。首先,我会尝试使用没有空格的“安全”路径。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-10-08
    • 2019-12-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-02-11
    相关资源
    最近更新 更多