commit:     9b8136f5f1ce8cd7616028da61cb65e354ccda5e
Author:     Brian Evans <grknight <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 19 00:33:53 2014 +0000
Commit:     Brian Evans <grknight <AT> gentoo <DOT> org>
CommitDate: Tue Aug 19 00:34:32 2014 +0000
URL:        
http://sources.gentoo.org/gitweb/?p=proj/mysql.git;a=commit;h=9b8136f5

[mysql-init-scripts] Add simple config check and support for chroot.  Copy old 
init scripts here to RIP

---
 .../files/{mysql-5.1.53-conf.d => conf.d-2.0}      |  13 +-
 dev-db/mysql-init-scripts/files/init.d-2.0         | 153 +++++++++++++++++++++
 dev-db/mysql-init-scripts/files/logrotate.mysql    |   6 +-
 .../mysql-init-scripts/files/mysql-5.1.53-conf.d   |  13 +-
 .../mysql-init-scripts/files/mysql-5.1.67-init.d   | 118 ++++++++++++++++
 dev-db/mysql-init-scripts/files/mysql.conf         |   1 +
 dev-db/mysql-init-scripts/files/mysqld-wait-ready  |  56 ++++++++
 dev-db/mysql-init-scripts/files/mysqld.service     |  26 ++++
 dev-db/mysql-init-scripts/files/mysqld_at.service  |  26 ++++
 .../mysql-init-scripts-2.0.ebuild                  |  68 +++++++++
 10 files changed, 465 insertions(+), 15 deletions(-)

diff --git a/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d 
b/dev-db/mysql-init-scripts/files/conf.d-2.0
similarity index 90%
copy from dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d
copy to dev-db/mysql-init-scripts/files/conf.d-2.0
index 3c79b13..781c8f5 100644
--- a/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d
+++ b/dev-db/mysql-init-scripts/files/conf.d-2.0
@@ -1,6 +1,6 @@
-# Copyright 1999-2010 Gentoo Foundation
+# Copyright 1999-2011 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header$
+# $Header: $
 
 # If you want a non-stock location for the config file, uncomment or update
 # either of these as needed. If you do use it, you must make sure that none of
@@ -33,7 +33,7 @@ STOP_TIMEOUT=120
 
 # integer [-20 .. 19 ] default 0
 # change the priority of the server -20 (high) to 19 (low)
-# see "man nice 1" for description
+# see nice(1) for description
 #NICE=0
 
 # See start-stop-daemon(8) for possible settings
@@ -72,7 +72,8 @@ STOP_TIMEOUT=120
 # But uncomment this next instead if you think it should.
 #rc_provide="mysql"
 
-# Tell OpenRC about our config file
-[ -n "${MY_CNF}" ] && rc_config="${MY_CNF}"
-
+# The conditional above has a false-positive "failure" return value as a
+# side-effect, and since it's the last statement, without the next line, this
+# script returns failure.
+return 0
 # vim: ft=gentoo-conf-d et ts=4 sw=4:

diff --git a/dev-db/mysql-init-scripts/files/init.d-2.0 
b/dev-db/mysql-init-scripts/files/init.d-2.0
new file mode 100644
index 0000000..5dc99d2
--- /dev/null
+++ b/dev-db/mysql-init-scripts/files/init.d-2.0
@@ -0,0 +1,153 @@
+#!/sbin/runscript
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+extra_commands="checkconfig"
+
+depend() {
+       use net.lo
+       # localmount needed for $basedir
+       need localmount
+}
+
+get_config() {
+       my_print_defaults --config-file="$1" mysqld |
+       sed -n -e "s/^--$2=//p"
+}
+
+mysql_svcname() {
+       local ebextra=
+       case "${SVCNAME}" in
+               mysql*) ;;
+               *) ebextra=" (mysql)" ;;
+       esac
+       echo "${SVCNAME}${ebextra}"
+}
+
+start() {
+       # Check for old conf.d variables that mean migration was not yet done.
+       set | egrep -sq '^(mysql_slot_|MYSQL_BLOG_PID_FILE|STOPTIMEOUT)'
+       rc=$?
+       # Yes, MYSQL_INIT_I_KNOW_WHAT_I_AM_DOING is a hidden variable.
+       # It does have a use in testing, as it is possible to build a config 
file
+       # that works with both the old and new init scripts simulateously.
+       if [ "${rc}" = 0 -a -z "${MYSQL_INIT_I_KNOW_WHAT_I_AM_DOING}" ]; then
+               eerror "You have not updated your conf.d for the new 
mysql-init-scripts-2 revamp."
+               eerror "Not proceeding because it may be dangerous."
+               return 1
+       fi
+
+       # Check the config or die
+       checkconfig || return 1
+
+       # Now we can startup
+       ebegin "Starting $(mysql_svcname)"
+
+       MY_CNF="${MY_CNF:-/etc/${SVCNAME}/my.cnf}"
+
+       if [ ! -r "${MY_CNF}" ] ; then
+               eerror "Cannot read the configuration file \`${MY_CNF}'"
+               return 1
+       fi
+
+       # tail -n1 is critical as these we only want the last instance of the 
option
+       local basedir=$(get_config "${MY_CNF}" basedir | tail -n1)
+       local datadir=$(get_config "${MY_CNF}" datadir | tail -n1)
+       local pidfile=$(get_config "${MY_CNF}" pid-file | tail -n1)
+       local socket=$(get_config "${MY_CNF}" socket | tail -n1)
+       local chroot=$(get_config "${MY_CNF}" chroot | tail -n1)
+
+       if [ -n "${chroot}" ] ; then
+               socket="${chroot}/${socket}"
+               pidfile="${chroot}/${pidfile}"
+       fi
+
+       if [ ! -d "${datadir}" ] ; then
+               eerror "MySQL datadir \`${datadir}' is empty or invalid"
+               eerror "Please check your config file \`${MY_CNF}'"
+               return 1
+       fi
+
+       if [ ! -d "${datadir}"/mysql ] ; then
+               # find which package is installed to report an error
+               local EROOT=$(portageq envvar EROOT)
+               local DBPKG_P=$(portageq match ${EROOT} $(portageq 
expand_virtual ${EROOT} virtual/mysql))
+               if [[ -z ${DBPKG_P} ]] ; then
+                       eerror "You don't appear to have a server package 
installed yet."
+               else
+                       eerror "You don't appear to have the mysql database 
installed yet."
+                       eerror "Please run \`emerge --config =${DBPKG_P}\` to 
have this done..."
+               fi
+               return 1
+       fi
+
+       local piddir="${pidfile%/*}"
+       checkpath -d --owner mysql:mysql --mode 0755 "$piddir"
+       rc=$?
+       if [ $rc -ne 0 ]; then
+               eerror "Directory $piddir for pidfile does not exist and cannot 
be created"
+               return 1
+       fi
+
+       local startup_timeout=${STARTUP_TIMEOUT:-900}
+       local startup_early_timeout=${STARTUP_EARLY_TIMEOUT:-1000}
+       local tmpnice="${NICE:+"--nicelevel "}${NICE}"
+       local tmpionice="${IONICE:+"--ionice "}${IONICE}"
+       start-stop-daemon \
+               ${DEBUG:+"--verbose"} \
+               --start \
+               --exec "${basedir}"/sbin/mysqld \
+               --pidfile "${pidfile}" \
+               --background \
+               --wait ${startup_early_timeout} \
+               ${tmpnice} \
+               ${tmpionice} \
+               -- --defaults-file="${MY_CNF}" ${MY_ARGS}
+       local ret=$?
+       if [ ${ret} -ne 0 ] ; then
+               eend ${ret}
+               return ${ret}
+       fi
+
+       ewaitfile ${startup_timeout} "${socket}"
+       eend $? || return 1
+
+       save_options pidfile "${pidfile}"
+       save_options basedir "${basedir}"
+}
+
+stop() {
+       ebegin "Stopping $(mysql_svcname)"
+
+       local pidfile="$(get_options pidfile)"
+       local basedir="$(get_options basedir)"
+       local stop_timeout=${STOP_TIMEOUT:-120}
+
+       start-stop-daemon \
+               ${DEBUG:+"--verbose"} \
+               --stop \
+               --exec "${basedir}"/sbin/mysqld \
+               --pidfile "${pidfile}" \
+               --retry ${stop_timeout}
+       eend $?
+}
+
+checkconfig() {
+       local basedir=$(get_config "${MY_CNF}" basedir | tail -n1)
+       ebegin "Checking mysqld configuration"
+
+       # Suppress output to check the return value
+       "${basedir}"/sbin/mysqld --help --verbose &> /dev/null
+
+       # If the above command does not return 0,
+       # then there is an error to echo to the user
+       if [ $? -ne 0 ] ; then
+               "${basedir}"/sbin/mysqld --help --verbose > /dev/null
+       fi
+
+       eend $? "MySQL config check failed"
+}
+
+# vim: filetype=gentoo-init-d sw=2 ts=2 sts=2 noet:
+

diff --git a/dev-db/mysql-init-scripts/files/logrotate.mysql 
b/dev-db/mysql-init-scripts/files/logrotate.mysql
index b3d50de..3399e30 100644
--- a/dev-db/mysql-init-scripts/files/logrotate.mysql
+++ b/dev-db/mysql-init-scripts/files/logrotate.mysql
@@ -1,6 +1,6 @@
-# Copyright 1999-2010 Gentoo Foundation
+# Copyright 1999-2011 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header$
+# $Header: 
/var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/logrotate.mysql,v 1.2 
2011/01/13 20:06:06 robbat2 Exp $
 
 /var/log/mysql/mysql.err /var/log/mysql/mysql.log /var/log/mysql/mysqld.err {
 monthly
@@ -10,6 +10,6 @@ size 5M
 sharedscripts
 missingok
 postrotate
-/bin/kill -HUP `cat /var/run/mysqld/mysqld.pid`
+[ -f /var/run/mysqld/mysqld.pid ] && /bin/kill -HUP `cat 
/var/run/mysqld/mysqld.pid`
 endscript
 }

diff --git a/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d 
b/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d
index 3c79b13..df4c3a4 100644
--- a/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d
+++ b/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d
@@ -1,6 +1,6 @@
-# Copyright 1999-2010 Gentoo Foundation
+# Copyright 1999-2011 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header$
+# $Header: 
/var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d,v 
1.2 2011/01/15 17:54:31 robbat2 Exp $
 
 # If you want a non-stock location for the config file, uncomment or update
 # either of these as needed. If you do use it, you must make sure that none of
@@ -33,7 +33,7 @@ STOP_TIMEOUT=120
 
 # integer [-20 .. 19 ] default 0
 # change the priority of the server -20 (high) to 19 (low)
-# see "man nice 1" for description
+# see nice(1) for description
 #NICE=0
 
 # See start-stop-daemon(8) for possible settings
@@ -72,7 +72,8 @@ STOP_TIMEOUT=120
 # But uncomment this next instead if you think it should.
 #rc_provide="mysql"
 
-# Tell OpenRC about our config file
-[ -n "${MY_CNF}" ] && rc_config="${MY_CNF}"
-
+# The conditional above has a false-positive "failure" return value as a
+# side-effect, and since it's the last statement, without the next line, this
+# script returns failure.
+return 0
 # vim: ft=gentoo-conf-d et ts=4 sw=4:

diff --git a/dev-db/mysql-init-scripts/files/mysql-5.1.67-init.d 
b/dev-db/mysql-init-scripts/files/mysql-5.1.67-init.d
new file mode 100644
index 0000000..511a6bf
--- /dev/null
+++ b/dev-db/mysql-init-scripts/files/mysql-5.1.67-init.d
@@ -0,0 +1,118 @@
+#!/sbin/runscript
+# Copyright 1999-2013 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: 
/var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/mysql-5.1.67-init.d,v 
1.1 2013/01/18 01:51:47 robbat2 Exp $
+
+depend() {
+       use net.lo
+       # localmount needed for $basedir
+       need localmount
+}
+
+get_config() {
+       my_print_defaults --config-file="$1" mysqld |
+       sed -n -e "s/^--$2=//p"
+}
+
+mysql_svcname() {
+       local ebextra=
+       case "${SVCNAME}" in
+               mysql*) ;;
+               *) ebextra=" (mysql)" ;;
+       esac
+       echo "${SVCNAME}${ebextra}"
+}
+
+start() {
+       # Check for old conf.d variables that mean migration was not yet done.
+       set | egrep -sq '^(mysql_slot_|MYSQL_BLOG_PID_FILE|STOPTIMEOUT)'
+       rc=$?
+       # Yes, MYSQL_INIT_I_KNOW_WHAT_I_AM_DOING is a hidden variable.
+       # It does have a use in testing, as it is possible to build a config 
file
+       # that works with both the old and new init scripts simulateously.
+       if [ "${rc}" = 0 -a -z "${MYSQL_INIT_I_KNOW_WHAT_I_AM_DOING}" ]; then
+               eerror "You have not updated your conf.d for the new 
mysql-init-scripts-2 revamp."
+               eerror "Not proceeding because it may be dangerous."
+               return 1
+       fi
+
+       # Now we can startup
+       ebegin "Starting $(mysql_svcname)"
+
+       MY_CNF="${MY_CNF:-/etc/${SVCNAME}/my.cnf}"
+
+       if [ ! -r "${MY_CNF}" ] ; then
+               eerror "Cannot read the configuration file \`${MY_CNF}'"
+               return 1
+       fi
+
+       # tail -n1 is critical as these we only want the last instance of the 
option
+       local basedir=$(get_config "${MY_CNF}" basedir | tail -n1)
+       local datadir=$(get_config "${MY_CNF}" datadir | tail -n1)
+       local pidfile=$(get_config "${MY_CNF}" pid-file | tail -n1)
+       local socket=$(get_config "${MY_CNF}" socket | tail -n1)
+
+       if [ ! -d "${datadir}" ] ; then
+               eerror "MySQL datadir \`${datadir}' is empty or invalid"
+               eerror "Please check your config file \`${MY_CNF}'"
+               return 1
+       fi
+
+       if [ ! -d "${datadir}"/mysql ] ; then
+               eerror "You don't appear to have the mysql database installed 
yet."
+               eerror "Please run /usr/bin/mysql_install_db to have this 
done..."
+               return 1
+       fi
+
+       local piddir="${pidfile%/*}"
+       checkpath -d --owner mysql:mysql --mode 0755 "$piddir"
+       rc=$?
+       if [ $rc -ne 0 ]; then
+               eerror "Directory $piddir for pidfile does not exist and cannot 
be created"
+               return 1
+       fi
+
+       local startup_timeout=${STARTUP_TIMEOUT:-900}
+       local startup_early_timeout=${STARTUP_EARLY_TIMEOUT:-1000}
+       local tmpnice="${NICE:+"--nicelevel "}${NICE}"
+       local tmpionice="${IONICE:+"--ionice "}${IONICE}"
+       start-stop-daemon \
+               ${DEBUG:+"--verbose"} \
+               --start \
+               --exec "${basedir}"/sbin/mysqld \
+               --pidfile "${pidfile}" \
+               --background \
+               --wait ${startup_early_timeout} \
+               ${tmpnice} \
+               ${tmpionice} \
+               -- --defaults-file="${MY_CNF}" ${MY_ARGS}
+       local ret=$?
+       if [ ${ret} -ne 0 ] ; then
+               eend ${ret}
+               return ${ret}
+       fi
+
+       ewaitfile ${startup_timeout} "${socket}"
+       eend $? || return 1
+
+       save_options pidfile "${pidfile}"
+       save_options basedir "${basedir}"
+}
+
+stop() {
+       ebegin "Stopping $(mysql_svcname)"
+
+       local pidfile="$(get_options pidfile)"
+       local basedir="$(get_options basedir)"
+       local stop_timeout=${STOP_TIMEOUT:-120}
+
+       start-stop-daemon \
+               ${DEBUG:+"--verbose"} \
+               --stop \
+               --exec "${basedir}"/sbin/mysqld \
+               --pidfile "${pidfile}" \
+               --retry ${stop_timeout}
+       eend $?
+}
+# vim: filetype=gentoo-init-d sw=2 ts=2 sts=2 noet:
+

diff --git a/dev-db/mysql-init-scripts/files/mysql.conf 
b/dev-db/mysql-init-scripts/files/mysql.conf
new file mode 100644
index 0000000..74cd5f8
--- /dev/null
+++ b/dev-db/mysql-init-scripts/files/mysql.conf
@@ -0,0 +1 @@
+d /var/run/mysqld 0755 mysql mysql -

diff --git a/dev-db/mysql-init-scripts/files/mysqld-wait-ready 
b/dev-db/mysql-init-scripts/files/mysqld-wait-ready
new file mode 100644
index 0000000..9e5d3e4
--- /dev/null
+++ b/dev-db/mysql-init-scripts/files/mysqld-wait-ready
@@ -0,0 +1,56 @@
+#!/bin/sh
+
+# This script waits for mysqld to be ready to accept connections
+# (which can be many seconds or even minutes after launch, if there's
+# a lot of crash-recovery work to do).
+# Running this as ExecStartPost is useful so that services declared as
+# "After mysqld" won't be started until the database is really ready.
+
+# Service file passes us the daemon's PID (actually, mysqld_safe's PID)
+daemon_pid="$1"
+
+# extract value of a MySQL option from config files
+# Usage: get_mysql_option SECTION VARNAME DEFAULT
+# result is returned in $result
+# We use my_print_defaults which prints all options from multiple files,
+# with the more specific ones later; hence take the last match.
+get_mysql_option(){
+       result=`/usr/bin/my_print_defaults "$1" | sed -n "s/^--$2=//p" | tail 
-n 1`
+       if [ -z "$result" ]; then
+           # not found, use default
+           result="$3"
+       fi
+}
+
+# Defaults here had better match what mysqld_safe will default to
+get_mysql_option mysqld datadir "/var/lib/mysql"
+datadir="$result"
+get_mysql_option mysqld socket "/var/lib/mysql/mysql.sock"
+socketfile="$result"
+
+# Wait for the server to come up or for the mysqld process to disappear
+ret=0
+while /bin/true; do
+       RESPONSE=`/usr/bin/mysqladmin --no-defaults --socket="$socketfile" 
--user=UNKNOWN_MYSQL_USER ping 2>&1`
+       mret=$?
+       if [ $mret -eq 0 ]; then
+           break
+       fi
+       # exit codes 1, 11 (EXIT_CANNOT_CONNECT_TO_SERVICE) are expected,
+       # anything else suggests a configuration error
+       if [ $mret -ne 1 -a $mret -ne 11 ]; then
+           ret=1
+           break
+       fi
+       # "Access denied" also means the server is alive
+       echo "$RESPONSE" | grep -q "Access denied for user" && break
+
+       # Check process still exists
+       if ! /bin/kill -0 $daemon_pid 2>/dev/null; then
+           ret=1
+           break
+       fi
+       sleep 1
+done
+
+exit $ret

diff --git a/dev-db/mysql-init-scripts/files/mysqld.service 
b/dev-db/mysql-init-scripts/files/mysqld.service
new file mode 100644
index 0000000..de9ea2f
--- /dev/null
+++ b/dev-db/mysql-init-scripts/files/mysqld.service
@@ -0,0 +1,26 @@
+[Unit]
+Description=MySQL database server
+After=syslog.target
+After=network.target
+
+[Service]
+Type=simple
+User=mysql
+Group=mysql
+
+# Note: we set --basedir to prevent probes that might trigger SELinux alarms,
+# https://bugzilla.redhat.com/show_bug.cgi?id=547485
+ExecStart=/usr/bin/mysqld_safe --basedir=/usr
+ExecStartPost=/usr/libexec/mysqld-wait-ready $MAINPID
+
+# Give a reasonable amount of time for the server to start up/shut down
+TimeoutSec=300
+
+# We rely on systemd, not mysqld_safe, to restart mysqld if it dies
+Restart=always
+
+# Place temp files in a secure directory, not /tmp
+PrivateTmp=true
+
+[Install]
+WantedBy=multi-user.target

diff --git a/dev-db/mysql-init-scripts/files/mysqld_at.service 
b/dev-db/mysql-init-scripts/files/mysqld_at.service
new file mode 100644
index 0000000..f46cf9e
--- /dev/null
+++ b/dev-db/mysql-init-scripts/files/mysqld_at.service
@@ -0,0 +1,26 @@
+[Unit]
+Description=MySQL database server
+ConditionPathExists=/etc/mysql/my%I.cnf
+After=network.target
+
+[Service]
+Type=simple
+User=mysql
+Group=mysql
+
+# Note: we set --basedir to prevent probes that might trigger SELinux alarms,
+# https://bugzilla.redhat.com/show_bug.cgi?id=547485
+ExecStart=/usr/bin/mysqld_safe --defaults-file=/etc/mysql/my%I.cnf 
--basedir=/usr
+ExecStartPost=/usr/libexec/mysqld-wait-ready $MAINPID
+
+# Give a reasonable amount of time for the server to start up/shut down
+TimeoutSec=300
+
+# We rely on systemd, not mysqld_safe, to restart mysqld if it dies
+Restart=always
+
+# Place temp files in a secure directory, not /tmp
+PrivateTmp=true
+
+[Install]
+WantedBy=multi-user.target

diff --git a/dev-db/mysql-init-scripts/mysql-init-scripts-2.0.ebuild 
b/dev-db/mysql-init-scripts/mysql-init-scripts-2.0.ebuild
new file mode 100644
index 0000000..1baca5e
--- /dev/null
+++ b/dev-db/mysql-init-scripts/mysql-init-scripts-2.0.ebuild
@@ -0,0 +1,68 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI=5
+
+inherit systemd
+
+DESCRIPTION="Gentoo MySQL init scripts."
+HOMEPAGE="http://www.gentoo.org/";
+SRC_URI=""
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc 
~x86 ~sparc-fbsd ~x86-fbsd"
+IUSE=""
+
+DEPEND=""
+# This _will_ break with MySQL 5.0, 4.x, 3.x
+# It also NEEDS openrc for the save_options/get_options builtins.
+RDEPEND="!<dev-db/mysql-5.1"
+# Need to set S due to PMS saying we need it existing, but no SRC_URI
+S=${WORKDIR}
+
+src_install() {
+       newconfd "${FILESDIR}/conf.d-${PV}" "mysql"
+       newinitd "${FILESDIR}/init.d-${PV}" "mysql"
+
+       # systemd unit installation
+       exeinto /usr/libexec
+       doexe "${FILESDIR}"/mysqld-wait-ready
+       systemd_dounit "${FILESDIR}/mysqld.service"
+       systemd_newunit "${FILESDIR}/mysqld_at.service" "[email protected]"
+       systemd_dotmpfilesd "${FILESDIR}/mysql.conf"
+
+       insinto /etc/logrotate.d
+       newins "${FILESDIR}/logrotate.mysql" "mysql"
+}
+
+pkg_postinst() {
+       grep -sq mysql_slot "${ROOT}"/etc/conf.d/mysql
+       old_conf_present=$?
+       grep -sq get_slot_config "${ROOT}"/etc/init.d/mysql
+       old_init_present=$?
+
+       egrep -sq 'MY_CNF|MY_ARGS|(STARTUP|STOP)_TIMEOUT' 
"${ROOT}"/etc/conf.d/mysql
+       new_conf_present=$?
+       egrep -sq 'MY_ARGS|STOP_TIMEOUT' "${ROOT}"/etc/init.d/mysql
+       new_init_present=$?
+
+       einfo "Please note that if you are using multiple internal 'slots' in 
the"
+       einfo "old conf.d file, you should use multiple init files now."
+       echo old $old_conf_present $old_init_present
+       echo new $new_conf_present $new_init_present
+
+       # new scripts present
+       if [ $new_conf_present -eq 0 -a $new_init_present -eq 0 -a \
+                $old_conf_present -eq 1 -a $old_init_present -eq 1 ]; then
+               :
+       elif [ $old_conf_present -eq 0 -a $old_init_present -eq 0 -a \
+                $new_conf_present -eq 1 -a $new_init_present -eq 1 ]; then
+               ewarn "Old /etc/init.d/mysql and /etc/conf.d/mysql still 
present!"
+               ewarn "Update both of those files to the new versions!"
+       else
+               eerror "DANGER, mixed update of /etc/init.d/mysql and 
/etc/conf.d/mysql"
+               eerror "detected! You must update BOTH to the new versions"
+       fi
+}

Reply via email to