From a3e03be058a9b9a2caf36c5b18f66c0fc3df3bf0 Mon Sep 17 00:00:00 2001 From: Eric Andersen Date: Tue, 8 May 2001 19:58:20 +0000 Subject: Add in libutil, based on Cory Visi's variant of Michael Shmulevich's libutil port. I have reworked the code quite a bit so that the stuff that is supposed to be in libc is in libc, and I added a bunch of missing stuff so the libutil interface matches that of glibc's libutil. The only caveat is that libutil/login.c is currently a stub. -Erik --- include/pty.h | 40 ++++++++++++++++++++++++++++++++++++++++ include/utmp.h | 3 +++ 2 files changed, 43 insertions(+) create mode 100644 include/pty.h (limited to 'include') diff --git a/include/pty.h b/include/pty.h new file mode 100644 index 000000000..d8550840e --- /dev/null +++ b/include/pty.h @@ -0,0 +1,40 @@ +/* Functions for pseudo TTY handling. + Copyright (C) 1996, 1997, 1999 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public License as + published by the Free Software Foundation; either version 2 of the + License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public + License along with the GNU C Library; see the file COPYING.LIB. If not, + write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ + +#ifndef _PTY_H +#define _PTY_H 1 + +#include + +#include +#include + + +/* Create pseudo tty master slave pair with NAME and set terminal + attributes according to TERMP and WINP and return handles for both + ends in AMASTER and ASLAVE. */ +extern int openpty (int *__amaster, int *__aslave, char *__name, + struct termios *__termp, struct winsize *__winp); + +/* Create child process and establish the slave pseudo terminal as the + child's controlling terminal. */ +extern int forkpty (int *__amaster, char *__name, + struct termios *__termp, struct winsize *__winp); + +#endif /* pty.h */ diff --git a/include/utmp.h b/include/utmp.h index c98caa5ce..e362181aa 100644 --- a/include/utmp.h +++ b/include/utmp.h @@ -44,6 +44,9 @@ extern struct utmp * getutid __P ((struct utmp *)); extern struct utmp * getutline __P ((struct utmp *)); extern struct utmp * pututline __P ((struct utmp *)); extern void endutent __P ((void)); +extern int login_tty (int __fd); +extern void login (const struct utmp *entry); +extern void logwtmp (const char *line, const char *name, const char *host); #ifdef _LIBC struct utmp * __getutent __P ((int)); -- cgit v1.2.3