Mercurial > jhg
view test/com/tmate/hgkit/ExecHelper.java @ 65:e21df6259f83
Log commandline sample updated to use LogCommand
author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
---|---|
date | Fri, 21 Jan 2011 06:17:56 +0100 |
parents | fac8e7fcc8b0 |
children |
line wrap: on
line source
/* * Copyright (c) 2011 Artem Tikhomirov */ package com.tmate.hgkit; import java.io.File; import java.io.IOException; import java.io.InputStreamReader; import java.nio.CharBuffer; import java.util.LinkedList; /** * * @author artem */ public class ExecHelper { private final OutputParser parser; private final File dir; public ExecHelper(OutputParser outParser, File workingDir) { parser = outParser; dir = workingDir; } public void run(String... cmd) throws IOException, InterruptedException { Process p = new ProcessBuilder(cmd).directory(dir).redirectErrorStream(true).start(); // Process p = Runtime.getRuntime().exec(cmd, null, dir); InputStreamReader stdOut = new InputStreamReader(p.getInputStream()); LinkedList<CharBuffer> l = new LinkedList<CharBuffer>(); int r = -1; CharBuffer b = null; do { if (b == null || b.remaining() < b.capacity() / 3) { b = CharBuffer.allocate(512); l.add(b); } r = stdOut.read(b); } while (r != -1); int total = 0; for (CharBuffer cb : l) { total += cb.position(); cb.flip(); } CharBuffer res = CharBuffer.allocate(total); for (CharBuffer cb : l) { res.put(cb); } res.flip(); p.waitFor(); parser.parse(res); } }