Incorporated from BSD 4.4-Lite.
authorroland <roland>
Sun, 31 Jul 1994 19:25:40 +0000 (19:25 +0000)
committerroland <roland>
Sun, 31 Jul 1994 19:25:40 +0000 (19:25 +0000)
misc/getusershell.c

index 6cd9b04..2bcdaf7 100644 (file)
@@ -1,6 +1,6 @@
 /*
 /*
- * Copyright (c) 1985 Regents of the University of California.
- * All rights reserved.
+ * Copyright (c) 1985, 1993
+ *     The Regents of the University of California.  All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  */
 
 #if defined(LIBC_SCCS) && !defined(lint)
  */
 
 #if defined(LIBC_SCCS) && !defined(lint)
-static char sccsid[] = "@(#)getusershell.c     5.7 (Berkeley) 2/23/91";
+static char sccsid[] = "@(#)getusershell.c     8.1 (Berkeley) 6/4/93";
 #endif /* LIBC_SCCS and not lint */
 
 #include <sys/param.h>
 #include <sys/file.h>
 #include <sys/stat.h>
 #endif /* LIBC_SCCS and not lint */
 
 #include <sys/param.h>
 #include <sys/file.h>
 #include <sys/stat.h>
-#include <ctype.h>
 #include <stdio.h>
 #include <stdio.h>
+#include <ctype.h>
 #include <stdlib.h>
 #include <unistd.h>
 #include <stdlib.h>
 #include <unistd.h>
-
-#define SHELLS "/etc/shells"
+#include <paths.h>
 
 /*
 
 /*
- * Do not add local shells here.  They should be added in /etc/shells
+ * Local shells should NOT be added here.  They should be added in
+ * /etc/shells.
  */
  */
-static const char *okshells[] =
-    { "/bin/sh", "/bin/csh", 0 };
 
 
-static char **shells, *strings;
-static char **curshell = NULL;
-static char **initshells();
+static char *okshells[] = { _PATH_BSHELL, _PATH_CSHELL, NULL };
+static char **curshell, **shells, *strings;
+static char **initshells __P((void));
 
 /*
 
 /*
- * Get a list of shells from SHELLS, if it exists.
+ * Get a list of shells from _PATH_SHELLS, if it exists.
  */
 char *
 getusershell()
  */
 char *
 getusershell()
@@ -76,7 +74,7 @@ endusershell()
 {
        
        if (shells != NULL)
 {
        
        if (shells != NULL)
-               free((char *)shells);
+               free(shells);
        shells = NULL;
        if (strings != NULL)
                free(strings);
        shells = NULL;
        if (strings != NULL)
                free(strings);
@@ -99,31 +97,31 @@ initshells()
        struct stat statb;
 
        if (shells != NULL)
        struct stat statb;
 
        if (shells != NULL)
-               free((char *)shells);
+               free(shells);
        shells = NULL;
        if (strings != NULL)
                free(strings);
        strings = NULL;
        shells = NULL;
        if (strings != NULL)
                free(strings);
        strings = NULL;
-       if ((fp = fopen(SHELLS, "r")) == (FILE *)0)
-               return(okshells);
+       if ((fp = fopen(_PATH_SHELLS, "r")) == NULL)
+               return (okshells);
        if (fstat(fileno(fp), &statb) == -1) {
                (void)fclose(fp);
        if (fstat(fileno(fp), &statb) == -1) {
                (void)fclose(fp);
-               return(okshells);
+               return (okshells);
        }
        }
-       if ((strings = malloc((unsigned)statb.st_size + 1)) == NULL) {
+       if ((strings = malloc((u_int)statb.st_size)) == NULL) {
                (void)fclose(fp);
                (void)fclose(fp);
-               return(okshells);
+               return (okshells);
        }
        }
-       shells = (char **)calloc((unsigned)statb.st_size / 3, sizeof (char *));
+       shells = calloc((unsigned)statb.st_size / 3, sizeof (char *));
        if (shells == NULL) {
                (void)fclose(fp);
                free(strings);
                strings = NULL;
        if (shells == NULL) {
                (void)fclose(fp);
                free(strings);
                strings = NULL;
-               return(okshells);
+               return (okshells);
        }
        sp = shells;
        cp = strings;
        }
        sp = shells;
        cp = strings;
-       while (fgets(cp, strings + statb.st_size - cp, fp) != NULL) {
+       while (fgets(cp, MAXPATHLEN + 1, fp) != NULL) {
                while (*cp != '#' && *cp != '/' && *cp != '\0')
                        cp++;
                if (*cp == '#' || *cp == '\0')
                while (*cp != '#' && *cp != '/' && *cp != '\0')
                        cp++;
                if (*cp == '#' || *cp == '\0')
@@ -133,7 +131,7 @@ initshells()
                        cp++;
                *cp++ = '\0';
        }
                        cp++;
                *cp++ = '\0';
        }
-       *sp = (char *)0;
+       *sp = NULL;
        (void)fclose(fp);
        return (shells);
 }
        (void)fclose(fp);
        return (shells);
 }