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

Side by Side Diff: runtime/bin/process_macos.cc

Issue 8506013: Correct the sign of exit codes for the process library. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Address review comments. Created 9 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « runtime/bin/process_linux.cc ('k') | runtime/bin/process_win.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "bin/process.h" 5 #include "bin/process.h"
6 6
7 #include <errno.h> 7 #include <errno.h>
8 #include <fcntl.h> 8 #include <fcntl.h>
9 #include <signal.h> 9 #include <signal.h>
10 #include <stdio.h> 10 #include <stdio.h>
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after
82 int os_error_message_len) { 82 int os_error_message_len) {
83 SafeStrNCpy(os_error_message, strerror(errno), os_error_message_len); 83 SafeStrNCpy(os_error_message, strerror(errno), os_error_message_len);
84 } 84 }
85 85
86 86
87 void ExitHandler(int process_signal, siginfo_t* siginfo, void* tmp) { 87 void ExitHandler(int process_signal, siginfo_t* siginfo, void* tmp) {
88 int pid = 0; 88 int pid = 0;
89 int status = 0; 89 int status = 0;
90 while ((pid = waitpid(-1, &status, WNOHANG)) > 0) { 90 while ((pid = waitpid(-1, &status, WNOHANG)) > 0) {
91 int exit_code = 0; 91 int exit_code = 0;
92 // TODO(ager): Transform exit_code 255 to -1. 92 int negative = 0;
93 if (WIFEXITED(status)) exit_code = WEXITSTATUS(status); 93 if (WIFEXITED(status)) {
94 // TODO(ager): Transform termsig to -termsig to destinguish from 94 exit_code = WEXITSTATUS(status);
95 // exit codes. 95 if (exit_code == 255) {
96 if (WIFSIGNALED(status)) exit_code = WTERMSIG(status); 96 exit_code = 1;
97 negative = 1;
98 }
99 }
100 if (WIFSIGNALED(status)) {
101 exit_code = WTERMSIG(status);
102 negative = 1;
103 }
97 ProcessInfo* process = LookupProcess(pid); 104 ProcessInfo* process = LookupProcess(pid);
98 if (process != NULL) { 105 if (process != NULL) {
99 intptr_t message[2] = { pid, exit_code }; 106 int message[3] = { pid, exit_code, negative };
100 intptr_t result = 107 intptr_t result =
101 FDUtils::WriteToBlocking(process->fd(), &message, sizeof(message)); 108 FDUtils::WriteToBlocking(process->fd(), &message, sizeof(message));
102 if (result != sizeof(message)) { 109 if (result != sizeof(message)) {
103 perror("ExitHandler notification failed"); 110 perror("ExitHandler notification failed");
104 } 111 }
105 close(process->fd()); 112 close(process->fd());
106 } 113 }
107 } 114 }
108 } 115 }
109 116
(...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after
327 if (result == -1) { 334 if (result == -1) {
328 return false; 335 return false;
329 } 336 }
330 return true; 337 return true;
331 } 338 }
332 339
333 340
334 void Process::Exit(intptr_t id) { 341 void Process::Exit(intptr_t id) {
335 RemoveProcess(id); 342 RemoveProcess(id);
336 } 343 }
OLDNEW
« no previous file with comments | « runtime/bin/process_linux.cc ('k') | runtime/bin/process_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698