2013-12-21 14:51:11 -06:00
|
|
|
|
#!@SBINDIR@/openrc-run
|
2015-12-04 16:52:19 -06:00
|
|
|
|
# Copyright (c) 2007-2015 The OpenRC Authors.
|
|
|
|
|
# See the Authors file at the top-level directory of this distribution and
|
|
|
|
|
# https://github.com/OpenRC/openrc/blob/master/AUTHORS
|
|
|
|
|
#
|
|
|
|
|
# This file is part of OpenRC. It is subject to the license terms in
|
|
|
|
|
# the LICENSE file found in the top-level directory of this
|
|
|
|
|
# distribution and at https://github.com/OpenRC/openrc/blob/master/LICENSE
|
|
|
|
|
# This file may not be copied, modified, propagated, or distributed
|
|
|
|
|
# except according to the terms contained in the LICENSE file.
|
2007-11-14 15:22:04 +00:00
|
|
|
|
|
2008-01-11 12:13:46 +00:00
|
|
|
|
depend()
|
|
|
|
|
{
|
2007-04-05 11:18:42 +00:00
|
|
|
|
need localmount
|
|
|
|
|
before logger
|
2013-12-08 12:23:56 -06:00
|
|
|
|
after clock root sysctl
|
2012-07-02 22:04:22 -05:00
|
|
|
|
keyword -prefix -timeout
|
2007-04-05 11:18:42 +00:00
|
|
|
|
}
|
|
|
|
|
|
2009-04-27 07:51:18 +00:00
|
|
|
|
: ${wipe_tmp:=${WIPE_TMP:-yes}}
|
2011-09-27 18:15:08 +02:00
|
|
|
|
: ${log_dmesg:=${LOG_DMESG:-yes}}
|
2009-04-27 07:51:18 +00:00
|
|
|
|
|
2008-01-11 12:13:46 +00:00
|
|
|
|
cleanup_tmp_dir()
|
|
|
|
|
{
|
2008-04-09 00:06:50 +00:00
|
|
|
|
local dir="$1"
|
2007-09-09 15:52:05 +00:00
|
|
|
|
|
2009-04-27 07:51:18 +00:00
|
|
|
|
if ! [ -d "$dir" ]; then
|
|
|
|
|
mkdir -p "$dir" || return $?
|
2008-04-08 23:25:48 +00:00
|
|
|
|
fi
|
2012-01-28 19:32:05 +01:00
|
|
|
|
checkpath -W "$dir" || return 1
|
2011-01-06 18:20:53 -06:00
|
|
|
|
chmod a+rwt "$dir" 2> /dev/null
|
bootmisc: clean up tmpdir cleaning
Make sure that the `cd` into the $dir actually happened. This we don't
have to worry about relative paths deleting stuff it shouldn't. This
step shouldn't fail, but who knows, and better to be sane than to wipe
out someone's valuables.
When wiping, automatically fall back to a dedicated `find` if the initial
`rm` failed on us. This should help with the speed issues related to the
later `find`.
Have the later find only search the top level allowing `rm` to walk the
directory contents. This means that -xdev no longer applies, but since
the earlier `rm` wasn't doing -xdev either and no one has complained thus
far, let's assume it isn't an issue. Also convert to the -exec...+ form
so that we don't have to worry about long argument lists, and add -- to
the `rm` that was previously missing. In practice, this shouldn't matter
as we've already deleted all those files, but better safe than sorry.
When cleaning, since we've already done a `cd` into the $dir, no point in
prefixing all the paths with $dir too. Go with the relative loving.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
X-Gentoo-Bug: 359831
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=359831
2011-03-23 14:42:42 -04:00
|
|
|
|
cd "$dir" || return 1
|
2009-04-27 07:51:18 +00:00
|
|
|
|
if yesno $wipe_tmp; then
|
|
|
|
|
ebegin "Wiping $dir directory"
|
2007-09-09 15:52:05 +00:00
|
|
|
|
|
bootmisc: clean up tmpdir cleaning
Make sure that the `cd` into the $dir actually happened. This we don't
have to worry about relative paths deleting stuff it shouldn't. This
step shouldn't fail, but who knows, and better to be sane than to wipe
out someone's valuables.
When wiping, automatically fall back to a dedicated `find` if the initial
`rm` failed on us. This should help with the speed issues related to the
later `find`.
Have the later find only search the top level allowing `rm` to walk the
directory contents. This means that -xdev no longer applies, but since
the earlier `rm` wasn't doing -xdev either and no one has complained thus
far, let's assume it isn't an issue. Also convert to the -exec...+ form
so that we don't have to worry about long argument lists, and add -- to
the `rm` that was previously missing. In practice, this shouldn't matter
as we've already deleted all those files, but better safe than sorry.
When cleaning, since we've already done a `cd` into the $dir, no point in
prefixing all the paths with $dir too. Go with the relative loving.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
X-Gentoo-Bug: 359831
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=359831
2011-03-23 14:42:42 -04:00
|
|
|
|
# Faster than raw find
|
2012-11-06 22:49:49 +00:00
|
|
|
|
if ! rm -rf -- [!ajlq\.]* 2>/dev/null ; then
|
bootmisc: clean up tmpdir cleaning
Make sure that the `cd` into the $dir actually happened. This we don't
have to worry about relative paths deleting stuff it shouldn't. This
step shouldn't fail, but who knows, and better to be sane than to wipe
out someone's valuables.
When wiping, automatically fall back to a dedicated `find` if the initial
`rm` failed on us. This should help with the speed issues related to the
later `find`.
Have the later find only search the top level allowing `rm` to walk the
directory contents. This means that -xdev no longer applies, but since
the earlier `rm` wasn't doing -xdev either and no one has complained thus
far, let's assume it isn't an issue. Also convert to the -exec...+ form
so that we don't have to worry about long argument lists, and add -- to
the `rm` that was previously missing. In practice, this shouldn't matter
as we've already deleted all those files, but better safe than sorry.
When cleaning, since we've already done a `cd` into the $dir, no point in
prefixing all the paths with $dir too. Go with the relative loving.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
X-Gentoo-Bug: 359831
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=359831
2011-03-23 14:42:42 -04:00
|
|
|
|
# Blah, too many files
|
2012-11-06 23:01:42 +00:00
|
|
|
|
find . -maxdepth 1 -name '[!ajlq\.]*' -exec rm -rf -- {} +
|
bootmisc: clean up tmpdir cleaning
Make sure that the `cd` into the $dir actually happened. This we don't
have to worry about relative paths deleting stuff it shouldn't. This
step shouldn't fail, but who knows, and better to be sane than to wipe
out someone's valuables.
When wiping, automatically fall back to a dedicated `find` if the initial
`rm` failed on us. This should help with the speed issues related to the
later `find`.
Have the later find only search the top level allowing `rm` to walk the
directory contents. This means that -xdev no longer applies, but since
the earlier `rm` wasn't doing -xdev either and no one has complained thus
far, let's assume it isn't an issue. Also convert to the -exec...+ form
so that we don't have to worry about long argument lists, and add -- to
the `rm` that was previously missing. In practice, this shouldn't matter
as we've already deleted all those files, but better safe than sorry.
When cleaning, since we've already done a `cd` into the $dir, no point in
prefixing all the paths with $dir too. Go with the relative loving.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
X-Gentoo-Bug: 359831
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=359831
2011-03-23 14:42:42 -04:00
|
|
|
|
fi
|
2007-09-09 15:52:05 +00:00
|
|
|
|
|
2010-10-31 19:39:41 +01:00
|
|
|
|
# pam_mktemp creates a .private directory within which
|
|
|
|
|
# each user gets a private directory with immutable
|
|
|
|
|
# bit set; remove the immutable bit before trying to
|
|
|
|
|
# remove it.
|
2010-11-26 14:54:30 -06:00
|
|
|
|
[ -d /tmp/.private ] && chattr -R -a /tmp/.private 2> /dev/null
|
2010-10-31 19:39:41 +01:00
|
|
|
|
|
bootmisc: clean up tmpdir cleaning
Make sure that the `cd` into the $dir actually happened. This we don't
have to worry about relative paths deleting stuff it shouldn't. This
step shouldn't fail, but who knows, and better to be sane than to wipe
out someone's valuables.
When wiping, automatically fall back to a dedicated `find` if the initial
`rm` failed on us. This should help with the speed issues related to the
later `find`.
Have the later find only search the top level allowing `rm` to walk the
directory contents. This means that -xdev no longer applies, but since
the earlier `rm` wasn't doing -xdev either and no one has complained thus
far, let's assume it isn't an issue. Also convert to the -exec...+ form
so that we don't have to worry about long argument lists, and add -- to
the `rm` that was previously missing. In practice, this shouldn't matter
as we've already deleted all those files, but better safe than sorry.
When cleaning, since we've already done a `cd` into the $dir, no point in
prefixing all the paths with $dir too. Go with the relative loving.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
X-Gentoo-Bug: 359831
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=359831
2011-03-23 14:42:42 -04:00
|
|
|
|
# Prune the paths that are left
|
|
|
|
|
find . -maxdepth 1 \
|
|
|
|
|
! -name . \
|
|
|
|
|
! -name lost+found \
|
|
|
|
|
! -name quota.user \
|
|
|
|
|
! -name aquota.user \
|
|
|
|
|
! -name quota.group \
|
|
|
|
|
! -name aquota.group \
|
|
|
|
|
! -name journal \
|
|
|
|
|
-exec rm -rf -- {} +
|
2007-09-09 15:52:05 +00:00
|
|
|
|
eend 0
|
|
|
|
|
else
|
2009-04-27 07:51:18 +00:00
|
|
|
|
ebegin "Cleaning $dir directory"
|
bootmisc: clean up tmpdir cleaning
Make sure that the `cd` into the $dir actually happened. This we don't
have to worry about relative paths deleting stuff it shouldn't. This
step shouldn't fail, but who knows, and better to be sane than to wipe
out someone's valuables.
When wiping, automatically fall back to a dedicated `find` if the initial
`rm` failed on us. This should help with the speed issues related to the
later `find`.
Have the later find only search the top level allowing `rm` to walk the
directory contents. This means that -xdev no longer applies, but since
the earlier `rm` wasn't doing -xdev either and no one has complained thus
far, let's assume it isn't an issue. Also convert to the -exec...+ form
so that we don't have to worry about long argument lists, and add -- to
the `rm` that was previously missing. In practice, this shouldn't matter
as we've already deleted all those files, but better safe than sorry.
When cleaning, since we've already done a `cd` into the $dir, no point in
prefixing all the paths with $dir too. Go with the relative loving.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
X-Gentoo-Bug: 359831
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=359831
2011-03-23 14:42:42 -04:00
|
|
|
|
rm -rf -- .X*-lock esrv* kio* \
|
|
|
|
|
jpsock.* .fam* .esd* \
|
|
|
|
|
orbit-* ssh-* ksocket-* \
|
|
|
|
|
.*-unix
|
2007-09-09 15:52:05 +00:00
|
|
|
|
eend 0
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
2013-02-16 00:48:36 -06:00
|
|
|
|
cleanup_var_run_dir()
|
|
|
|
|
{
|
|
|
|
|
ebegin "Cleaning /var/run"
|
|
|
|
|
for x in $(find /var/run ! -type d ! -name utmp \
|
|
|
|
|
! -name random-seed ! -name dev.db \
|
|
|
|
|
! -name ld-elf.so.hints ! -name ld.so.hints);
|
|
|
|
|
do
|
|
|
|
|
# Clean stale sockets
|
|
|
|
|
if [ -S "$x" ]; then
|
2013-12-01 19:25:01 -06:00
|
|
|
|
if command -v fuser >/dev/null 2>&1; then
|
2013-02-16 00:48:36 -06:00
|
|
|
|
fuser "$x" >/dev/null 2>&1 || rm -- "$x"
|
|
|
|
|
else
|
|
|
|
|
rm -- "$x"
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
[ ! -f "$x" ] && continue
|
|
|
|
|
# Do not remove pidfiles of already running daemons
|
|
|
|
|
case "$x" in
|
|
|
|
|
*.pid)
|
|
|
|
|
start-stop-daemon --test --quiet \
|
|
|
|
|
--stop --pidfile "$x" && continue
|
|
|
|
|
;;
|
|
|
|
|
esac
|
|
|
|
|
rm -f -- "$x"
|
|
|
|
|
done
|
|
|
|
|
eend 0
|
|
|
|
|
}
|
|
|
|
|
|
2009-04-16 23:39:37 +00:00
|
|
|
|
mkutmp()
|
|
|
|
|
{
|
|
|
|
|
: >"$1"
|
2009-04-18 00:56:48 +00:00
|
|
|
|
# Not all systems have the utmp group
|
|
|
|
|
chgrp utmp "$1" 2>/dev/null
|
2009-04-16 23:39:37 +00:00
|
|
|
|
chmod 0664 "$1"
|
|
|
|
|
}
|
|
|
|
|
|
2011-11-30 10:00:44 -06:00
|
|
|
|
migrate_to_run()
|
|
|
|
|
{
|
|
|
|
|
src="$1"
|
|
|
|
|
dst="$2"
|
|
|
|
|
if [ -L $src -a "$(readlink -f $src)" != $dst ]; then
|
|
|
|
|
ewarn "$src does not point to $dst."
|
|
|
|
|
ewarn "Setting $src to point to $dst."
|
|
|
|
|
rm $src
|
|
|
|
|
elif [ ! -L $src -a -d $src ]; then
|
|
|
|
|
ebegin "Migrating $src to $dst"
|
|
|
|
|
cp -a $src/* $dst/
|
|
|
|
|
rm -rf $src
|
|
|
|
|
eend $?
|
|
|
|
|
fi
|
|
|
|
|
# If $src doesn't exist at all, just run this
|
|
|
|
|
if [ ! -e $src ]; then
|
|
|
|
|
ln -s $dst $src
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
2013-01-31 12:05:37 -06:00
|
|
|
|
clean_run()
|
|
|
|
|
{
|
2014-08-10 17:15:05 -05:00
|
|
|
|
[ "$RC_SYS" = VSERVER -o "$RC_SYS" = LXC ] && return 0
|
2013-01-31 12:05:37 -06:00
|
|
|
|
local dir
|
2015-02-26 17:58:22 -08:00
|
|
|
|
# If / is still read-only due to a problem, this will fail!
|
|
|
|
|
if ! checkpath -W /; then
|
2015-10-05 11:21:55 -05:00
|
|
|
|
ewarn "/ is not writable; unable to clean up underlying /run"
|
2015-02-26 17:58:22 -08:00
|
|
|
|
return 1
|
|
|
|
|
fi
|
|
|
|
|
if ! checkpath -W /tmp; then
|
2015-10-05 11:21:55 -05:00
|
|
|
|
ewarn "/tmp is not writable; unable to clean up underlying /run"
|
2015-02-26 17:58:22 -08:00
|
|
|
|
return 1
|
|
|
|
|
fi
|
|
|
|
|
# Now we know that we can modify /tmp and /
|
|
|
|
|
# if mktemp -d fails, it returns an EMPTY string
|
|
|
|
|
# STDERR: mktemp: failed to create directory via template ‘/tmp/tmp.XXXXXXXXXX’: Read-only file system
|
|
|
|
|
# STDOUT: ''
|
|
|
|
|
rc=0
|
2013-01-31 12:05:37 -06:00
|
|
|
|
dir=$(mktemp -d)
|
2015-02-26 17:58:22 -08:00
|
|
|
|
if [ -n "$dir" -a -d $dir -a -w $dir ]; then
|
|
|
|
|
mount --bind / $dir && rm -rf $dir/run/* || rc=1
|
2015-10-05 11:08:11 -05:00
|
|
|
|
umount $dir && rmdir $dir
|
2015-02-26 17:58:22 -08:00
|
|
|
|
else
|
|
|
|
|
rc=1
|
|
|
|
|
fi
|
|
|
|
|
if [ $rc -ne 0 ]; then
|
2015-10-05 11:21:55 -05:00
|
|
|
|
ewarn "Could not clean up underlying /run on /"
|
2015-02-26 17:58:22 -08:00
|
|
|
|
return 1
|
|
|
|
|
fi
|
2013-01-31 12:05:37 -06:00
|
|
|
|
}
|
|
|
|
|
|
2008-01-11 12:13:46 +00:00
|
|
|
|
start()
|
|
|
|
|
{
|
2009-04-27 07:51:18 +00:00
|
|
|
|
# Remove any added console dirs
|
2014-01-15 10:43:52 -06:00
|
|
|
|
if checkpath -W "$RC_LIBEXECDIR"; then
|
|
|
|
|
rm -rf "$RC_LIBEXECDIR"/console/*
|
|
|
|
|
fi
|
2009-04-27 07:51:18 +00:00
|
|
|
|
|
2009-06-08 22:18:39 +01:00
|
|
|
|
local logw=false runw=false extra=
|
2007-07-30 11:31:29 +00:00
|
|
|
|
# Ensure that our basic dirs exist
|
2011-11-30 10:00:44 -06:00
|
|
|
|
if [ "$RC_UNAME" = Linux ]; then
|
|
|
|
|
# Satisfy Linux FHS
|
|
|
|
|
extra=/var/lib/misc
|
|
|
|
|
if [ ! -d /run ]; then
|
|
|
|
|
extra="/var/run $extra"
|
|
|
|
|
fi
|
|
|
|
|
else
|
|
|
|
|
extra=/var/run
|
|
|
|
|
fi
|
|
|
|
|
for x in /var/log /tmp $extra; do
|
2009-04-27 07:51:18 +00:00
|
|
|
|
if ! [ -d $x ]; then
|
|
|
|
|
if ! mkdir -p $x; then
|
|
|
|
|
eend 1 "failed to create needed directory $x"
|
2007-07-30 11:31:29 +00:00
|
|
|
|
return 1
|
|
|
|
|
fi
|
2011-01-17 04:49:07 -05:00
|
|
|
|
fi
|
2007-07-30 11:31:29 +00:00
|
|
|
|
done
|
2007-04-05 11:18:42 +00:00
|
|
|
|
|
2012-10-16 14:27:19 -05:00
|
|
|
|
if [ "$RC_UNAME" = Linux -a -d /run ]; then
|
2011-11-30 10:00:44 -06:00
|
|
|
|
migrate_to_run /var/lock /run/lock
|
|
|
|
|
migrate_to_run /var/run /run
|
2013-01-31 12:05:37 -06:00
|
|
|
|
clean_run
|
2011-11-30 10:00:44 -06:00
|
|
|
|
fi
|
|
|
|
|
|
2012-01-28 19:32:05 +01:00
|
|
|
|
if checkpath -W /var/run; then
|
2008-04-08 23:25:48 +00:00
|
|
|
|
ebegin "Creating user login records"
|
2009-04-16 23:39:37 +00:00
|
|
|
|
local xtra=
|
2009-04-27 07:51:18 +00:00
|
|
|
|
[ "$RC_UNAME" = NetBSD ] && xtra=x
|
2009-04-16 23:39:37 +00:00
|
|
|
|
for x in "" $xtra; do
|
2009-04-27 07:51:18 +00:00
|
|
|
|
mkutmp /var/run/utmp$x
|
2009-04-16 23:39:37 +00:00
|
|
|
|
done
|
2009-11-10 20:09:03 +00:00
|
|
|
|
[ -e /var/log/wtmp ] || mkutmp /var/log/wtmp
|
2008-04-08 23:25:48 +00:00
|
|
|
|
eend 0
|
|
|
|
|
|
2013-02-16 00:48:36 -06:00
|
|
|
|
mountinfo -q -f tmpfs /var/run || cleanup_var_run_dir
|
2008-04-08 23:25:48 +00:00
|
|
|
|
fi
|
2007-04-05 11:18:42 +00:00
|
|
|
|
|
2007-09-09 15:52:05 +00:00
|
|
|
|
# Clean up /tmp directories
|
2007-11-20 12:20:50 +00:00
|
|
|
|
local tmp=
|
2009-02-23 09:36:48 +00:00
|
|
|
|
for tmp in ${clean_tmp_dirs:-${wipe_tmp_dirs-/tmp}}; do
|
2013-02-16 00:48:36 -06:00
|
|
|
|
mountinfo -q -f tmpfs "$tmp" || cleanup_tmp_dir "$tmp"
|
2007-09-09 15:52:05 +00:00
|
|
|
|
done
|
2007-09-09 16:08:32 +00:00
|
|
|
|
|
2012-01-28 19:32:05 +01:00
|
|
|
|
if checkpath -W /tmp; then
|
2008-04-08 23:25:48 +00:00
|
|
|
|
# Make sure our X11 stuff have the correct permissions
|
|
|
|
|
# Omit the chown as bootmisc is run before network is up
|
|
|
|
|
# and users may be using lame LDAP auth #139411
|
2011-01-17 04:49:07 -05:00
|
|
|
|
rm -rf /tmp/.ICE-unix /tmp/.X11-unix
|
2008-04-08 23:25:48 +00:00
|
|
|
|
mkdir -p /tmp/.ICE-unix /tmp/.X11-unix
|
|
|
|
|
chmod 1777 /tmp/.ICE-unix /tmp/.X11-unix
|
2009-04-27 07:51:18 +00:00
|
|
|
|
if [ -x /sbin/restorecon ]; then
|
|
|
|
|
restorecon /tmp/.ICE-unix /tmp/.X11-unix
|
|
|
|
|
fi
|
2008-04-08 23:25:48 +00:00
|
|
|
|
fi
|
|
|
|
|
|
2011-09-27 18:15:08 +02:00
|
|
|
|
if yesno $log_dmesg; then
|
2012-01-28 19:32:05 +01:00
|
|
|
|
if $logw || checkpath -W /var/log; then
|
2011-09-27 18:15:08 +02:00
|
|
|
|
# Create an 'after-boot' dmesg log
|
2015-05-28 00:01:43 -04:00
|
|
|
|
case "$RC_SYS" in
|
|
|
|
|
VSERVER|OPENVZ|LXC|SYSTEMD-NSPAWN) ;;
|
|
|
|
|
*)
|
2015-10-21 14:01:57 -05:00
|
|
|
|
if yesno ${previous_dmesg:-no}; then
|
|
|
|
|
mv /var/log/dmesg /var/log/dmesg.old
|
|
|
|
|
fi
|
2015-05-28 00:01:43 -04:00
|
|
|
|
dmesg > /var/log/dmesg
|
|
|
|
|
chmod 640 /var/log/dmesg
|
|
|
|
|
;;
|
|
|
|
|
esac
|
2008-04-08 23:25:48 +00:00
|
|
|
|
fi
|
2007-04-26 14:22:54 +00:00
|
|
|
|
fi
|
2008-01-10 23:22:46 +00:00
|
|
|
|
|
2008-04-09 00:06:50 +00:00
|
|
|
|
return 0
|
2007-04-05 11:18:42 +00:00
|
|
|
|
}
|
|
|
|
|
|
2008-01-11 12:13:46 +00:00
|
|
|
|
stop()
|
|
|
|
|
{
|
2007-04-05 11:18:42 +00:00
|
|
|
|
# Write a halt record if we're shutting down
|
2009-04-27 07:51:18 +00:00
|
|
|
|
if [ "$RC_RUNLEVEL" = shutdown ]; then
|
|
|
|
|
[ "$RC_UNAME" = Linux ] && halt -w
|
|
|
|
|
if [ "$RC_SYS" = OPENVZ ]; then
|
|
|
|
|
yesno $RC_REBOOT && printf "" >/reboot
|
2009-02-10 15:16:25 +00:00
|
|
|
|
fi
|
2009-02-10 15:06:48 +00:00
|
|
|
|
fi
|
2007-11-20 12:55:56 +00:00
|
|
|
|
|
2007-04-05 11:18:42 +00:00
|
|
|
|
return 0
|
|
|
|
|
}
|
2012-10-16 21:00:45 +02:00
|
|
|
|
|
|
|
|
|
# vim: ft=sh
|