9

我正在尝试在 Ant 中调试宏定义。我似乎找不到一种方法来显示作为元素发送的参数的内容。

<project name='debug.macrodef'>
  <macrodef name='def.to.debug'>
    <attribute name='attr' />
    <element name='elem' />
    <sequential>
      <echo>Sure, the attribute is easy to debug: @{attr}</echo>
      <echo>The element works only in restricted cases: <elem /> </echo>
      <!-- This works only if <elem /> doesn't contain anything but a
           textnode, if there were any elements in there echo would
           complain it doesn't understand them. -->
    </sequential>
  </macrodef>

  <target name='works'>
    <def.to.debug attr='contents of attribute'>
      <elem>contents of elem</elem>
    </def.to.debug>
  </target>

  <target name='does.not.work'>
    <def.to.debug attr='contents of attribute'>
      <elem><sub.elem>contents of sub.elem</sub.elem></elem>
    </def.to.debug>
  </target>
</project>

示例运行:

$ ant works
...
works:
 [echo] Sure, the attribute is easy to debug: contents of attribute
 [echo] The element works only in restricted cases:  contents of elem
...

$ ant does.not.work
...
does.not.work:
 [echo] Sure, the attribute is easy to debug: contents of attribute

BUILD FAILED
.../build.xml:21: The following error occurred while executing this line:
.../build.xml:7: echo doesn't support the nested "sub.elem" element.
...

所以我想我需要一种方法以某种方式将 的内容<elem />放入属性中(某些扩展的宏定义实现可能有这种方法),或者我需要一种<element-echo><elem /></element-echo>可以打印出您放入其中的任何 XML 树的方法。有谁知道其中任何一个的实现?当然,也欢迎任何第三种出乎意料的获取数据的方式。

4

1 回答 1

10

echoxml任务呢?

在您的示例构建文件中替换该行

<echo>The element works only in restricted cases: <elem /> </echo>

<echoxml><elem /></echoxml>

结果是

$ ant does.not.work
...
does.not.work:
     [echo] Sure, the attribute is easy to debug: contents of attribute
<?xml version="1.0" encoding="UTF-8"?>
<sub.elem>contents of sub.elem</sub.elem>

不过,也许不需要 XML 声明。您可以使用 echoxmlfile属性将输出放到一个临时文件中,然后读取该文件并删除声明,或者重新格式化您认为合适的信息。

编辑

经过反思,您可能会接近您所描述的内容,例如您的宏定义的这个顺序主体

<sequential>
  <echo>Sure, the attribute is easy to debug: @{attr}</echo>
  <echoxml file="macro_elem.xml"><elem /></echoxml>
  <loadfile property="elem" srcFile="macro_elem.xml">
    <filterchain>
      <LineContainsRegexp negate="yes">
      <regexp pattern=".xml version=.1.0. encoding=.UTF-8..." />
      </LineContainsRegexp>
    </filterchain>
  </loadfile>
  <echo message="${elem}" />
</sequential>

$ ant does.not.work
...
does.not.work:
     [echo] Sure, the attribute is easy to debug: contents of attribute
     [echo] <sub.elem>contents of sub.elem</sub.elem>
于 2010-07-23T23:19:43.417 回答