aboutsummaryrefslogtreecommitdiff
path: root/pty.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2017-01-23 12:26:06 +0000
committerNicholas Marriott <nicholas.marriott@gmail.com>2017-01-23 12:26:06 +0000
commit1ebe79dd628f009108c3d6dbdbfbfc69b7a6933d (patch)
tree9ddce6c3f7386d1f01358663871d1f1c355d512c /pty.c
parentb3a724f30ced2f3be3a52fb54c6551b2b6c6de63 (diff)
downloadrtmux-1ebe79dd628f009108c3d6dbdbfbfc69b7a6933d.tar.gz
rtmux-1ebe79dd628f009108c3d6dbdbfbfc69b7a6933d.tar.bz2
rtmux-1ebe79dd628f009108c3d6dbdbfbfc69b7a6933d.zip
Use forkpty() except on OpenBSD.
Diffstat (limited to 'pty.c')
-rw-r--r--pty.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/pty.c b/pty.c
index 05a02ef0..6db623f9 100644
--- a/pty.c
+++ b/pty.c
@@ -19,13 +19,14 @@
#include <sys/types.h>
#include <sys/ioctl.h>
#include <sys/time.h>
+#ifdef __OpenBSD__
#include <sys/tty.h>
+#endif
#include <fcntl.h>
#include <string.h>
#include <termios.h>
#include <unistd.h>
-#include <util.h>
int pty_open(int *);
pid_t pty_fork(int, int *, char *, size_t, struct winsize *);
@@ -33,15 +34,20 @@ pid_t pty_fork(int, int *, char *, size_t, struct winsize *);
int
pty_open(int *fd)
{
+#ifdef __OpenBSD__
*fd = open(PATH_PTMDEV, O_RDWR|O_CLOEXEC);
if (*fd < 0)
return (-1);
+#else
+ *fd = -1;
+#endif
return (0);
}
pid_t
pty_fork(int ptmfd, int *fd, char *name, size_t namelen, struct winsize *ws)
{
+#ifdef __OpenBSD__
struct ptmget ptm;
pid_t pid;
@@ -64,4 +70,7 @@ pty_fork(int ptmfd, int *fd, char *name, size_t namelen, struct winsize *ws)
*fd = ptm.cfd;
close(ptm.sfd);
return (pid);
+#else
+ return (forkpty(fd, name, NULL, ws));
+#endif
}