例如
/test/a.jar
/test/b.jar
/test/c.jar
output:
a.jar
b.jar
c.jar
这在大多数情况下工作,除了它似乎只获得一个文件,而不是全部=/
<for param="file">
<path>
<fileset dir="${test.dir}/lib">
<include name="**/*.jar"/>
</fileset>
</path>
<sequential>
<basename property="filename" file="@{file}"/>
<echo message="${filename}"/>
</sequential>
</for>
这正好抓住了我:
c.jar
c.jar
c.jar
您遇到的问题是Ant属性的不可变性-一旦设置了属性,其值通常不能更改。
第一次循环设置filename
属性,并且该值"保持不变"。
自Ant 1.8以来,local
任务允许您将属性定位到当前执行块。例如,您的sequential
将是:
<sequential>
<local name="filename" />
<basename property="filename" file="@{file}"/>
<echo message="${filename}"/>
</sequential>
Ant忘记了序列末尾的属性,因此可以在每次迭代中使用一个新值。
我已经有一段时间没有用蚂蚁做任何事情了,但是你试过每一个吗?
<foreach>
<fileset dir="${test.dir}/lib">
<include name="**/*.jar"/>
</fileset>
<echo message="${foreach.file}"/>
</foreach>
列出目录中的文件。
<fileset id="filesref" dir="path/to/dir" includes="*"/>
<property name="files" refid="filesref"/>
<echo message="Files:${line.separator}" />
<for list="${files}" delimiter=";" param="file" >
<sequential>
<echo message=" @{file}"/>
<!--Do more stuff with the file's name here-->
</sequential>
</for>
获取文件名及其大小的列表。
E:ANT>ant -buildfile=nashornFileNames.xml
Buildfile: E:ANTnashornFileNames.xml
<?xml version="1.0" encoding="ISO-8859-1"?>
<project name="MyProject" basedir="." default="fileNames">
<property environment="env"/>
<property name="library.file" value="E:\ANT\JAR"/>
<condition property="fileSep" value=""><os family="windows"/></condition>
<condition property="fileSep" value="/"><os family="unix"/></condition>
<target name="fileNames" depends="showEnv">
<!-- script run both on rhino and nashorn -->
<script language="javascript"> <![CDATA[
// "nashorn:" pseudo URL scheme for nashorn's built-in scripts.
// To support Rhino load Mozilla compatibility script - which defines global functions like importPackage, importClass for rhino compatibility.
load("nashorn:mozilla_compat.js");
// Accessing Java packages and classes from script. Nashorn's recommended way to access Java classes is to use Java.type.
importPackage(java.io) // Rhino extensions: importPackage global function
importClass(java.lang.System); // Rhino extensions: global.importClass
var File = java.io.File; // Rhino way!
var String = Java.type("java.lang.String"); // Nashorn way!
// Access to Ant-Properties by their names
basedir = self.getProject().getProperty("basedir");
fileSep = project.getProperty("fileSep");
System.out.println(" [script command-line] Java API : " + fileSep);
// create and use a Task via Ant API
echo = self.getProject().createTask("echo");
function setMessage( msg ) {
echo.setMessage( msg );
echo.perform();
}
setMessage("[echo Task] Ant API : " + basedir );
// <fileset dir="" includes=""/> « https://ant.apache.org/manual/Types/fileset.html
var fileset = project.createDataType("fileset");
files = project.getProperty("library.file");
setMessage("files: " + files);
fileset.setDir( new File( files ) );
fileset.setIncludes("**/*.jar");
// Get the files (array) of that fileset
ds = fileset.getDirectoryScanner( self.getProject() );
fileset_files = ds.getIncludedFiles(); // Get only the files
// iterate over that array
for (i=0; i < fileset_files.length; i++) {
var basedir = fileset.getDir( self.getProject() );
var filePath = fileset_files[i];
var folders = filePath.split(fileSep).slice(0,-1).join(fileSep);
var fileName = filePath.split(fileSep).slice(-1)[0];
var file = new File(basedir, filePath);
var fileSize = file.length();
setMessage(folders + "« FileName : "+ fileName +" : " + fileSize + " byte");
}
]]></script>
</target>
<target name="showEnv">
<echo message="java.io.tmpdir = ${java.io.tmpdir}"/>
<echo message="windows tmpdir = ${env.TMP}"/>
<echo message="windows JAVA_HOME = ${env.JAVA_HOME}"/>
<echo message="windows ANT_HOME = ${env.ANT_HOME}"/>
</target>
</project>
Oracle Nashorn作为命令行工具和Java应用程序中的嵌入式解释器wiki
Nashorn是一个JavaScript ecma兼容的引擎,由Oracle用Java编程语言开发。它基于达芬奇机器 (JSR 292),并与Java 8一起发布。_jdk.nashorn.api.scripting.NashornScriptEngine
<一口> openjdk 一口>
直到Java SE 7, jdk都附带了一个基于Mozilla Rhino的JavaScript脚本引擎。Java SE 8将附带一个名为Oracle Nashorn的新引擎,该引擎基于JSR 292和invokedynamic。它提供了与ECMA规范化JavaScript规范更好的遵从性,并通过invokedynamic绑定调用站点提供了更好的运行时性能。
Nashorn扩展和一些已经被Nashorn支持的Rhino特定扩展。例:
var String = Java.type("java.lang.String"); // Nashorn way!
var Array = java.lang.reflect.Array // Rhino way!
// collections are interpreted as arrays.
var arr = [ "hello", "world" ];
var list = Java.to(array, Java.type("java.util.List"))
只有当你加载由nashorn提供的兼容性脚本时才支持Rhino/Mozilla扩展。使用"load(' nashorn:mozilla_compat.js
")