diff options
author | Lennart Poettering <lennart@poettering.net> | 2004-01-14 18:08:39 +0000 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2004-01-14 18:08:39 +0000 |
commit | 1b34f889f90cd879367f233c90d98b18dd47d338 (patch) | |
tree | 10025d8103bff429ccfdac18a70158996ba05c7f /src/client-tty.c | |
parent | 94fea1e00bc2115cb9163d53a0d5b25a88d35898 (diff) |
initial commit
git-svn-id: file:///home/lennart/svn/public/bidilink/trunk@3 9cde1c1d-e4d0-0310-8a68-bf217395ea82
Diffstat (limited to 'src/client-tty.c')
-rw-r--r-- | src/client-tty.c | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/client-tty.c b/src/client-tty.c new file mode 100644 index 0000000..e94d560 --- /dev/null +++ b/src/client-tty.c @@ -0,0 +1,55 @@ +#include <unistd.h> +#include <fcntl.h> +#include <stdio.h> +#include <termios.h> +#include <stdlib.h> +#include <string.h> +#include <errno.h> +#include <assert.h> + +#include "client-tty.h" + +struct stream* stream_client_tty(const char *args) { + struct stream *s = NULL; + struct termios ts; + int fd = -1; + + s = malloc(sizeof(struct stream)); + assert(s); + memset(s, 0, sizeof(struct stream)); + + if ((fd = open(args, O_RDWR|O_NOCTTY)) < 0) { + fprintf(stderr, "open('%s', O_RDWR|O_NOCTTY): %s\n", args, strerror(errno)); + goto fail; + } + + if (tcgetattr(fd, &ts) < 0) { + fprintf(stderr, "tcgetattr(): %s\n", strerror(errno)); + goto fail; + } + + cfmakeraw(&ts); + + ts.c_cflag |= HUPCL | CS8 | CLOCAL; + ts.c_iflag |= IGNPAR | IGNBRK; + + ts.c_cc[VMIN] = 1; + ts.c_cc[VTIME] = 0; + + tcflush(fd, TCIOFLUSH); + + if (tcsetattr(fd, TCSANOW, &ts) < 0) { + fprintf(stderr, "tcsetattr(): %s\n", strerror(errno)); + goto fail; + } + + s->input_fd = s->output_fd = fd; + return s; + +fail: + free(s); + if (fd >= 0) + close(fd); + + return NULL; +} |