View Single Post
Old 01-04-2011, 08:51   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Cittā: Tra Verona e Mantova
Messaggi: 4553
A meno che non esista un comando (simile al > o >>) che da console di permette di reindirizzare l'output sia sul file che sulla console stessa, puoi reindirizzare l'output del secondo programma java tramite un primo programma java:

Codice:
import java.io.File;
import java.io.IOException;
import java.io.PrintStream;
import java.nio.ByteBuffer;
import java.nio.channels.Channels;
import java.nio.channels.WritableByteChannel;
import java.nio.charset.Charset;

public class Main {
    private static final PrintStream OUT = System.out;
    private static final PrintStream ERR = System.err;

    /* 
     * usage java Main filedilog nomeclassemain
     * es.: java Main pippo.txt test.Main
     * Riproduce l'output di test.Main su pippo.txt e sulla console
     */
    public static void main(String[] args) throws Throwable {
        PrintStream file = null;
        try {
            file = new PrintStream(new File(args[0]));

            System.setErr(createLoggingStream(file, ERR));
            System.setOut(createLoggingStream(file, OUT));
            
            //avvia l'altro programma
            Class.forName(args[1]).getMethod("main", String[].class).invoke(null, (Object)args);
        } finally {
            if(file != null) file.close();
        }
    }

    /* Crea uno stream che "duplica" quel che gli si passa su file e stream */
    private static PrintStream createLoggingStream(final PrintStream file, final PrintStream stream) {
        WritableByteChannel channel = new WritableByteChannel() {
            final Charset charset = Charset.defaultCharset();

            public int write(ByteBuffer src) throws IOException {
                int count = src.limit();
                String text = charset.decode(src).toString();
                file.print(text);
                stream.print(text);
                return count;
            }

            public boolean isOpen() {
                return true;
            }

            public void close() throws IOException {
            }
        };
        return new PrintStream(Channels.newOutputStream(channel));
    }
}
Supponendo che la classe d'avvio del programma bersaglio sia ciccio.Main, diremo:

java Main log.txt ciccio.Main

Devi usare il classpath (java -cp qualcosa Main log.txt ciccio.Main) per indicare alla jvm dove reperire le classi necessarie ad eseguire ciccio.Main.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis č offline   Rispondi citando il messaggio o parte di esso