commit:     a6391f44ee6c68d674ae8425983467b971710d5d
Author:     William Hubbs <w.d.hubbs <AT> gmail <DOT> com>
AuthorDate: Sat Apr 25 20:37:52 2015 +0000
Commit:     William Hubbs <williamh <AT> gentoo <DOT> org>
CommitDate: Sat Apr 25 21:37:09 2015 +0000
URL:        https://gitweb.gentoo.org/proj/openrc.git/commit/?id=a6391f44

mtab: move toward requiring /etc/mtab to be a symbolic link

This changes the mtab service in the following way:

- If /etc/mtab is a symbolic link, success is returned.
- If /etc is not writable, we warn that we could not update /etc/mtab
  and return success.
- If /etc/mtab does not exist, we create a symbolic link from
  /etc/mtab to /proc/self/mounts.
- Otherwise, we warn that updating /etc/mtab as a file is
  deprecated and continue to update it after outputting instructions to
  the user for how to move it to a symbolic link.

 init.d/mtab.in | 44 +++++++++++++++++++++++---------------------
 1 file changed, 23 insertions(+), 21 deletions(-)

diff --git a/init.d/mtab.in b/init.d/mtab.in
index e38d33e..3ac39ed 100644
--- a/init.d/mtab.in
+++ b/init.d/mtab.in
@@ -12,28 +12,30 @@ depend()
 
 start()
 {
-       if [ -L /etc/mtab ]; then
-               return 0
-       fi
-
+       [ -L /etc/mtab ] && return 0
+       local rc=0
        ebegin "Updating /etc/mtab"
-       vewarn "The support for updating /etc/mtab as a file is"
-       vewarn "deprecated and will be removed in the future."
-       vewarn "Please run the following command as root on your system."
-       vewarn
-       vewarn "ln -snf /proc/self/mounts /etc/mtab"
-       if ! echo 2>/dev/null >/etc/mtab; then
-               ewend 1 "/etc/mtab is not updateable"
-               return 0
-       fi
+       if ! checkpath -W /etc; then
+               rc=1
+       elif [ ! -e /etc/mtab ]; then
+               ln -snf /proc/self/mounts /etc/mtab
+       else
+               ewarn "The support for updating /etc/mtab as a file is"
+               ewarn "deprecated and will be removed in the future."
+               ewarn "Please run the following command as root on your system."
+               ewarn
+               ewarn "ln -snf /proc/self/mounts /etc/mtab"
+               ewarn
 
-       # With / as tmpfs we cannot umount -at tmpfs in localmount as that
-       # makes / readonly and dismounts all tmpfs even if in use which is
-       # not good. Luckily, umount uses /etc/mtab instead of /proc/mounts
-       # which allows this hack to work.
-       grep -v "^[! ]* / tmpfs " /proc/mounts > /etc/mtab
+               # With / as tmpfs we cannot umount -at tmpfs in localmount as 
that
+               # makes / readonly and dismounts all tmpfs even if in use which 
is
+               # not good. Luckily, umount uses /etc/mtab instead of 
/proc/mounts
+               # which allows this hack to work.
+               grep -v "^[! ]* / tmpfs " /proc/mounts > /etc/mtab
 
-       # Remove stale backups
-       rm -f /etc/mtab~ /etc/mtab~~
-       eend 0
+               # Remove stale backups
+               rm -f /etc/mtab~ /etc/mtab~~
+       fi
+       eend $rc "/etc is not writable; unable to create /etc/mtab"
+       return 0
 }

Reply via email to