利用Ant脚本导出BIRT

       最近公司在对birt进行二次开发,需要对birt进行自动化编译,因此对其研究了一番,写了下面的这篇文章,希望对初学者有些帮助。

谈到自动化编译,很容易让人想到ant工具,到网上找些资料,还是有些不错的,像下面的:

         meteors1113的专栏的使用Ant导出Eclipse RCP全攻略  

         网址:http://blog.csdn.net/meteors1113/article/details/5522538

       这篇文章对于单插件和多插件导出RCP产品都是可以导出的,但是对于BIRT来讲,还是差了些东西,因为BIRT的插件工程有二百多个,各插件之间的依赖关系比较复杂,本文也是在这篇博文的基础上做些修改和调整,原理其实是一样的,都是利用PDE进行编译和打包。

       下面就来说说利用ant脚本打包编译BIRT的步骤:

 

1. 下载birt源码

       这里就不作介绍了,网上还是有很多资料的,本文用的是birt3.7.0的源码;

       还有一点要说明,自己手动下载源码跟通过cvs下载的源码结构不太一样,cvs下载的源码结构不太一样,手动下载的包含编译时所依赖的jar包,但是cvs下载的源码得自己来配置所需要的jar包,建议大家选择手动下载,如果用cvs下载的也没关系,本文就是用cvs下载的源码,不包含依赖包。

 

2. 搭建环境

       在源码下载完成后,需要修改源码目录的结构,并且放到设定好的目录中,整个环境的结构如下所示(假设是在D盘);

            

           D:\BIRT-BUILD

                    |------build

                             |-------features

                             |-------plugins

                    |------repos

                             |-------rcp

                    |------target

 

       创建完目录后,将源码复制到plugins目录中,然后将源码中的feature类型的工程剪贴到features文件夹中,以nl1结尾的国际化工程和所有的测试工程都要放到plugins文件夹中,不能放到子目录中,否则会出现插件找不到的问题。

       源码配置好以后,就需要下载各种的环境包,列表如下:

                eclipse-SDK-3.7.2-win32.zip(网址待更新)

                eclipse-3.7.2-delta-pack.zip(网址待更新)

                org.eclipse.rcp-3.7.2.zip(网址待更新)

                emf2.6.x( http://archive.eclipse.org/modeling/emf/emf/downloads/drops/)

                GEF-ALL-3.7.2(网址待更新)

                dtp-sdk_1.9.x(网址待更新)

 

       下载完成后,将eclipse-SDK-3.7.2-win32.zip解压到target中,解压后的目录:

     

                target

                    |----eclipse

 

       这个target文件夹就是用来放置eclipse的,之后的PDE就是从这里调用。

       解压eclipse-3.7.2-delta-pack.zip到eclipse目录,并进行替换。如果不解压eclipse-3.7.2-delta-pack的话,发布的RCP程序将没有可执行程序(eclipse.exe)。

       解压org.eclipse.rcp-3.7.2.zip到rcp目录下,emf、gef以及dtp包都解压到eclipse目录中。

       如果你已经手动下载了3.7.0源码的话,就将源码plugins文件夹下的所有jar包以及下列文件夹复制到eclipse目录下的plugins文件夹中:

               javax.xml.rpc_1.1.0.v201005080400

                javax.xml.soap_1.2.0.v201005080501

               org.apache.axis_1.4.0.v201005080400

               org.apache.commons.discovery_0.2.0.v201004190315

               org.w3c.sac

      

       如果没有手动下载3.7.0源码的话(如果下载了那就更容易了,环境都省了好多,话又说回来,如果手动下载了源码的话,那谁还这么麻烦的用cvs下载的源码来搭建环境啊),建议下载EclipseIDE for Java and Report Developers 简称eclipse4report,地址: http://www.eclipse.org/downloads/download.php?file=/technology/epp/downloads/release/juno/SR1/eclipse-reporting-juno-SR1-win32.zip ,这个IDE包含birt的功能,因此在plugins里会有编译所依赖的一些插件,缺少插件时可以到这个IDE中去copy,不然的话,找这些个插件会挺麻烦的。

 

3. 编写脚本

       在eclipse中创建一个一般工程,名为org.eclipse.birt.report.designer.build,里面创建两个文件,build.properties和build.xml,这两个文件是最关键的文件,最终编译就靠这两个文件,也就是ant脚本。 

        build.xml文件内容如下:

<project name="org.eclipse.birt.report.designer.build" default="build">
    <property file="build.properties" />
    <!--
        Paths that allow running PDE Build without knowing specific bundle versions    
    -->
    <path id="equinox.launcher.path">
        <fileset dir="${eclipseLocation}/plugins">
            <include name="org.eclipse.equinox.launcher_*.jar" />
        </fileset>
    </path>
    <property name="equinox.launcher" refid="equinox.launcher.path" />
    <path id="pde.build.dir.path">
        <dirset dir="${eclipseLocation}/plugins">
            <include name="org.eclipse.pde.build_*" />
        </dirset>
    </path>
    <property name="pde.build.dir" refid="pde.build.dir.path" />
            
    <!--
        This target actually executes the PDE Build process by launching the
        Eclipse antRunner application.
    -->
    <target name="pde-build">
        <java classname="org.eclipse.equinox.launcher.Main" fork="true" failonerror="true">
            <arg value="-application" />
            <arg value="org.eclipse.ant.core.antRunner" />
            <arg value="-buildfile" />
            <arg value="${pde.build.dir}/scripts/productBuild/productBuild.xml" />
            <arg value="-Dtimestamp=${timestamp}" />
            <classpath>
                <pathelement location="${equinox.launcher}" />
            </classpath>
        </java>
    </target>
    <target name="clean">
        <delete dir="${buildDirectory}" />
    </target>
    <target name="build" depends="pde-build" />
</project>

 

build.properties文件内容如下:

       

###############################################################################
# Copyright (c) 2003, 2009 IBM Corporation and others.
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Eclipse Public License v1.0
# which accompanies this distribution, and is available at
# http://www.eclipse.org/legal/epl-v10.html
#
# Contributors:
#     IBM Corporation - initial API and implementation
###############################################################################
#####################
             
eclipseLocation=D:/BIRT-BUILD/target/eclipse
pde.build.includeFetch=true
generateSourceReferences=true
product=D:/BIRT-BUILD/build/plugins/org.eclipse.birt.report.designer.ui.rcp/BIRT.product
             
runPackager=true
basedir=D:/BIRT-BUILD
             
# The prefix that will be used in the generated archive.
archivePrefix=BIRT
             
# The directory into which the build elements are fetched and where
# the build takes place.
buildDirectory=D:/BIRT-BUILD/build
             
# The location underwhich all of the build output will be collected.
collectingFolder=${archivePrefix}
             
# The list of {os, ws, arch} configurations to build.  This
# value is a '&' separated list of ',' separate triples.  For example,
#     configs=win32,win32,x86 & linux,motif,x86
# By default the value is *,*,*
#configs = *, *, *
configs=win32, win32, x86
             
#Allow cycles involving at most one bundle that needs to be compiled with the rest being binary bundles.
allowBinaryCycles = true
             
#Arguments to send to the zip executable
zipargs=
             
#Arguments to send to the tar executable
tarargs=
             
# Type of build.  Used in naming the build output.  Typically this value is
# one of I, N, M, S, ...
buildType=I
             
# ID of the build.  Used in naming the build output.
buildId=BIRT
             
# Label for the build.  Used in naming the build output
buildLabel=${buildType}.${buildId}
             
# Timestamp for the build.  Used in naming the build output
timestamp=007
             
base=D:/BIRT-BUILD
baseLocation=${base}/target/eclipse
             
#Folder containing repositories whose content is needed to compile against
repoBaseLocation=${base}/repos
#Folder where the content of the repositories from ${repoBaseLocation} will be made available as a form suitable to be compiled against
transformedRepoLocation=${buildDirectory}/transformedRepos
             
#Os/Ws/Arch/nl of the eclipse specified by baseLocation
baseos=win32
basews=win32
basearch=x86
             
#this property indicates whether you want the set of plug-ins and features to be considered during the build to be limited to the ones reachable from the features / plugins being built
filteredDependencyCheck=false
             
#this property indicates whether the resolution should be done in development mode (i.e. ignore multiple bundles with singletons)
resolution.devMode=false
             
#pluginPath is a list of locations in which to find plugins and features.  This list is separated by the platform file separator (; or :)
#a location is one of: 
#- the location of the jar or folder that is the plugin or feature : /path/to/foo.jar or /path/to/foo
#- a directory that contains a /plugins or /features subdirectory
#- the location of a feature.xml, or for 2.1 style plugins, the plugin.xml or fragment.xml
pluginPath=${buildDirectory}/transformedRepos/features/
             
skipBase=true
eclipseURL=<url for eclipse download site>
eclipseBuildId=<Id of Eclipse build to get>
eclipseBaseURL=${eclipseURL}/eclipse-platform-${eclipseBuildId}-win32.zip
             
skipMaps=true
mapsRepo=:pserver:[email protected]/path/to/repo
mapsRoot=path/to/maps
mapsCheckoutTag=HEAD
             
             
#tagMaps=true
mapsTagTag=v${buildId}
             
skipFetch=true
             
# Specify the output format of the compiler log when eclipse jdt is used
logExtension=.log
             
# Whether or not to include debug info in the output jars
javacDebugInfo=false

  

4. 编写批处理文件

       windows的bat为例。在windows中进入org.eclipse.birt.report.designer.build的目录,创建一个bat文件(比如build.bat ),内容如下: 

rem 设置java jdk的路径,本文用的是jdk1.5.0_22
set JAVA_HOME=D:/DevTools/jdk1.6.0_19
rem 设置ant路径,本文用的是ant-1.8.2
set ANT_HOME=D:/DevTools/apache-ant-1.7.1
%ANT_HOME%/bin/ant.bat -file build.xml
 

        以后每次打包就可以只运行这个bat文件了。

       设置java jdk的路径,本文用的是jdk1.5.0_22设置ant路径,本文用的是ant-1.8.2

 

5. 常见问题

       双击运行批处理的时候,很有可能会出现问题,但是窗口会闪退,因此最好在命令提示符中运行批处理文件。

       下面对运行脚本的过程中可能会出现的一些问题进行一下说明:

    

       运行脚本,会出现如下问题:

[java]BUILD FAILED
[java]D:\BIRT-BUILD\target\eclipse\plugins\org.eclipse.pde.build_3.7.0.v20111116-2009\scripts\productBuild\productBuild.xml:39:The following error occurred while executing this line:
[java]D:\BIRT-BUILD\target\eclipse\plugins\org.eclipse.pde.build_3.7.0.v20111116-2009\scripts\productBuild\productBuild.xml:69:Unable to find plug-in: com.lowagie.text_0.0.0. Please check the error log formore details.
[java]
[java]Total time: 4 seconds
[java]An error has occurred. See the log file

 

       由异常信息可以知道,导致编译失败的原因是由于缺少com.lowagie.text插件,到eclipse4report目录下plugins文件夹中复制过来即可。

 

       再次运行,会出现以下错误:

[java]BUILD FAILED
[java]D:\BIRT-BUILD\target\eclipse\plugins\org.eclipse.pde.build_3.7.0.v20111116-2009\scripts\productBuild\productBuild.xml:39:The following error occurred while executing this line:
[java]D:\BIRT-BUILD\target\eclipse\plugins\org.eclipse.pde.build_3.7.0.v20111116-2009\scripts\productBuild\productBuild.xml:69:Bundle com.shentong.kfront.designer.gdm_1.0.0.201302261654 failed to resolve.:
[java]     Missing required plug-inorg.eclipse.birt.report.model_3.7.0.
[java]     Missing required plug-inorg.eclipse.birt.report.designer.core_3.7.0.
[java]     Missing required plug-inorg.eclipse.birt.report.designer.ui_3.7.0.
[java]     Missing required plug-inorg.eclipse.birt.report.designer.ui.views_3.7.0.
[java]     Missing required plug-inorg.eclipse.birt.core_3.7.0.
[java]     Missing required plug-inorg.eclipse.birt.report.designer.ui.data_3.7.0.
[java]     Missing required plug-in org.eclipse.birt.report.data.adapter_3.7.0.
[java]     Missing required plug-inorg.eclipse.birt.data_3.7.0.
[java]     Unsatisfied import packageorg.eclipse.birt.report.engine.api_0.0.0.
[java]     Unsatisfied import packageorg.eclipse.birt.report.engine.api.impl_0.0.0.
[java]     Unsatisfied import packageorg.eclipse.birt.report.model.adapter.oda.impl_0.0.0.
[java]
[java]
[java]Total time: 5 seconds
[java]An error has occurred. See the log file
 

       在eclipse4report目录下plugins文件夹中找到如下插件并导入:

              org.apache.batik.*.jar  (以org.apache.batik开头的都要导入)

              org.mozilla.javascript_*.jar

              org.w3c.css.sac_*.jar

              org.w3c.dom.events_*.jar

              org.w3c.dom.smil_*.jar

              org.w3c.dom.svg_*.jar

       

       导入后运行脚本:

[java]BUILD FAILED
[java]D:\BIRT-BUILD\target\eclipse\plugins\org.eclipse.pde.build_3.7.0.v20111116-2009\scripts\productBuild\productBuild.xml:39:The following error occurred while executing this line:
[java]D:\BIRT-BUILD\target\eclipse\plugins\org.eclipse.pde.build_3.7.0.v20111116-2009\scripts\productBuild\productBuild.xml:69:Unable to find plug-in: javax.xml.rpc_0.0.0. Please check the error log formore details.
[java]
[java]Total time: 4 seconds
[java]An error has occurred. See the log file
 

       还是报找不到插件的异常,同理,缺少哪个插件,到eclipse4report中复制过来即可。

       导入完成后,脚本应该就可以正常编译了,但是打包出来的产品可能会出现如下的问题:

java.lang.RuntimeException:Application "{0}" could not be found in the registry. Theapplications available are: org.eclipse.equinox.app.error, org.eclipse.help.base.infocenterApplication,org.eclipse.help.base.helpApplication, org.eclipse.help.base.indexTool,org.eclipse.update.core.standaloneUpdate,org.eclipse.update.core.siteOptimizer.
       atorg.eclipse.equinox.internal.app.EclipseAppContainer.startDefaultApp(EclipseAppContainer.java:248)
       at org.eclipse.equinox.internal.app.MainApplicationLauncher.run(MainApplicationLauncher.java:29)
       at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
       atorg.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
       atorg.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:344)
       atorg.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179)
       atsun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
       at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
       atsun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
       atjava.lang.reflect.Method.invoke(Method.java:597)
       at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:622)
       atorg.eclipse.equinox.launcher.Main.basicRun(Main.java:577)
       atorg.eclipse.equinox.launcher.Main.run(Main.java:1410)
 

       造成这个问题的原因有很多种,我只说我遇到的,在将下载的包导入到eclipse中时,很有可能会出现版本冲突的问题,在运行脚本的时候就是因为如下包的版本不对,才出现了如上所示的异常:

              org.w3c.dom.smil_*.jar

版本本该是1.0.0.*,但是由于导入了1.0.1版本的jar包,导致出现了上述的问题。

 

       继续运行批处理文件,解决了以上的问题后,应该会成功的导出BIRT产品的,祝大家成功!!!

 

你可能感兴趣的:(ant,birt,自动编译)