在之前的两篇文章中,我们已经学会了如何如何用Tycho来build plugin和feature。在通常RCP项目当中,仅仅有plugin和feature是不够的,plugin提供着RCP程序中最小的逻辑功能,而feature则把这些功能点包装成一个单独的逻辑单元。但如果一个RCP的程序需要很多的features时怎么办?你可以说我可以feautre里面套feature。但如果客户要求这个RCP的程序需要在windows,linux和Mac oc都有客户端时,feature就已经明显满足不了我们的需求了。这个时候就需要引入RCP中product的概念了。
对于Product,官方的解释是这样的:
Products include all the code and plug-ins needed to run them. This includes a Java runtime environment (JRE) and the Eclipse platform code. The plug-in code, JRE, and Eclipse platform are typically installed with a product-specific installation program. Product providers are free to use any installation tool or program that is appropriate for their needs.
http://help.eclipse.org/luna/index.jsp?topic=/org.eclipse.pde.doc.user/concepts/product.htm
简单点说,product就是一个standalone的可执行程序,他可以包含很多的plugin和feautre,也可以针对于不同的平台定制不同的参数。关于product,feauture和plugin的关系,个人觉得下面的这句话是概括的最好的。
对Product的概念有了一定的了解之后,我们便可以开始创建product项目了:
1. 首先还是 New -> Project -> General -> Project
2. 在接下来的对话框中输入我们的项目名称,这里我们用com.chnic.tycho.mail.product
3. 项目创建完成之后我们需要创建product文件,还是New -> Other -> Plug-in Development -> Product Configuration -> Next
4. 在接下来的对话框中,选中我们刚刚创建的product项目,然后在下面的File Name里输入我们的product文件名,这里我们用Mail.product -> Finish
5. 在Mail.product配置的overview tab界面中,给出相应的信息。值得一提的是,我们需要选择这个product是based on在features上的。其次,ID是必须填写的,因为Tycho会使用ID加上你build的平台后缀组合成一个完成的文件名。其他的配置不多赘述。
6. 在Dependencies tab界面中,把我们之前创建的feature添加进来。
7. 接下来在Configuration tab中,我们需要添加Start Levels。这么做是因为,在传统的PDE build过程中,PDE会自动添加start levels。但是Tycho不会自动添加这些配置,所以就需要我们手动添加。否则Tycho就会在build过程中出错。因为我们这里只是个demo程序,所以不做过多的考虑,直接点击Add Recommanded,使用系统推荐配置即可。
假如你添加完成之后用Tycho build发现还是有start levels的问题,那么试一下切换到overview tab然后用Eclipse Product export wizard来导出你的product,在你导出的文件夹中找到configuration/org.eclipse.equinox.simpleconfigurator/bundles.info这个文件,文件中的每一行是由bundle_name, version, location, startlevel, autostart组成的,筛选出所有autostart是ture的行,然后根据他的startlevel把他们加到你的Mail.product配置文件中来。
至此我们便完成了Product项目的创建,其实这个时候我们的product项目是run不起来的。(除非你在Run Configurations的Plug-ins选项卡里点击Add Required Plug-ins添加所需要的依赖)这是因为我们还缺少一些RCP程序所需要target platform级别的plugin。这些plugin添加到我们的feauture项目当中,因为我们这里主要关注的是Tycho,我们只需build出一个应用程序即可,在此我就不多赘述RCP相关的内容。
在接下来我们就需要把我们刚创建好的Product项目变成一个支持Tycho的Maven项目。还是右键product项目名,然后把他转换成一个Maven项目,在Maven的配置框中,其他的属性和我们之前介绍的plugin和feature的命名规范类似,唯一不同的一点就是packaging变成了eclipse-repository。
在生成的POM文件中,添加parent属性,让他继承我们之前创建的parent项目。然后添加Tycho product build相关的插件。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>com.chnic.tycho.mail</groupId> <artifactId>com.chnic.tycho.mail.parent</artifactId> <version>1.0.0-SNAPSHOT</version> <relativePath>../com.chnic.tycho.mail.parent/pom.xml</relativePath> </parent> <artifactId>com.chnic.tycho.mail.product</artifactId> <packaging>eclipse-repository</packaging> <build> <plugins> <plugin> <groupId>org.eclipse.tycho</groupId> <artifactId>tycho-p2-repository-plugin</artifactId> <version>${tycho.version}</version> <configuration> <includeAllDependencies>true</includeAllDependencies> </configuration> </plugin> <plugin> <groupId>org.eclipse.tycho</groupId> <artifactId>tycho-p2-director-plugin</artifactId> <version>${tycho.version}</version> <executions> <execution> <id>materialize-products</id> <goals> <goal>materialize-products</goal> </goals> </execution> <execution> <id>archive-products</id> <goals> <goal>archive-products</goal> </goals> </execution> </executions> </plugin> </plugins> </build> </project>
这个时候我们虽然告诉Tycho如何去build这个product项目了,但是我们还没有提供我们build出的程序应当支持那种平台的信息。返回parent项目,修改POM文件,添加target-platform-configuration插件
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.chnic.tycho.mail</groupId> <artifactId>com.chnic.tycho.mail.parent</artifactId> <version>1.0.0-SNAPSHOT</version> <packaging>pom</packaging> <properties> <tycho.version>0.22.0</tycho.version> <luna-repo.url>http://download.eclipse.org/releases/luna</luna-repo.url> </properties> <repositories> <repository> <id>luna</id> <url>${luna-repo.url}</url> <layout>p2</layout> </repository> </repositories> <build> <plugins> <plugin> <groupId>org.eclipse.tycho</groupId> <artifactId>tycho-maven-plugin</artifactId> <version>${tycho.version}</version> <extensions>true</extensions> </plugin> <plugin> <groupId>org.eclipse.tycho</groupId> <artifactId>target-platform-configuration</artifactId> <version>${tycho.version}</version> <configuration> <environments> <!-- <environment> <os>linux</os> <ws>gtk</ws> <arch>x86</arch> </environment> <environment> <os>linux</os> <ws>gtk</ws> <arch>x86_64</arch> </environment> --> <environment> <os>win32</os> <ws>win32</ws> <arch>x86</arch> </environment> <!-- <environment> <os>win32</os> <ws>win32</ws> <arch>x86_64</arch> </environment> <environment> <os>macosx</os> <ws>cocoa</ws> <arch>x86_64</arch> </environment> --> </environments> </configuration> </plugin> </plugins> </build> </project>
添加完成之后我们会发现,parent的pom中多了很多的平台信息,因为我们只需要build出来的程序是一个win32.x86的程序,所以在这里我们注释掉其他的平台信息。这个时候你也许会问,我们可以直接build product了么?答案是否定的,因为你的product项目只有一个孤零零的product文件,他最终依赖的仍然是你的feature和plugin。所以我们需要在运行时提供这些依赖。还记得第二篇文章中我们最后提出的问题么?如果一个feature包含非常多的plugin,然后plugin A依赖plugin B,plugin B依赖plugin C的时候,这个时候我们怎么办?难道要按照依赖关系一个一个来构建么?很显然,全部手动是一种反人类的做法。更何况你在build product的时候即便全部手动也不一定能够build成功。这个时候,我们就需要一个聚合器,偏巧我们的Maven也支持这样的做法。
到目前为止,我们已经有了parent, pulgin, feature, product这四个项目,要聚合这四个项目,我们还需要另外的一个项目:com.chnic.tycho.mail.build。最终我们的Mail这个demo的目录结构会是这样:
com.chnic.tycho.mail RCP Project
|
|----com.chnic.tycho.mail.build
|----com.chnic.tycho.mail.feature
|----com.chnic.tycho.mail.parent
|----com.chnic.tycho.mail.plugin
|----com.chnic.tycho.mail.product
com.chnic.tycho.mail.build依然是一个普通的项目,创建完成之后我们仍然需要把他convert成一个Maven项目。因为他是一个聚合项目,所以packaging的方式依然是pom
转化完成之后,我们依然让build的项目继承parent项目,然后把plugin, feature和product加入build的pom当中,让他们变成build项目的modules。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>com.chnic.tycho.mail</groupId> <artifactId>com.chnic.tycho.mail.parent</artifactId> <version>1.0.0-SNAPSHOT</version> <relativePath>../com.chnic.tycho.mail.parent/pom.xml</relativePath> </parent> <artifactId>com.chnic.tycho.mail.build</artifactId> <packaging>pom</packaging> <modules> <module>../com.chnic.tycho.mail.feature</module> <module>../com.chnic.tycho.mail.plugin</module> <module>../com.chnic.tycho.mail.product</module> </modules> </project>
完成之后clean install com.chnic.tycho.mail.build这个项目,控制台上面的信息告诉我们build成功。
[INFO] Reactor Summary:
[INFO]
[INFO] com.chnic.tycho.mail.plugin ........................ SUCCESS [ 1.563 s]
[INFO] com.chnic.tycho.mail.feature ....................... SUCCESS [ 0.186 s]
[INFO] com.chnic.tycho.mail.product ....................... SUCCESS [ 8.189 s]
[INFO] com.chnic.tycho.mail.build ......................... SUCCESS [ 0.063 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 25.715 s
[INFO] Finished at: 2015-04-14T15:21:46+08:00
[INFO] Final Memory: 74M/178M
[INFO] ------------------------------------------------------------------------
Build成功之后我们刷新一下product项目,会发现在target/products目录下已经多了Mail-win32.win32.x86.zip这个zip文件。这个文件就是我们这个demo的可执行文件的压缩包。至此,我们也完成了product项目的构建工作。
Demo的代码在此给共享给大家。
相关推荐
标题中的"tycho_build_RCP_app.rar.zip"表明这是一个使用Tycho构建的Eclipse RCP(Rich Client Platform)应用程序的源码压缩包,且文件格式是rar和zip的结合。RCP是Eclipse框架用于创建桌面应用的方式,而Tycho则是...
压缩包子文件的文件名“tycho_build_RCP_app”可能是一个示例项目,包含了一个使用Tycho构建的RCP应用程序的源代码和构建配置。通过分析这个项目,读者可以学习如何设置Tycho项目,如何定义依赖,以及如何执行构建...
一个用于Eclipse RCP应用程序(例如Virtual Satellite)的Maven Tycho演示项目。 项目状态 状态 用于开发构建。 状态 用于集成构建。 状态 为大师建造。 目的 该项目是使虚拟卫星开源的测试设置。 它有助于将软件...
在IT行业中,RCP(Rich Client Platform)是一种用于构建桌面应用程序的框架,它源自Eclipse项目,提供了丰富的用户界面和强大的插件系统。RCP产品的开发者通常需要将他们的应用程序打包成可执行文件(exe),以便于...
3. **运行父POM来构建插件、特性及产品**:执行Maven构建,当构建产品时,Tycho会根据目标平台的OS和架构从特性项目中的相应JRE子文件夹复制JRE到产品目录中。例如,如果目标是Linux GTK 32位,那么特性项目中`linux...
Eclipse Rich Client Platform (RCP) 是一个强大的框架,用于构建桌面应用程序,它基于Java语言并依赖于Eclipse IDE。这个“RCP经典实例”是一个由国外JAVA专家开发的示例项目,它演示了如何利用Eclipse RCP来创建一...
`maven-tycho-thirdparty` 是一个示例项目,它展示了如何在 Eclipse 插件项目中有效地管理和使用第三方依赖,结合 Maven 和 Tycho 进行构建。下面将详细介绍这个项目及其相关知识点。 1. **Maven**: Maven 是一个...
Xtext Tycho示例这是一个演示项目,显示了如何使用tycho / maven构建Xtext项目。 它具有以下特点: 项目基于Xtext和Xtend 2.7.3 在fornax mwe2插件的帮助下从Maven运行xtext生成器mwe2工作流程生成的文件未检入,...
这个测试项目是为了演示和帮助开发者理解如何有效地利用Tycho来构建、管理和测试Eclipse插件和RCP应用。 在Java开发环境中,Eclipse Tycho提供了一种强大的解决方案,它可以处理Eclipse插件和RCP项目的依赖关系,...
通过Tycho,你可以使用Maven的强大的依赖管理和构建流程来处理Eclipse插件的构建问题,避免了传统Ant脚本的复杂性。 ** Maven Tycho的核心概念 ** 1. **基于POM的构建**:Tycho遵循Maven的约定,使用Project ...
这篇博文将深入探讨如何使用Eclipse IDE和Equinox框架来开发OSGi Bundle应用。 **OSGi基本概念** 1. **Bundle**:OSGi的核心单元,类似于Java的JAR文件,但包含了额外的元数据,描述了其依赖和其他模块的关系。 2....
这个名为"eclipse_rcp_example"的项目是为展示Eclipse RCP的强大功能而设计的一个实例,其中包括了功能模块、片段(plug-ins)、测试以及Tycho构建工具的使用。在Java开发领域,Eclipse RCP是一个重要的工具,它允许...
Eclipse RCP (Rich Client Platform) 和 RAP (Rich Ajax Platform) 是两个重要的软件开发框架,主要用于构建桌面应用程序和Web应用程序。Eclipse IDE for RCP and RAP 是一个专为这两种平台开发者设计的强大集成开发...
RCP演示RCP 演示应用程序。 应用程序的特征被分成模块,每个模块包含: API - 服务器和客户端之间远程通信的契约服务器 - 服务器实现客户端 - RCP 实现项目结构Common - 包含用于客户端和服务器的库。 杂项 1 模块 1...
9. **发布和打包**:最后,书籍会讲解如何打包和部署Eclipse RCP应用程序,包括使用Update Manager创建更新站点,以及利用Tycho进行Maven化的构建过程。 通过阅读《Addison Wesley - Eclipse Rich Client Platform ...
maven-tycho-plugin-0.10.0.jar
书中可能还会介绍使用Tycho构建工具链进行自动化构建,以及使用PDE Test框架进行单元测试和集成测试。 总之,Eclipse插件开发是一个涵盖广泛且深入的领域,它需要开发者熟悉Java编程、OSGi模块系统和Eclipse的API。...
Eclipse RCP允许开发者使用已有的Eclipse插件系统来创建自定义的、独立的桌面应用程序。这个平台提供了诸如窗口管理、用户界面组件、国际化和本地化、事件处理、持久性存储等核心功能,使得开发者可以专注于业务...
Part2可能涵盖了RCP应用的基础结构,如启动配置、窗口系统、视图和编辑器的集成,以及如何使用模型-视图-控制器(MVC)设计模式来构建可扩展的应用程序。 4. **Java开发工具(JDT)**:Eclipse的JDT组件是其作为...
tycho-eclipse-plugin-原型这个原型将创建一个具有嵌套结构的多模块项目: __artifactId__ : parent pom project | |---__artifactId__.core : eclipse-plugin | |---__artifactId__.feature: eclipse-feature | |--...