Annotation of researchv9/cmd/emacs/findtty.c, revision 1.1

1.1     ! root        1: #include <stdio.h>
        !             2: #include "stddefs.h"
        !             3: #include <sys/types.h>
        !             4: #include <sys/stat.h>
        !             5: #include <utmp.h>
        !             6: 
        !             7: /* Returns a pointer to a character string containing the tty name of a
        !             8:  * logged-on user.  If the user is logged on more than once, the tty
        !             9:  * returned is the one that has been used most recently.  If the user is
        !            10:  * not presently logged on, the null string is returned.  Each call to
        !            11:  * findtty returns a pointer to the same data area, so the string must
        !            12:  * be copied if it is to be used again.
        !            13:  *
        !            14:  * NOTE: if this code is compiled with the "-DMAIN" option, then a main
        !            15:  * program will be produced, instead of a function.  The main program
        !            16:  * takes one user name as argument and outputs the ttyname on standard
        !            17:  * output.
        !            18:  *
        !            19:  * J. Leth, IH 6E-318, x6133.
        !            20:  */
        !            21: 
        !            22: #define NAMELEN        8
        !            23:        /* Max. number of characters in a login name */
        !            24: #define TTYLEN 8
        !            25:        /* Max. number of characters in a tty name */
        !            26: 
        !            27: #ifndef MAIN
        !            28: char *
        !            29: findtty(user)
        !            30:        char *user;     /* user login name */
        !            31: {
        !            32: 
        !            33: #else
        !            34: main(argc, argv)
        !            35:        int argc;
        !            36:        char *argv[];
        !            37: {
        !            38:        char *user;
        !            39: #endif
        !            40: 
        !            41:        extern long ftime();
        !            42:        extern int strcmp();
        !            43: 
        !            44:        FILE *f;
        !            45:        struct utmp buf;
        !            46:        long ttytime = 0L;
        !            47:                /* Holds latest access time found for requested user */
        !            48:        static char ttyname[TTYLEN+1];
        !            49:                /* Holds name of tty with that access time */
        !            50:        long acc_time = 0L;
        !            51:                /* Access time of tty currently being considered */
        !            52:        char *utmp = "/etc/utmp";
        !            53: 
        !            54:        if((f=fopen(utmp,"r"))==NULL) {
        !            55:                errexit("findtty: can't open %s file.\n", utmp);
        !            56:        }
        !            57: 
        !            58:        ttyname[0] = NUL;
        !            59: 
        !            60: #ifdef MAIN
        !            61:        if (argc != 2) {
        !            62:                usage("Usage:\tfindtty <login-id>\n\
        !            63:        Outputs the name of the most recently-used terminal on which\n\
        !            64:        user <login-id> is currently logged in.\n");
        !            65:        }
        !            66: 
        !            67:        user = argv[1];
        !            68: #endif
        !            69: 
        !            70:        while(fread(&buf,sizeof(buf),1,f) == 1) {
        !            71:                /* Search utmp file for logins of the designated user.
        !            72:                 * For each one found, see if the access time is later
        !            73:                 * than the latest one so far; if it is, remember the
        !            74:                 * ttyname and ttytime.
        !            75:                 */
        !            76: 
        !            77:                if(strncmp(buf.ut_name, user, NAMELEN) != 0)    continue;
        !            78: 
        !            79:                if((acc_time=ftime(buf.ut_line)) > ttytime) {
        !            80:                        ttytime = acc_time;
        !            81:                        strncpy(ttyname, buf.ut_line, TTYLEN);
        !            82:                        ttyname[TTYLEN] = '\0';
        !            83:                                /* just to be sure string is terminated */
        !            84:                }
        !            85:        }
        !            86: #ifndef MAIN
        !            87:        return(ttyname);
        !            88: #else
        !            89:        printf("%s\n", ttyname);
        !            90: #endif
        !            91: }
        !            92: 
        !            93: long
        !            94: ftime(s)
        !            95: char *s;
        !            96: {
        !            97:        /* Returns the time of last access for the named device.
        !            98:         * The name given as taken as the last component of the device
        !            99:         * pathname.  The first component, "/dev/" is supplied by this
        !           100:         * routine.  If the device doesn't exist, -1L is returned.
        !           101:         */
        !           102: 
        !           103:        char dev[20];
        !           104:        struct stat statb;
        !           105: 
        !           106:        strcpy(dev,"/dev/");
        !           107:        strcat(dev,s);
        !           108:        if( stat(dev,&statb)<0 )
        !           109:                return(-1L);
        !           110:        return( statb.st_atime );
        !           111: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.