From: Kristian Høgsberg Date: Fri, 12 Dec 2008 18:39:03 +0000 (-0500) Subject: Don't close uninitialized fd, check forkpty error. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f0c7b2083ac0654dba6508e8ddd5de1a431a95e1;p=profile%2Fivi%2Fweston-ivi-shell.git Don't close uninitialized fd, check forkpty error. --- diff --git a/terminal.c b/terminal.c index 3091a9d..8087938 100644 --- a/terminal.c +++ b/terminal.c @@ -561,7 +561,7 @@ io_handler(GIOChannel *source, static int terminal_run(struct terminal *terminal, const char *path) { - int master, slave; + int master; pid_t pid; pid = forkpty(&master, NULL, NULL, NULL); @@ -571,9 +571,11 @@ terminal_run(struct terminal *terminal, const char *path) printf("exec failed: %m\n"); exit(EXIT_FAILURE); } + } else if (pid < 0) { + fprintf(stderr, "failed to fork and create pty (%m).\n"); + return -1; } - close(slave); terminal->master = master; terminal->channel = g_io_channel_unix_new(master); fcntl(master, F_SETFL, O_NONBLOCK); @@ -608,7 +610,8 @@ int main(int argc, char *argv[]) g_source_attach(source, NULL); terminal = terminal_create(display, fd); - terminal_run(terminal, "/bin/bash"); + if (terminal_run(terminal, "/bin/bash")) + exit(EXIT_FAILURE); g_main_loop_run(loop);