How to redirect stdout stderr in an ant script?

10.2k Views Asked by At

I am triggering an ant script (via cruise control), and would like to be able to dump the std out and std err for a particular ant target to a plain text file.

Yes, I am aware that cruise control already does maintain an XML log file containing this information (among many other things), but for portability reasons, I need this to happen from the ant script itself.

Is this possible, and if so, how to do it?

Many thanks!

3

There are 3 best solutions below

0
On BEST ANSWER

The recorder task may be able to do what you want:

<record name="log.txt" action="start"/>
...
<record name="log.txt" action="stop"/>

Beyond that, certain tasks (exec, java, etc) offer this functionality by themselves (usually by means of output and error arguments)

1
On

Try this:

<java classname="some.package.Class"
    fork="yes"
    output="stdouterr.txt">
    ...
</java>

stdouterr.txt will contain both stdout and stderr

<java classname="some.package.Class"
    fork="yes"
    output="stdout.txt"
    error="stderr.txt">
    ...
</java>

stdout.txt and stderr.txt will contain stdout and stderr respectively

From my experience, the record task tends to fail when the ant script is run on cruise control, due to file access permissions (if someone can tell me how to fix that I'll be a happy man).

HTH

1
On

It's easy:

ant -logfile <logfile> <command>

And you can also say to ant shut up:

ant -q <command>

It worked fine to me.