implement getusershell, etc. legacy functions
authorRich Felker <dalias@aerifal.cx>
Sun, 22 Apr 2012 18:41:54 +0000 (14:41 -0400)
committerRich Felker <dalias@aerifal.cx>
Sun, 22 Apr 2012 18:41:54 +0000 (14:41 -0400)
I actually wrote these a month ago but forgot to integrate them. ugly,
probably-harmful-to-use functions, but some legacy apps want them...

include/unistd.h
src/misc/getusershell.c [new file with mode: 0644]

index 17f024f..9309872 100644 (file)
@@ -163,6 +163,9 @@ char *get_current_dir_name(void);
 int daemon(int, int);
 int getdomainname(char *, size_t);
 int getdtablesize(void);
+void setusershell(void);
+void endusershell(void);
+char *getusershell(void);
 #endif
 
 #define _XOPEN_VERSION          700
diff --git a/src/misc/getusershell.c b/src/misc/getusershell.c
new file mode 100644 (file)
index 0000000..11e697b
--- /dev/null
@@ -0,0 +1,33 @@
+#define _GNU_SOURCE
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+static const char defshells[] = "/bin/sh\n/bin/csh\n";
+
+static char *line;
+size_t linesize;
+static FILE *f;
+
+void endusershell(void)
+{
+       if (f) fclose(f);
+       f = 0;
+}
+
+void setusershell(void)
+{
+       if (!f) f = fopen("/etc/shells", "rb");
+       if (!f) f = fmemopen((void *)defshells, sizeof defshells - 1, "rb");
+}
+
+char *getusershell(void)
+{
+       ssize_t l;
+       if (!f) setusershell();
+       if (!f) return 0;
+       l = getline(&line, &linesize, f);
+       if (l <= 0) return 0;
+       if (line[l-1]=='\n') line[l-1]=0;
+       return line;
+}