Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1302)

Unified Diff: utils/pub/io.dart

Issue 10386021: Add a Pub source that checks packages out from Git. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: utils/pub/io.dart
diff --git a/utils/pub/io.dart b/utils/pub/io.dart
index e6c79ca853701c5e85fef70008b5c24ef73d3ff2..00defd188efdb4805d8c670dce7351d33a23d82a 100644
--- a/utils/pub/io.dart
+++ b/utils/pub/io.dart
@@ -320,9 +320,13 @@ String getFullPath(entry) => new File(_getPath(entry)).fullPathSync();
* Spawns and runs the process located at [executable], passing in [args].
* Returns a [Future] that will complete the results of the process after it
* has ended.
+ *
+ * If [pipeStdout] and/or [pipeStderr] are set, all output from the subprocess's
+ * output stream(s) to the parent process's output stream(s). Output from piped
Bob Nystrom 2012/05/08 17:01:49 "to the" -> "are sent to the". Also "(s)" -> "s".
nweiz 2012/05/09 00:21:04 Done.
+ * streams won't be available in the result object.
*/
Future<ProcessResult> runProcess(String executable, List<String> args,
- [String workingDir]) {
+ [String workingDir, bool pipeStdout = false, bool pipeStderr = false]) {
int exitCode;
final options = new ProcessOptions();
@@ -348,13 +352,21 @@ Future<ProcessResult> runProcess(String executable, List<String> args,
processStdout, processStderr, exitCode));
}
- outStream.onLine = () => processStdout.add(outStream.readLine());
- outStream.onClosed = checkComplete;
- outStream.onError = (error) => completer.completeException(error);
+ if (pipeStdout) {
+ process.stdout.pipe(stdout, close: false);
+ } else {
+ outStream.onLine = () => processStdout.add(outStream.readLine());
+ outStream.onClosed = checkComplete;
+ outStream.onError = (error) => completer.completeException(error);
+ }
- errStream.onLine = () => processStderr.add(errStream.readLine());
- errStream.onClosed = checkComplete;
- errStream.onError = (error) => completer.completeException(error);
+ if (pipeStderr) {
+ process.stderr.pipe(stderr, close: false);
+ } else {
+ errStream.onLine = () => processStderr.add(errStream.readLine());
+ errStream.onClosed = checkComplete;
+ errStream.onError = (error) => completer.completeException(error);
+ }
process.onExit = (actualExitCode) {
exitCode = actualExitCode;
@@ -375,6 +387,8 @@ class ProcessResult {
final int exitCode;
const ProcessResult(this.stdout, this.stderr, this.exitCode);
+
+ bool get success() => exitCode == 0;
}
/**

Powered by Google App Engine
This is Rietveld 408576698