2011-08-18 47 views
0

如何构建使用Scala(2.9.1.RC3)和PDE(Eclipse Helios)的OSGi包。我正在使用Scala IDE(2.0.0-beta)构建项目并将其转换为PDE项目。 我的MANIFEST.MF是这样的:使用Eclipse PDE和Scala IDE构建OSGi模块和Scala

Manifest-Version: 1.0 
Bundle-ManifestVersion: 2 
Bundle-Name: ScalaTest1 
Bundle-SymbolicName: ScalaTest1 
Bundle-Version: 1.0.0.qualifier 
Bundle-Activator: scalatest1.Activator 
Import-Package: org.osgi.framework;version="1.3.0" 
Bundle-RequiredExecutionEnvironment: JavaSE-1.6 

项目构建没有错误,但是当开始出现此异常的束(使用Apache 3.2.2菲利克斯):

org.osgi.framework.BundleException: Not found: scalatest1.Activator 
     at org.apache.felix.framework.Felix.createBundleActivator(Felix.java:3812) 
     at org.apache.felix.framework.Felix.activateBundle(Felix.java:1899) 
     at org.apache.felix.framework.Felix.startBundle(Felix.java:1822) 
     at org.apache.felix.framework.BundleImpl.start(BundleImpl.java:927) 
     at org.apache.felix.gogo.command.Basic.start(Basic.java:758) 
     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.apache.felix.gogo.runtime.Reflective.method(Reflective.java:136) 
     at org.apache.felix.gogo.runtime.CommandProxy.execute(CommandProxy.java:82) 
     at org.apache.felix.gogo.runtime.Closure.executeCmd(Closure.java:469) 
     at org.apache.felix.gogo.runtime.Closure.executeStatement(Closure.java:395) 
     at org.apache.felix.gogo.runtime.Pipe.run(Pipe.java:108) 
     at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:183) 
     at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:120) 
     at org.apache.felix.gogo.runtime.CommandSessionImpl.execute(CommandSessionImpl.java:89) 
     at org.apache.felix.gogo.shell.Console.run(Console.java:62) 
     at org.apache.felix.gogo.shell.Shell.console(Shell.java:203) 
     at org.apache.felix.gogo.shell.Shell.gosh(Shell.java:128) 
     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.apache.felix.gogo.runtime.Reflective.method(Reflective.java:136) 
     at org.apache.felix.gogo.runtime.CommandProxy.execute(CommandProxy.java:82) 
     at org.apache.felix.gogo.runtime.Closure.executeCmd(Closure.java:469) 
     at org.apache.felix.gogo.runtime.Closure.executeStatement(Closure.java:395) 
     at org.apache.felix.gogo.runtime.Pipe.run(Pipe.java:108) 
     at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:183) 
     at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:120) 
     at org.apache.felix.gogo.runtime.CommandSessionImpl.execute(CommandSessionImpl.java:89) 
     at org.apache.felix.gogo.shell.Activator.run(Activator.java:75) 
     at java.lang.Thread.run(Unknown Source) 
Caused by: java.lang.ClassNotFoundException: scalatest1.Activator not found by ScalaTest1 [27] 
     at org.apache.felix.framework.ModuleImpl.findClassOrResourceByDelegation(ModuleImpl.java:812) 
     at org.apache.felix.framework.ModuleImpl.access$400(ModuleImpl.java:72) 
     at org.apache.felix.framework.ModuleImpl$ModuleClassLoader.loadClass(ModuleImpl.java:1807) 
     at java.lang.ClassLoader.loadClass(Unknown Source) 
     at org.apache.felix.framework.ModuleImpl.getClassByDelegation(ModuleImpl.java:670) 
     at org.apache.felix.framework.Felix.createBundleActivator(Felix.java:3808) 
     ... 33 more 

和代码:

package scalatest1 

import org.osgi.framework._ 

class Activator extends BundleActivator { 
    def start(context: BundleContext) { 
    println("Hello, World!"); 

    val bundleNames = context.getBundles() 
     .map(b => b.getSymbolicName()) 
     .filter(b => b != context.getBundle()); 
    println("Installed bundles: " + bundleNames.mkString(", ")); 
    } 

    def stop(context: BundleContext) { 
    println("Goodbye, World!"); 
    } 
} 

该过程出了什么问题?如何正确映射类Activator?

在此先感谢

+0

您的激活器类是否实现了java接口BundleActivator?所有类型都是由包中的激活器类引用的,还是导入了包中的? –

+0

@ bj-hargrave是的。我也会发布代码。 – adelarsq

+1

您的包似乎并未导入Scala标准库包。不幸的是,我不知道这会是什么,但可能至少需要'scala'包。看起来你正在使用scala集合,所以你需要导入'scala.collection',并且你可能还需要'scala.runtime'。 –

回答

0

我发现这个愚蠢的问题。何时导出字段“使用在工作区中编译的类文件”未标记。 Works,但还有另一个问题,即.scala文件在导出的.jar文件中。