Fixed compilation with local changes (to be commited later).

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@5263 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2003-11-06 00:10:03 +00:00
parent b86315d90a
commit ea2aba5dc9

View File

@ -3,6 +3,9 @@
** Distributed under the terms of the OpenBeOS License.
*/
#include <SupportDefs.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
@ -15,66 +18,61 @@
#define DEV_TTY "/dev/tt/"
/*
* ttyname - return the full pathname of the tty device
* (NULL if not a tty or an error occurs)
/** return the full pathname of the tty device
* (NULL if not a tty or an error occurs)
*/
char *
ttyname (int fd)
ttyname(int fd)
{
static char pathname[MAXPATHLEN];
char *stub = pathname + sizeof(DEV_TTY) - 1;
int stubLen = sizeof(pathname) - sizeof(DEV_TTY);
struct stat fdStat;
DIR *dir;
bool found = false;
// first, some sanity checks:
if (!isatty(fd))
return NULL;
if (fstat(fd, &fdStat) < 0)
return NULL;
if (!S_ISCHR(fdStat.st_mode))
return NULL;
// start with the root tty directory at /dev
strcpy(pathname, DEV_TTY);
if ((dir = opendir(pathname)) != NULL) {
// find a matching entry in the directory:
// we must match both the inode for the file
// and the device that the file resides on
struct dirent *e;
struct stat entryStat;
while ((e = readdir(dir)) != NULL) {
// try to match the file's inode
if (e->d_ino != fdStat.st_ino)
continue;
// construct the entry's full filename and
// call stat() to retrieve the inode info
strncpy(stub, e->d_name, stubLen);
if (stat(pathname, &entryStat) < 0)
continue;
if (entryStat.st_ino == fdStat.st_ino &&
entryStat.st_dev == fdStat.st_dev) {
found = true;
break;
}
}
closedir(dir);
}
return found ? pathname : NULL;
}