about summary refs log tree commit diff
path: root/src/misc/getusershell.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2012-04-22 14:41:54 -0400
committerRich Felker <dalias@aerifal.cx>2012-04-22 14:41:54 -0400
commit90da74ef51ddd51924042ee42b5e766908e9980c (patch)
treeeaffdd07abc1c64b4595c0ec5d10605033fd25c3 /src/misc/getusershell.c
parent431a4cd4df25dd9cc9fd699c59036f896aef1003 (diff)
downloadmusl-90da74ef51ddd51924042ee42b5e766908e9980c.tar.gz
musl-90da74ef51ddd51924042ee42b5e766908e9980c.tar.xz
musl-90da74ef51ddd51924042ee42b5e766908e9980c.zip
implement getusershell, etc. legacy functions
I actually wrote these a month ago but forgot to integrate them. ugly,
probably-harmful-to-use functions, but some legacy apps want them...
Diffstat (limited to 'src/misc/getusershell.c')
-rw-r--r--src/misc/getusershell.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/misc/getusershell.c b/src/misc/getusershell.c
new file mode 100644
index 00000000..11e697b6
--- /dev/null
+++ b/src/misc/getusershell.c
@@ -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;
+}