11

我们已将 OSGi 运行时 (Equinox) 嵌入到自定义客户端-服务器应用程序中,以促进插件开发,到目前为止一切进展顺利。由于内置的​​清单编辑器、依赖管理和导出向导,我们一直在使用 Eclipse 构建插件。使用 Eclipse 来管理构建对于通过 Hudson 进行持续集成不是很有利。

我们有依赖于其他 OSGi 包的 OSGi 包。我真的很讨厌在自定义 ANT 构建中对构建顺序进行硬编码。我们已经这样做了,这已经是过去了,而且非常可怕。是否有任何构建工具可以轻松管理 OSGi 依赖项,如果不能自动解决它们?是否有任何体面的例子说明如何做到这一点?

澄清:

生成的构建脚本只能通过 Eclipse 使用。它们需要手动运行 Eclipse 的各个部分。我们还有一些 Eclipse 构建没有的标准目标,我不想修改生成的文件,因为我可能会重新生成(我知道我可以做包含,但我想避免所有 Eclipse 生成文件一起)

这是我的项目布局:

/
-PluginA
-PluginB
-PluginC
.
.
.

在使用 Eclipse PDE 时,每个插件都有一个 Manifest,但没有 build.xml,因为 PDE 会为我这样做。很难用 Hudson 自动化一个 gui 驱动的过程。我想设置我自己的 build.xml 来构建每个,但是存在依赖项和构建顺序问题。这些问题是由 Manifest 文件(描述 OSGi 导入)驱动的。例如,PluginC 依赖于 PluginB,而 PluginB 又依赖于 PluginA。它们必须以正确的顺序构建。我意识到我可以手动控制构建顺序,我正在寻找一种工具来帮助自动化构建顺序依赖管理。

4

9 回答 9

7

Maven2一路;有一个名为m2eclipse的 Eclipse 插件来帮助管理它,解决了依赖问题,然后解决了一些问题。有一本免费的在线书籍作为文档

专门查看将许多组件捆绑在一起的多模块项目,并让 Maven 计算出构建顺序和依赖关系。

还有一章是关于 Eclipse 集成的

这只是 Eclipse 和 Maven,接下来你会为 OSGi 获得一些很酷的东西:

而且从根本上说,Maven 模块模型与 OSGi 的捆绑模型完美契合。3 年多来,我们一直在使用 Maven 构建和管理具有数百个捆绑包的多个产品,这很棒。

于 2008-09-05T13:19:48.177 回答
2

借调Maven2。查看用于构建的 Tycho 插件 - 它们使用 Eclipse 的 JDT 编译器,因此它在编译时实现所有 OSGi 规则,就像 Eclipse 在运行时一样。

或者,Apache Felix BND 插件似乎也很受欢迎。我更喜欢 Tycho,因为它似乎更紧密地统一了 Maven 和 Eclipse 开发环境。

于 2008-10-25T14:33:18.907 回答
1

我们使用Buckminster。它是一个构建和组装框架,负责解决依赖关系、从各种存储库中获取、构建和打包产品。

这是一个 Eclipse 工具项目。它与 PDE 很好地集成。

这意味着我们用于构建 RCP 的所有元数据对于 Buckminster 解析和构建都是有用的。例如,manifest.MF、.product 中的 feature.xml 和 Require-Bundle 标头。

我们现在在每个包中都没有任何构建脚本;我们现在每个产品都有一个构建。Buckminster 负责遍历依赖关系图。

尽管他们(Buckminster 团队)已经开始使用 Hudson 来托管项目本身,但让我们现有的巡航控制/蚂蚁系统与它一起工作需要一些努力。我相信他们的构建设置也可以下载。

尽管它还处于起步阶段,但我们对它印象深刻。

我们还研究了Pax-Construct,但我们不想使用 Maven。

我们目前还在研究Spring DM 测试框架以增强单元测试工作。

于 2008-09-05T12:32:57.697 回答
1

结束一些老问题......

由于缺乏网络连接和时间,我们的设置不利于 maven。我知道有离线的 maven 设置,但考虑到时间太多了。当我们有时间重新组织构建过程时,希望我们能够使用正确的设置。

该解决方案涉及 Ant、BND 和一些自定义的 Ant 任务。各种捆绑依赖项是手动管理的。我们已经在使用 Ant 了;BND 和自定义任务将它们捆绑在一起。自定义任务只是确保我们的 bnd/eclipse 项目是同步的。

于 2009-01-26T01:44:39.053 回答
1

PDE 无头构建。Eclipse 对此进行了详细记录。如果您正在构建 Eclipse 插件,并且想通过命令行来完成,那么 Eclipse PDE 无头构建是您的最佳选择。

于 2010-06-28T19:06:12.550 回答
0

你能详细说明问题发生在哪里吗?您提到了 OSGi 捆绑包依赖项。这是在运行时吗?还是在编译时?在第一种情况下,您应该考虑声明式服务(请参阅 OSGi 规范)。

于 2008-09-05T21:33:11.300 回答
0

我们使用 Hudson 和PluginBuilder来构建我们基于 Eclipse 的 OSGi 包/插件。这建立在 Eclipse 用于构建插件的标准 PDE 过程之上。这意味着使用 Eclipse 作为编译器。

于 2008-10-16T12:15:19.090 回答
0

我使用 Maven 3.0.2

mvn 生成:原型

select 252 - osgi-archetype
mvn idea:idea

http://felix.apache.org/site/apache-felix-maven-bundle-plugin-bnd.html

要将您的依赖项添加到包中,请使用 pom.xml 中的这个简短示例

<Export-Package>org.foo.myproject.api</Export-Package>

或者

<Import-Package>org.foo.myproject.api</Import-Package>
于 2011-03-01T13:24:57.820 回答
0

Maven 不需要互联网连接!看在上帝的份上,使用 -o 开关。

于 2011-07-13T14:38:21.953 回答