build.xml详解

 

<?xml version="1.0" encoding="UTF-8">

<!--

==============================

hello-ant项目,学习ant工具的build file。

参照ant的jakarta-ant-1.6alpha的buil.xml

==============================

-->

<!--

文档结构为:

<project>

<property/>全局变量的定义

<property/>...

<target name="1">任务组(tasks)

<javac></javac>一项javac任务

...

<oneTask></oneTask>一项其它任务

</target>

<target name="2">

<javac></javac>

...

<oneTask></oneTask>

</target>

</project>

project代表一个项目,

default:运行到名称为"dist"的target(任务组)

basedir:基准路径

-->

<project default="dist" basedir=".">

<!--

==============================

定义属性(property tasks)

最好把用到的路径,名称都在这里定义成全局变量

例:定义

<property name="a" value="hello"/>

以后就可以这样用它:

<property name="b" value="${a}/b"/>

现在:b=="hello/b"

==============================

-->

<!--主要的系统环境属性-->

<property environment="env"/><!--取window,unix...的环境变量-->

<property name="java.home" value="${env.JAVA_HOME}"/>

<property name="ant.home" value="${env.ANT_HOME}"/>

<!--主要的app环境属性-->

<property name="app.name" value="hello-ant"/>

<property name="app.jar" value="${app.name}.jar"/>

<property name="app.copyright" value="Copyright(c) 2002 The Neusoft Software Foundation.All rights reserved."/>

<!--app中src的属性-->

<property name="src.dir" value="src"/>

<property name="src.main" value="${src.dir}/main"/>

<property name="src.script" value="${src.dir}/script"/>

<!--app用到的lib-->

<property name="lib.dir" value="lib"/>

<!--app的build目录中-->

<property name="build.dir" value="build"/>

<property name="build.classes" value="${build.dir}/classes"/>

<property name="build.docs" value="${build.dir}/docs"/>

<property name="build.docs.api" value="${build.docs}/api"/>

<property name="build.lib" value="${build.dir}/lib"/>

<!--app的dist(distribution)目录中-->

<property name="dist.dir" value="dist"/>

<property name="dist.bin" value="${dist.dir}/bin"/>

<property name="dist.docs" value="${dist.dir}/docs"/>

<property name="dist.lib" value="${dist.dir}/lib"/>

<!--app的docs目录中-->

<property name="docs.dir" value="docs"/>

<!--

定义一组路径以后可以通过id重组这组路径,例:

<javac srcdir="src/main" destdir="build/classes">

<classpath refid="classpath"/>

</javac>

-->

<path id="classpath">

<!--本项目只有一个java,用不上classpath,这里只是做个例子-->

<pathelement location="${build.classes}"/>

<pathelement path="${java.home}/lib/tools.jar"/>

</path>

<!--

==============================

init准备目录(File Tasks)

主要的目录结构通常是不会变的,一起生成他们

==============================

-->

<target name="init">

<!--清除以前目录-->

<delete dir="${build.dir}" failοnerrοr="false"/>

<delete dir="${dist.dir}" failοnerrοr="false"/>

<!--清除以前目录-->

<mkdir dir="${build.dir}"/>

<mkdir dir="${build.classes}"/>

<mkdir dir="${build.docs}"/>

<mkdir dir="${build.docs.api}"/>

<mkdir dir="${build.lib}"/>

<mkdir dir="${dist.dir}"/>

<mkdir dir="${dist.bin}"/>

<mkdir dir="${dist.lib}"/>

</target>

<!--

====================

Build the code(Compile Tasks,File Tasks)

====================

-->

<target name="build" depends="init">

<!--编译-->

<javac srcdir="${src.main}" destdir="${build.classes}">

<classpath refid="classpath"/>

</javac>

</target>

<!--

====================

打包文档(archive tasks)

create the project jars:xxx1.jar and xxx2.jar

====================

-->

<target name="jars" depends="build">

<jar basedir="${build.classes}" jarfile="${build.lib}/${app.jar}"/>

</target>

<!--

====================

create the API documentation

====================

-->

<target name="javadocs" depends="jars"

description="-->create the API documentation">

<!--copy docs手册-->

<copy todir="${build.docs}">

<fileset dir="${docs.dir}"/>

</copy>

<javadoc packagenames="hello.ant.*"

sourcepath="${src.main}"

defaultexcludes="yes"

destdir="${build.docs.api}"

author="true"

verson="true"

use="true"

windowtitle="Docs API">

<doctitle><![CDATA[<h1>hello ant Docs API</h1>]]></doctitle>

<bottom><![CDATA[<i>${app.copyright}</i>]]></bottom>

<tag name="todo" scope="all" description="To do:"/>

</javadoc>

</target>

<!--

====================

create the distribution that can run(archive tasks)

主要是从各目录中把该copy的copy上

====================

-->

<target name="dist" depends="javadoc">

<!--copy bin执行文件-->

<copy todir="${dist.bin}">

<fileset dir="${src.script}"/>

</copy>

<copy todir="${dist.docs}">

<fileset dir="${build.docs}"/>

</copy>

<!--copy lib文件-->

<copy todir="${dist.lib}">

<fileset dir="${build.lib}"/>

</copy>

</target>

<!--

====================

Cleans everything(File Tasks)

例如可以删除build中的文件,留给i发挥吧

====================

-->

</project>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pom.xml是Maven项目的核心配置文件,它包含了项目的基本信息、依赖关系、构建配置等重要信息。下面是pom.xml文件的详细解释: 1. 项目基本信息 ``` <groupId>com.example</groupId> <artifactId>my-project</artifactId> <version>1.0.0</version> ``` - groupId:项目的组织或公司名称。 - artifactId:项目的名称。 - version:项目的版本号。 2. 依赖关系 ``` <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>5.1.6.RELEASE</version> </dependency> </dependencies> ``` - dependencies:依赖关系列表。 - dependency:依赖项。 - groupId:依赖项的组织或公司名称。 - artifactId:依赖项的名称。 - version:依赖项的版本号。 3. 插件 ``` <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> ``` - build:构建配置。 - plugins:插件列表。 - plugin:插件。 - groupId:插件的组织或公司名称。 - artifactId:插件的名称。 - version:插件的版本号。 - configuration:插件的配置。 4. 项目打包方式 ``` <packaging>jar</packaging> ``` - packaging:项目的打包方式,常见的有jar、war、pom等。 5. 项目依赖管理 ``` <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>5.1.6.RELEASE</version> </dependency> </dependencies> </dependencyManagement> ``` - dependencyManagement:依赖管理。 - dependencies:依赖关系列表。 - dependency:依赖项。 - groupId:依赖项的组织或公司名称。 - artifactId:依赖项的名称。 - version:依赖项的版本号。 6. 项目构建描述 ``` <description>This is a sample Maven project.</description> ``` - description:项目的描述。 7. 仓库配置 ``` <repositories> <repository> <id>central</id> <url>http://central.maven.org/maven2/</url> </repository> </repositories> ``` - repositories:仓库列表。 - repository:仓库。 - id:仓库的唯一标识符。 - url:仓库的URL。 8. 插件仓库配置 ``` <pluginRepositories> <pluginRepository> <id>central</id> <url>http://central.maven.org/maven2/</url> </pluginRepository> </pluginRepositories> ``` - pluginRepositories:插件仓库列表。 - pluginRepository:插件仓库。 - id:插件仓库的唯一标识符。 - url:插件仓库的URL。 9. 构建配置 ``` <build> <sourceDirectory>src/main/java</sourceDirectory> <testSourceDirectory>src/test/java</testSourceDirectory> <resources> <resource> <directory>src/main/resources</directory> </resource> </resources> <testResources> <testResource> <directory>src/test/resources</directory> </testResource> </testResources> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> ``` - build:构建配置。 - sourceDirectory:源代码目录。 - testSourceDirectory:测试代码目录。 - resources:资源目录列表。 - resource:资源目录。 - directory:资源目录的路径。 - testResources:测试资源目录列表。 - testResource:测试资源目录。 - plugins:插件列表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值