aboutsummaryrefslogtreecommitdiff
path: root/REORG.TODO/hurd/get-host.c
diff options
context:
space:
mode:
Diffstat (limited to 'REORG.TODO/hurd/get-host.c')
-rw-r--r--REORG.TODO/hurd/get-host.c92
1 files changed, 92 insertions, 0 deletions
diff --git a/REORG.TODO/hurd/get-host.c b/REORG.TODO/hurd/get-host.c
new file mode 100644
index 0000000000..be8345fbf9
--- /dev/null
+++ b/REORG.TODO/hurd/get-host.c
@@ -0,0 +1,92 @@
+/* Get a host configuration item kept as the whole contents of a file.
+ Copyright (C) 1996-2017 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, see
+ <http://www.gnu.org/licenses/>. */
+
+#include <fcntl.h>
+#include <hurd.h>
+#include <hurd/lookup.h>
+#include "hurdhost.h"
+#include <string.h>
+
+ssize_t
+_hurd_get_host_config (const char *item, char *buf, size_t buflen)
+{
+ error_t err;
+ char *data;
+ mach_msg_type_number_t nread, more;
+ file_t config;
+
+ err = __hurd_file_name_lookup (&_hurd_ports_use, &__getdport, 0,
+ item, O_RDONLY, 0, &config);
+ switch (err)
+ {
+ case 0: /* Success; read file contents below. */
+ break;
+
+ case ENOENT: /* ? Others? All errors? */
+ /* The file does not exist, so no value has been set. Rather than
+ causing gethostname et al to fail with ENOENT, give an empty value
+ as other systems do before sethostname has been called. */
+ if (buflen != 0)
+ *buf = '\0';
+ return 0;
+
+ default:
+ return __hurd_fail (err);
+ }
+
+ data = buf;
+ nread = buflen;
+ err = __io_read (config, &data, &nread, -1, buflen);
+ if (! err)
+ /* Check if there is more in the file we didn't read. */
+ err = __io_readable (config, &more);
+ __mach_port_deallocate (__mach_task_self (), config);
+ if (err)
+ return __hurd_fail (err);
+ if (data != buf)
+ {
+ memcpy (buf, data, nread);
+ __vm_deallocate (__mach_task_self (), (vm_address_t) data, nread);
+ }
+
+ /* If the file is empty, give an empty value. */
+ if (nread == 0)
+ {
+ if (buflen != 0)
+ *buf = '\0';
+ return 0;
+ }
+
+ /* Remove newlines in case someone wrote the file by hand. */
+ while (nread > 0 && buf[nread - 1] == '\n')
+ buf[--nread] = '\0';
+
+ /* Null-terminate the result if there is enough space. */
+ if (nread < buflen)
+ buf[nread] = '\0';
+ else
+ if (buf[nread - 1] != '\0')
+ more = 1;
+
+ if (more)
+ /* If we didn't read the whole file, tell the caller to use a bigger
+ buffer next time. */
+ return __hurd_fail (ENAMETOOLONG);
+
+ return nread;
+}