在下面的ant脚本片段中,我正在处理目录中的所有conn.xml文件,以确定是否存在除MyDB之外的数据库条目。此代码仅设置最后一个匹配的DB名称,因为通常只有一个这样的文件。但我想命名具有此无效条目的确切文件(包含所有包含的文件)。
<xmltask>
<fileset dir="${srcdir}/../apps" includes="*/conn.xml"/>
<copy path="//Reference[@name!='MyDB']/@name" attrvalue="true" property="bad_connection_name"/>
</xmltask>
我可以在copy命令的“path”字段中使用哪个参数来打印当前文件名?
答案 0 :(得分:2)
xmltask copy的path属性仅包含要复制的元素的XPath引用
如果要捕获所有匹配项,则需要为xmltask副本设置属性追加,见xmltask manual:
设置为true时,附加到给定的缓冲区或属性。您可以 仅在创建新属性时附加,因为Ant属性是 不可变的(即当XPath解析为多个文本节点时)
<copy path="//Reference[@name!='MyDB']/@name" attrvalue="true" property="bad_connection_name" append="true"/>
您也可以设置propertySeparator,默认=&#39;,&#39;
但是,使用错误连接字符串获取所有文件的一种更简单的方法是使用selector这样的文件集:
<fileset dir="${srcdir}/../apps" includes="*/conn.xml" id="foo">
<contains text=" your bad Connection string goes here "/>
</fileset>
<!-- simple echo -->
<echo>${toString:foo}</echo>
<!-- convert to one file one line -->
<pathconvert refid="foo" pathsep="${line.separator}" property="foobar"/>
<!-- echo to ant logger/stdout -->
<echo>${foobar}</echo>
<!-- write to file -->
<echo file="path/to/badconnection.txt">${foobar}</echo>
如果错误的连接字符串不是静态的,请使用containsregexp选择器而不是contains。
答案 1 :(得分:1)
<target name="check_connection_violations">
<xmltask source="${file}">
<copy path="//Reference[@className='oracle.jdeveloper.db.adapter.DatabaseProvider' and @name!='MyDB']/@name" attrvalue="true" property="bad_connection_name"/>
</xmltask>
<if>
<isset property="bad_connection_name"/>
<then>
<echo message="${file} has connection violation due to ${bad_connection_name} entry. ${line.separator}" file="${basedir}/conn_name_violation.txt" append="true"/>
</then>
</if>
</target>
以上是新添加的目标。以下是循环调用它的原始代码段:
<foreach target="check_connection_violations" param="file">
<fileset dir="${srcdir}/../apps" includes="*/conn.xml"/>
</foreach>