summaryrefslogtreecommitdiffstats
path: root/base/process_util_posix.cc
diff options
context:
space:
mode:
authormaruel@chromium.org <maruel@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-06-10 18:26:33 +0000
committermaruel@chromium.org <maruel@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-06-10 18:26:33 +0000
commit96878a218c1435911233ab9b5b42efe8d0a88db8 (patch)
tree6ccf804b44ecfb816965a70ae5ce2f924d27fb48 /base/process_util_posix.cc
parent28877041246461af71a33e53fd8b5438843ee12d (diff)
downloadchromium_src-96878a218c1435911233ab9b5b42efe8d0a88db8.zip
chromium_src-96878a218c1435911233ab9b5b42efe8d0a88db8.tar.gz
chromium_src-96878a218c1435911233ab9b5b42efe8d0a88db8.tar.bz2
Changed the position of the output->swap() call. This way, even if the command encounters an error, we still record the output. This is important for the case when stderr has been redirected to stdout, and we'd like to see stdout even when the exit code is non-zero.
Patch contributed by Michael Williamson. Review URL: http://codereview.chromium.org/2665004 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@49423 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/process_util_posix.cc')
-rw-r--r--base/process_util_posix.cc6
1 files changed, 2 insertions, 4 deletions
diff --git a/base/process_util_posix.cc b/base/process_util_posix.cc
index af5ddcb..6c5b5fe 100644
--- a/base/process_util_posix.cc
+++ b/base/process_util_posix.cc
@@ -735,7 +735,6 @@ int64 TimeValToMicroseconds(const struct timeval& tv) {
// specify the path of the application, and |envp| will be used as the
// environment. Redirects stderr to /dev/null. Returns true on success
// (application launched and exited cleanly, with exit code indicating success).
-// |output| is modified only when the function finished successfully.
static bool GetAppOutputInternal(const CommandLine& cl, char* const envp[],
std::string* output, size_t max_output,
bool do_search_path) {
@@ -807,8 +806,8 @@ static bool GetAppOutputInternal(const CommandLine& cl, char* const envp[],
// write to the pipe).
close(pipe_fd[1]);
+ output->clear();
char buffer[256];
- std::string output_buf;
size_t output_buf_left = max_output;
ssize_t bytes_read = 1; // A lie to properly handle |max_output == 0|
// case in the logic below.
@@ -818,7 +817,7 @@ static bool GetAppOutputInternal(const CommandLine& cl, char* const envp[],
std::min(output_buf_left, sizeof(buffer))));
if (bytes_read <= 0)
break;
- output_buf.append(buffer, bytes_read);
+ output->append(buffer, bytes_read);
output_buf_left -= static_cast<size_t>(bytes_read);
}
close(pipe_fd[0]);
@@ -834,7 +833,6 @@ static bool GetAppOutputInternal(const CommandLine& cl, char* const envp[],
return false;
}
- output->swap(output_buf);
return true;
}
}