From 085d68bcc29ecddb6c48e9f32c20648db28f4417 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott <nicholas.marriott@gmail.com> Date: Wed, 18 Jun 2008 21:14:42 +0000 Subject: [PATCH] Solaris bits. --- compat/forkpty-sunos.c | 28 +++++++++++++++++++--------- 1 file changed, 19 insertions(+), 9 deletions(-) diff --git a/compat/forkpty-sunos.c b/compat/forkpty-sunos.c index 27a44bc2..e333b80e 100644 --- a/compat/forkpty-sunos.c +++ b/compat/forkpty-sunos.c @@ -1,4 +1,4 @@ -/* $Id: forkpty-sunos.c,v 1.2 2008-06-18 20:11:25 nicm Exp $ */ +/* $Id: forkpty-sunos.c,v 1.3 2008-06-18 21:14:42 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -45,19 +45,29 @@ forkpty(int *master, if ((slave = open(path, O_RDWR)) == -1) goto out; - if (ioctl(slave, I_PUSH, "ptem") == -1) - fatal("ioctl failed"); - if (ioctl(slave, I_PUSH, "ldterm") == -1) - fatal("ioctl failed"); - - if (ioctl(slave, TIOCSWINSZ, ws) == -1) - fatal("ioctl failed"); - switch (pid = fork()) { case -1: goto out; case 0: close(*master); + + setsid(); + if (ioctl(slave, TIOCSCTTY, NULL) == -1) + fatal("ioctl failed"); + + if (ioctl(slave, I_PUSH, "ptem") == -1) + fatal("ioctl failed"); + if (ioctl(slave, I_PUSH, "ldterm") == -1) + fatal("ioctl failed"); + + if (ioctl(slave, TIOCSWINSZ, ws) == -1) + fatal("ioctl failed"); + + dup2(slave, 0); + dup2(slave, 1); + dup2(slave, 2); + if (slave > 2) + close(slave); return (0); }