Ant :Property

properties是由key-value组成的集合,就是Java中的Properties集合。属性的定义使用的是<property>。通常情况下,property值一经设置,就不能再改变了。Property是全局范围的properties中的一个元素,所以每个property都是全局的,是可以被任何的target、task使用。

Ant内置的属性

系统属性

Ant对Java程序的系统属性做了支持,可以直接的访问系统属性:

<project default="showSystemProperties">

<target name="showSystemProperties">

<echo>${java.version}</echo>

<echo>${java.vendor}</echo>

<echo>${java.vendor.url}</echo>

<echo>${java.home}</echo>

<echo>${java.vm.specification.version}</echo>

<echo>${java.vm.specification.vendor}</echo>

<echo>${java.vm.specification.name}</echo>

<echo>${java.vm.version}</echo>

<echo>${java.vm.vendor}</echo>

<echo>${java.vm.name}</echo>

<echo>${java.specification.version}</echo>

<echo>${java.specification.vendor}</echo>

<echo>${java.specification.name}</echo>

<echo>${java.class.version}</echo>

<echo>${java.class.path}</echo>

<echo>${java.library.path}</echo>

<echo>${java.io.tmpdir}</echo>

<echo>${java.compiler}</echo>

<echo>${java.ext.dirs}</echo>

<echo>${os.name}</echo>

<echo>${os.arch}</echo>

<echo>${os.version}</echo>

<echo>${file.separator}</echo>

<echo>${path.separator}</echo>

<echo>${line.separator}</echo>

<echo>${user.name}</echo>

<echo>${user.home}</echo>

<echo>${user.dir}</echo>

</target>

</project>

Ant附加的属性


basedir             the absolute path of the project's basedir (as set
                    with the basedir attribute of <project>).
ant.file            the absolute path of the buildfile.
ant.version         the version of Ant
ant.project.name    the name of the project that is currently executing;
                    it is set in the name attribute of <project>.
ant.project.default-target
                    the name of the currently executing project's
                    default target;  it is set via the default
                    attribute of <project>.
ant.project.invoked-targets
                    a comma separated list of the targets that have
                    been specified on the command line (the IDE,
                    an <ant> task ...) when invoking the current
                    project.
                    This property is set properly when the first target is executed.
                    If you use it in the implicit target (directly
                    under the <project> tag) the list will be
                    empty if no target has been specified while it
                    will contain the project's default target in this
                    case for tasks nested into targets..
ant.java.version    the JVM version Ant detected; currently it can hold
                    the values "1.9", "1.8",
                    "1.7", "1.6", "1.5",
                    "1.4", "1.3" and
                    "1.2".  ant.core.lib the absolute path
                    of the ant.jar file.
ant.home            home directory of Ant
ant.library.dir     the directory that has been used to load Ant's
                    jars from.  In most cases this is ANT_HOME/lib.

<target name="showAntBuildInProperties">

<echo>${basedir}</echo>

<echo>${ant.file}</echo>

<echo>${ant.version}</echo>

<echo>${ant.project.name}</echo>

<echo>${ant.project.default-target}</echo>

<echo>${ant.project.invoked-targets}</echo>

<echo>${ant.java.version}</echo>

<echo>${ant.home}</echo>

<echo>${ant.library.dir}</echo>

</target>

执行结果:

showAntBuildInProperties:

[echo] D:\Ant_Test\task

[echo] D:\Ant_Test\task\build.xml

[echo] Apache Ant(TM) version 1.9.4 compiled on April 29 2014

[echo] ${ant.project.name}

[echo] showAntBuildInProperties

[echo] showAntBuildInProperties

[echo] 1.7

[echo] E:\Program Files\apache\ant\apache-ant-1.9.4

[echo] E:\Program Files\apache\ant\apache-ant-1.9.4\lib

自定义Property

在build.xml中可以使用<property>来自定义属性。属性一经设置,将不可改变。

共有7种方式可以设置属性:

·

Attribute

Description

Required

name

属性名

No

value

属性值

One of these or nested text, when using the name attribute

location

Sets the property to the absolute filename of the given file.

If the value of this attribute is an absolute path,

it is left unchanged (with / and \ characters converted to the current platforms conventions).

Otherwise it is taken as a path relative to the project's basedir and expanded.

refid

Reference to an object defined elsewhere.

Only yields reasonable results for references toPATH like structures or properties.

resource

the name of the classpath resource containing properties settings in properties file format.

One of these, whennot using the name attribute

file

the location of the properties file to load.

url

a url containing properties-format settings.

environment

the prefix to use when retrieving environment variables.

Thus if you specify environment="myenv" you will be able to

access OS-specific environment variables via property names "myenv.PATH" or "myenv.TERM".

Note that if you supply a property name with a final "." it will not be doubled;

i.e. environment="myenv." will still allow access of environment variables

through "myenv.PATH" and "myenv.TERM".

This functionality is currently only implemented on select platforms.

Feel free to send patches to increase the number of platforms on which this functionality is supported ;).
Note also that properties are case-sensitive,

even if the environment
variables on your operating system are not;

e.g. Windows 2000's system path
variable is set to an Ant property named "env.Path" rather than
"env.PATH".

classpath

the classpath to use when looking up a resource.

No

classpathref

the classpath to use when looking up a resource,

given as reference to a <path> defined elsewhere..

No

prefix

Prefix to apply to properties loaded using

fileresource, or url. A "." is
appended to the prefix if not specified.

No

prefixValues

Whether to apply the prefix when expanding the right hand side
of

properties loaded using file,resource, or urlSince
Ant 1.8.2

No (default=false)

relative

If set to true the relative path to basedir is set. Since Ant 1.8.0

No (default=false)

basedir

The basedir to calculate the relative path from. Since
Ant 1.8.0

No (default=${basedir})

Property其实是一种特殊的task,它的作用就是为变量设置值,也可以理解为定义变量。但是我没有将其放在task一节中,是因为它是一种提供值的常用方式。

在Ant构建文件中,有7种方式可以设置property。

1)指定name,以及value或者location的方式

<property name=”xxx” value=”” />或者<property name=”xxx”
location=”” />

如果是value,则是直接设置为字面量。如果是location,则表示该值是一个文件系统上的一个路径,可以设置为绝对路径,也可以设置为相对路径。

示例:

<project default="main">

<target
name="main" depends="showSimpleProperty" />

<property
name="test.ant.property.useValue" value="hello, ant, property,
value" />

<property
name="test.ant.property.useLocation.absoulte"
location="c:/hello"/>

<property
name="test.ant.property.useLocation.relative"
location="."/>

<target
name="showSimpleProperty">

<echo>${test.ant.property.useValue}</echo>

<echo>${test.ant.property.useLocation.absoulte}</echo>

<echo>${test.ant.property.useLocation.relative}</echo>

</target>

</project>

结果:

showSimpleProperty:

[echo] hello,
ant, property, value

[echo] c:\hello

[echo]
D:\Projects\ant_test\property

main:

BUILD SUCCESSFUL

Total time: 0 seconds

2)指定name并以及嵌入文本的方式

<property name=”xxx”>your text
value</property>

3)指定name,refid

示例:

<property
id="test.ant.property.text"

name="test.ant.property.text">your
text value</property>

<target
name="showTextProperty">

<echo>${test.ant.property.text}</echo>

</target>

<property
name="test.ant.property.refid" refid="test.ant.property.text"
/>

<target
name="showRefidProperty">

<echo>${test.ant.property.refid}</echo>

</target>

之前已提到过,每个task都有一个id,property是一种特殊的task,所以也可以为它设置id属性。

4)指定file属性来设置多个Property

Java中两种文件通常作为配置文件:xml、properties。Ant也对properties文件提供了支持。

属性文件可以放在本地文件系统中,可以是网络上某个主机里,也可以是在当前classpath下。针对这几种情况,ant都做了支持。分别通过指定file,url,resource来加载属性文件。

另外,在使用这三种方式(file,url,resource)时,可以指定前缀prefix的。默认情况下是没有前缀的,也就是,定义的变量仍然属性文件中的变量名。如果指定了前缀,就是定义了这样的变量(前缀.属性名)。

file属性是指定本地文件的路径,可以是绝对路径,也可以是相对路径

实例:

属性文件如下:

test.ant.property.propertiesFile.A=hello
a

test.ant.property.propertiesFile.B=hello
b

test.ant.property.propertiesFile.C=hello
c

test.ant.property.propertiesFile.D=hello
d

test.ant.property.propertiesFile.E=hello
e

使用<property
file/>设置属性:

<property
file="./build.properties" />

<target
name="showFileProperty">

<echo>${test.ant.property.propertiesFile.A}</echo>                        <echo>${test.ant.property.propertiesFile.B}</echo>

<echo>${test.ant.property.propertiesFile.C}</echo>

<echo>${test.ant.property.propertiesFile.D}</echo>

</target>

结果如下:

showFileProperty:

[echo] hello a

[echo] hello b

[echo] hello c

[echo] hello d

5)指定URL,通过网络资源来配置

将上面的脚本做如下调整即可测试:

<!--

<property
file="./build.properties" />

-->

<target
name="showFileProperty">

<echo>${test.ant.property.propertiesFile.A}</echo>                        <echo>${test.ant.property.propertiesFile.B}</echo>

<echo>${test.ant.property.propertiesFile.C}</echo>

<echo>${test.ant.property.propertiesFile.D}</echo>

</target>

<property
url="file:///D:/Projects/ant_test/property/build.properties" />

<target
name="showUrlProperty" depends="showFileProperty" />

6)指定resource ,加载classpath下属性文件

如果属性文件放在指定的classpath下,可以通过使用resource来指定属性文件位置。

默认是当前路径下。也就是说在使用resource时,如果指定了classpath属性,则从指定的classpath下加载,如果没有指定,则从当前classpath下加载。

根据上面的说明,可以知道resource是和classpath(或者classpathref)结合使用的。

所以使用resource时,可以是下面三种形式:

<property resource=”xxxx” />

<property resource=”xxxx” classpath=”yyyy”
/>

<property resource=”xxxx”
classpathref=”yyyy” />

7)将环境变量作为property使用

使用方法是:<property
environment=”env” />

这样就是将环境变量作为属性加载的。加载的变量名是:env.XXX。例如环境变量中的PATH、JAVA_HOME,加载后的变量名是:env.JAVA_HOME,env.PATH。

<property
environment="env"/>

<target
name="showEnvironmentProperty">

<echo>${env.JAVA_HOME}</echo>

</target>

Ant :Property的更多相关文章

  1. Cesium原理篇:Property

    之前主要是Entity的一个大概流程,本文主要介绍Cesium的属性,比如defineProperties,Property(ConstantProperty,CallbackProperty,Con ...

  2. python面对对象编程-------5:获取属性的四种办法:@property, __setattr__(__getattr__) ,descriptor

    一:最基本的属性操作 class Generic: pass g= Generic() >>> g.attribute= "value" #创建属性并赋值 > ...

  3. OC中两个关键字的作用:@property和@synthesize

    两个关键字的使用:@property和@synthesize 一.@property关键字这个关键字是OC中能够快速的定义一个属性的方式,而且他可以设置一些值,就可以达到一定的效果,比如引用计数的问题 ...

  4. python对象属性管理(2):property管理属性

    使用Property管理属性 python提供了一种友好的getter.setter.deleter类方法的属性管理工具:property. property()是一个内置函数,它返回一个Proper ...

  5. 搭建Turbine时,报错误:Property or field 'default' cannot be found on object of type 'com.netflix.appinfo.InstanceInfo'

    Spring Boot + Eureka Server + Hystrix with Turbine: empty turbine.stream 配置的时候遇到了问题: Property or fie ...

  6. spring property标签中的 ref属性和ref 标签有什么不同? 如下:<property name="a" ref="b" />

    spring property标签中的 ref属性和ref 标签有什么不同? 如下:<property name="a" ref="b" /> sp ...

  7. Python进阶:@property 动态属性

    Python进阶:@property 动态属性 Python 动态属性的概念可能会被面试问到,在项目当中也非常实用,但是在一般的编程教程中不会提到,可以进修一下. 先看一个简单的例子.创建一个 Stu ...

  8. spring boot 2.0.0 + mybatis 报:Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required

    spring boot 2.0.0 + mybatis 报:Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required 无法启动 ...

  9. 第7.27节 Python案例详解: @property装饰器定义属性访问方法getter、setter、deleter

    上节详细介绍了利用@property装饰器定义属性的语法,本节通过具体案例来进一步说明. 一.    案例说明 本节的案例是定义Rectangle(长方形)类,为了说明问题,除构造函数外,其他方法都只 ...

随机推荐

  1. Android之debug---menu的getActionView()return null

    MainActivity代码 @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this a ...

  2. 深入seajs源码系列二

    模块类和状态类 参照上文的demo,我们结合源码分析在简单的API调用的背后,到底使用了什么技巧来实现各个模块的依赖加载以及模块API的导出. 首先定义了一个Module类,对应与一个模块 funct ...

  3. Cesium原理篇:6 Renderer模块(2: Texture)

    Texture也是WebGL中重要的概念,使用起来也很简单.但有句话叫大道至简,如果真的想要用好纹理,里面的水其实也是很深的.下面我们来一探究竟. 下面是WebGL中创建一个纹理的最简过程: var ...

  4. FineUI Grid控件高度自适应

    引言 页面里使用f:Grid控件,添加分页功能,然后高度填充整个页面. 如何使用 使用FineUI 控件的每个页面都有一个f:PageManager控件,它包含属性:AutoSizePanelID,设 ...

  5. YAML 语法

    YAML 语法 来源:yaml 这个页面提供一个正确的 YAML 语法的基本概述, 它被用来描述一个 playbooks(我们的配置管理语言). 我们使用 YAML 是因为它像 XML 或 JSON ...

  6. jQuery-1.9.1源码分析系列(九) CSS操作

    jquery.fn.css获取当前jQuery所匹配的元素中第一个元素的属性值[$(…).css(cssName),注意这个cssName可以是数组]或给当前jQuery所匹配的每个元素设置样式值[$ ...

  7. 【翻译】设计模式学习系列1---【Design Patterns Simplified: Part 1【设计模式简述:第一部分】】

    原文链接:http://www.c-sharpcorner.com/UploadFile/19b1bd/design-patterns-simplified-part1/ Design Pattern ...

  8. [Excel] 打印设置

    Excel 中每一个 WorkSheet 都有一个 PageSetup 对象,用于设置打印属性: 一:页面 1. Orientation,返回或设置一个 XlPageOrientation 值,表示纵 ...

  9. C#基础-邮件发送

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  10. centos安装禅道的步骤

    1.下载 XAMPP 套件: https://sourceforge.net/projects/xampp/files/XAMPP%20Linux/stats/timeline  下载的文件是 xam ...