about summary refs log tree commit diff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1999-05-23 19:18:19 +0000
committerRoland McGrath <roland@gnu.org>1999-05-23 19:18:19 +0000
commit043032f443161389640449efa58e6ec9279684ce (patch)
treeba84200145997911c32baa904c9125154d63789a
parent8aba992a60cbe815ddcd14ffb51f2aa1186a6ed0 (diff)
downloadglibc-043032f443161389640449efa58e6ec9279684ce.tar.gz
glibc-043032f443161389640449efa58e6ec9279684ce.tar.xz
glibc-043032f443161389640449efa58e6ec9279684ce.zip
1999-05-23 Roland McGrath <roland@baalperazim.frob.com>
* hurd/set-host.c (_hurd_set_host_config): Use mode 0644, not 0600. 
Do proper error return.
-rw-r--r--hurd/set-host.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/hurd/set-host.c b/hurd/set-host.c
index eee50fc08e..889f532885 100644
--- a/hurd/set-host.c
+++ b/hurd/set-host.c
@@ -1,5 +1,5 @@
 /* Set a host configuration item kept as the whole contents of a file.
-   Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+   Copyright (C) 1996, 1997, 1999 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
@@ -27,23 +27,24 @@ _hurd_set_host_config (const char *item, const char *value, size_t valuelen)
   error_t err;
   mach_msg_type_number_t nwrote;
   file_t new, dir;
+  char *name;
 
-  dir = __file_name_split (item, (char **)&item);
+  dir = __file_name_split (item, &name);
   if (dir == MACH_PORT_NULL)
     return -1;
 
   /* Create a new node.  */
-  err = __dir_mkfile (dir, O_CREAT|O_TRUNC, 0600, &new);
+  err = __dir_mkfile (dir, O_CREAT|O_TRUNC, 0644, &new);
   if (! err)
     {
       /* Write the contents.  */
       err = __io_write (new, value, valuelen, 0, &nwrote);
       if (! err)
 	/* Atomically link the new node onto the name.  */
-	err = __dir_link (dir, new, item, 0);
+	err = __dir_link (dir, new, name, 0);
       __mach_port_deallocate (__mach_task_self (), new);
     }
   __mach_port_deallocate (__mach_task_self (), dir);
 
-  return nwrote;
+  return err ? __hurd_fail (err) : nwrote;
 }