下面的Ant构建文件片段尝试简单地输出每个sql脚本运行之前和之后的时间。我不能改变Ant目标的结构(create-tables必须像它一样调用run-sql-script )。问题是属性(time和time2)是不可变的(http://ant.apache.org/manual/Tasks/property.html),因此只对第一次操作计时,而不对第二次操作计时。有没有办法在Ant中做我想做的事情?
<target name="create-tables">
<antcall target="run-sql-script">
<param name="db.script" value="teams.sql"/>
</antcall>
<!-- Create the base UDM schema. -->
<antcall target="run-sql-script">
<param name="db.script" value="players.sql"/>
</antcall>
</target>
<target name="run-sql-script">
<tstamp>
<format property="time" pattern="MM/dd/yyyy hh:mm:ss aa"
offset="-5" unit="hour"/>
</tstamp>
<echo>before: ${time}</echo>
<sql
classpath="${classpath}"
driver="${db.driver}"
url="${db.url}"
userid="${db.userid}"
password="${db.password}"
src="${script.dir}/${db.script}"
delimiter="${script.delimiter}"
onerror="abort">
</sql>
<tstamp>
<format property="time2" pattern="MM/dd/yyyy hh:mm:ss aa"
offset="-5" unit="hour"/>
</tstamp>
<echo>after: ${time2}</echo>
</target>
https://stackoverflow.com/questions/1472301
复制相似问题