build.xml
1. ant中变量的传递有两种方法:
a) setenv,然后在build.xml中获取系统环境变量,e.g. setenv ANT_HOME xxxx
b) ant -D变量名=变量值 target_name,则在build.xml中可以直接使用该变量, e.g. ant -Dlsf.version=6.2 all (build.xml见下)
########################################<?xml version="1.0" encoding="UTF-8"?>
<!-- 定义default target,以及当前目录 -->
<project name="xxx" default="all" basedir=".">
<!-- 定义一些变量,直接指定其值 -->
<property name="perf.version" value="1.2"></property>
<!-- 定义一些变量,其值从环境变量获取 -->
<property environment="env"></property>
<property name="bname" value="${env.ANT_HOME}"></property>
<!-- 定义一些变量,其值是基于其他的变量值 -->
<property name="perf.home" value="${basedir}/../.."></property>
<property name="bname" value="${env.BNAME}"></property>
<property name="ant.home" value="${env.ANT_HOME}"></property>
<!-- 通过 Condition 定义一些变量,其值根据不同的条件设定不同的值 -->
<condition property="cmd.ant" value="${ant.home}\bin\ant.bat">
<!-- ant 定义并自动获取的os type -->
<os family="windows"></os>
</condition>
<condition property="cmd.ant" value="${ant.home}/bin/ant">
<not>
<os family="windows"></os>
</not>
</condition>
<condition property="node.lsflib.dir" value="linux-x86">
<equals arg1="${bname}" arg2="linux-x86"></equals>
</condition>
<condition property="node.lsflib.dir" value="linux-x86_64">
<equals arg1="${bname}" arg2="linux-x86_64"></equals>
</condition>
......
<condition property="build" value="true">
<or>
<equals arg1="${bname}" arg2="linux-x86"></equals>
<equals arg1="${bname}" arg2="linux-x86_64"></equals> ...... </or>
</condition>
<!-- 这里lsf.version 就是通过 ant -Dlsf.version=xxx 传进来的-->
<condition property="lsf.shared.dir" value="LSF6.2">
<contains string="${lsf.version}" substring="6.2">
</contains>
</condition>
<condition property="lsf.shared.dir" value="LSF7_0_4_Gold_Patch">
<contains string="${lsf.version}" substring="7.0"></contains>
</condition>
......
<!-- Get build date -->
<tstamp>
<format property="build.date" pattern="EEE MMM dd HH:mm:ss yyyy">
</format>
</tstamp>
<path id="compile.classpath">
<pathelement location="${classes.dir}"></pathelement>
<fileset dir="${perf.home}/xxx/lib">
<include name="*.jar"></include>
</fileset>
</path>
<!--可以用 if 或者 unless 设定在什么条件下执行该target-->
<target name="all" if="build">
<antcall target="xxx"></antcall>
<antcall target="xxx"></antcall>
......
</target>
<target name="xxx">
<!--到某个目录下执行ant命令或其他-->
<exec dir="${perf.home}/xxx" executable="${cmd.ant}" failonerror="true">
<arg line="clean"> </arg>
<arg line="build"></arg>
</exec>
<!--到某个目录下执行带参数的gmake命令 "gmake all variable_name=variable_value"--><exec dir="${basedir}/node/c" executable="gmake" failonerror="true"><arg line="clean"></arg><arg line="all LSF_SHARED_DIR=${lsf.shared.dir}"></arg></exec><mkdir dir="${build.home}/classes"></mkdir><!-- Compile java,指定-classpath, 这里compile.class是通过<path id="compile.classpath">...</path>定义的 --><javac srcdir="${basedir}/xxx/java" destdir="${build.home}/classes" debug="${DEBUG}" deprecation="${compile.deprecation}" optimize="${compile.optimize}"><classpath refid="compile.classpath"></classpath></javac><!-- Copy files--><copy todir="${build.home}/classes" filtering="on"><fileset dir="${basedir}/xxx/java" includes="**/*.properties"></fileset><fileset dir="${basedir}/xxx/c" excludes="**/*.txt"></fileset></copy><!-- jar --><jar jarfile="${build.home}/xxx/xxx.jar"><!-- 指定要打包的文件目录 --><fileset dir="${build.home}/classes" includes="**/*"></fileset><!--定义写入manifest的内容--><manifest><section name="${sp.name}.jar"><attribute name="Created-By" value="xxxx"></attribute><attribute name="Version" value="${VERSION}"></attribute><attribute name="Build-Date" value="${build.date}"></attribute> ...... </section></manifest></jar><!-- 删除目录 --><delete dir="${build.home}/classes"></delete><!--打tar包--><tar destfile="${dist.home}/"><tarfileset dir="${basedir}/DBschema/xxx" includes="**/*.sql" prefix="${schema.dir.name}"></tarfileset></tar> ...... </target></project>
分享到:
相关推荐
至于压缩包子文件的文件名称列表,只有一个`build.xml`,这通常意味着这是一个简单的项目,其构建过程完全由这个XML文件定义。可能的结构是直接在`build.xml`中包含了所有的构建逻辑,没有将配置分离到其他辅助文件...
本文将深入解析Ant的`build.xml`模板,探讨其核心概念,并通过实例展示如何利用`build.xml`文件进行项目构建。 `build.xml`是Ant的构建配置文件,它是Ant执行任务的蓝图,定义了一系列的构建目标和任务。文件的结构...
为了保持`build.xml`的整洁,可以使用`<import>`元素引入其他XML文件,实现模块化构建。 9. **MyEclipse中的Ant支持** 在MyEclipse这样的IDE中,可以直接导入`build.xml`文件,然后通过IDE的构建工具直接运行和...
Apache Ant 是一个广泛使用的Java构建工具,它以XML格式定义构建脚本,即`build.xml`文件。这个文件包含了构建项目的整个流程,从编译源代码到生成最终的可执行或部署包。下面我们将深入探讨`build.xml`的使用以及...
jmeter+ant 持续集成build.xml文件,直接使用ant命令执行jmeter脚本文件,得到图形测试报告
Ant build.xml 文件详解 Ant 是一个项目管理工具,相比make命令,gnumake和nmake等编译工具,Ant克服了这些工具的缺陷。Ant 的优点包括跨平台性、操作简单、易于集成到开发环境中。Ant 的构建文件是 XML 格式的文件...
总结来说,这个Python程序gen1.py旨在简化Java开发中的ANT配置过程,通过自动分析项目结构和生成相应的build.xml文件,从而提高开发效率。了解ANT的基本概念、XML配置语法以及如何利用类似gen1.py的工具,对于Java...
我的开发环境是Eclipse,ant.xml是放在项目下的ant(新建),也可以修改project的basedir.
3. **build.xml文件详解**:`build.xml`是Ant的构建文件,其中包含了一系列的任务和目标。例如,你可以定义一个目标来启动JMeter,另一个目标来生成测试报告,甚至还有一个目标用来发送测试结果的邮件通知。在描述中...
ant +build.xml 文件Jenkins部署javaEE项目,助力成功自动化部署。ant +build.xml 文件Jenkins部署javaEE项目,助力成功自动化部署。ant +build.xml 文件Jenkins部署javaEE项目,助力成功自动化部署。ant +build.xml...
同时,`import`和`include`元素可以引入其他XML文件,实现模块化和代码复用。 在实际开发中,`build.xml`常常会引用外部依赖库,通过`classpath`元素和`pathelement`或`fileset`来指定。对于大型项目,使用`path`...
第一次做jmeter+ant自动化接口测试,需要build文件,开始直接copy博客中的内容,格式不对,调试好久不成功;后发现在jmeter/extras文件夹中有一个build文件,copy出来根据需要修改下,成功了,特上传自选供大家使用...
ant打包配置文件,参考了博主的文章,作者:失语失芯不失梦 链接:https://www.jianshu.com/p/04cfce59890a 来源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Ant构建文件通常命名为`build.xml`,这是一个XML文件,用于定义项目的构建规则。构建文件由一系列的元素构成,主要包括`<project>`、`<target>`和`<task>`等。 ##### 2.1 `<project>`标签 - **default**: 指定默认...
Ant是Apache组织提供的一款Java语言的构建工具,它的配置文件通常以`build.xml`为名,它是Ant工作的蓝图。这篇博客文章“ant build.xml例子”可能详细介绍了如何使用Ant来管理Java项目的构建过程。 `build.xml`文件...
一个普通java程序用ant打包的列子,完整的,里面采用的是eclipse自带的编译插件进行的打包,需要结合eclipse中的插件一起使用
ant 中 build.xml 文档写法 Ant 是 Apache 软件基金会 JAKARTA 目录中的一个子项目,它是一个项目管理工具,具有跨平台性、操作简单、易于维护和书写等优点。Ant 的概念可能有些读者并不知道什么是 Ant 以及如何...
java项目打包build.xml文件 ant打包
本文将详细介绍 Ant 的环境变量配置和 build.xml 文件的配置详解。 第一步:安装 Apache Ant 在开始使用 Ant 之前,需要先安装 Apache Ant。在官网下载相应的版本,例如 apache-ant-1.5.4,然后按照安装向导进行...
ant build.xml demo 供自己及好友学习,能很快上手