/[gentoo-x86]/eclass/mysql.eclass
Gentoo

Diff of /eclass/mysql.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.9 Revision 1.43
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2006 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.9 2006/01/24 23:09:00 vivo Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.43 2006/10/23 12:26:45 vivo Exp $
4 4
5# Author: Francesco Riosa <vivo at gentoo.org> 5# Author: Francesco Riosa <vivo@gentoo.org>
6# Maintainer: Francesco Riosa <vivo at gentoo.org> 6# Maintainer: Luca Longinotti <chtekk@gentoo.org>
7 7
8# Both MYSQL_VERSION_ID and MYSQL_PATCHSET_REV must be set in the ebuild too
9# Note that MYSQL_VERSION_ID must be empty !!!
10
11# MYSQL_VERSION_ID will be:
12# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99]
13# This is an important part, because many of the choices the MySQL ebuild will do
14# depend on this variable.
15# In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803"
16
17if [[ -z "${MYSQL_VERSION_ID}" ]] ; then
18 tpv=( ${PV//[-._]/ } ) ; tpv[3]="${PVR:${#PV}}" ; tpv[3]="${tpv[3]##*-r}"
19 for vatom in 0 1 2 3 ; do
20 # pad to length 2
21 tpv[${vatom}]="00${tpv[${vatom}]}"
22 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}"
23 done
24 # strip leading "0" (otherwise it's considered an octal number by BASH)
25 MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"}
26fi
27
8inherit eutils flag-o-matic gnuconfig 28inherit eutils flag-o-matic gnuconfig autotools mysql_fx
9 29
10#major, minor only in the slot 30# Be warned, *DEPEND are version-dependant
11SLOT=$(( ${MYSQL_VERSION_ID} / 10000 )) 31DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d )
32 userland_GNU? ( sys-process/procps )
33 >=sys-apps/sed-4
34 >=sys-apps/texinfo-4.7-r1
35 >=sys-libs/readline-4.1
36 >=sys-libs/zlib-1.2.3"
12 37
38mysql_version_is_at_least "5.01.00.00" \
39|| DEPEND="${DEPEND} berkdb? ( sys-apps/ed )"
40
41RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )"
42
43# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
44PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
45
13# shorten the path because the socket path length must be shorter than 107 chars 46# Shorten the path because the socket path length must be shorter than 107 chars
14# and we will run a mysql server during test phase 47# and we will run a mysql server during test phase
15S="${WORKDIR}/${PN}" 48S="${WORKDIR}/${PN/_alpha/-bk-}" # BitKeeper ebuilds
16 49
50# Define $MY_FIXED_PV for MySQL patchsets
51MY_FIXED_PV="${PV/_alpha/}"
52#MY_FIXED_PV="${MY_FIXED_PV/_beta/}"
53#MY_FIXED_PV="${MY_FIXED_PV/_rc/}"
54
55MY_P="${P/_/-}"
56MY_P="${MY_P/-alpha/-bk-}" # BitKeeper ebuilds
57
58# Define correct SRC_URIs
59SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${MY_P}${MYSQL_RERELEASE}.tar.gz"
60if [[ -n "${MYSQL_PATCHSET_REV}" ]] ; then
61 MYSQL_PATCHSET_FILENAME="${PN}-patchset-${MY_FIXED_PV}-r${MYSQL_PATCHSET_REV}.tar.bz2"
62 # We add the Gentoo mirror here, as we only use primaryuri for the MySQL tarball
63 SRC_URI="${SRC_URI} http://gentoo.longitekk.com/${MYSQL_PATCHSET_FILENAME}"
64fi
65
17DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" 66DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
18HOMEPAGE="http://www.mysql.com/" 67HOMEPAGE="http://www.mysql.com/"
19NEWP="${P/_/-}" 68SLOT="0"
20SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${NEWP}.tar.gz
21 mirror://gentoo/mysql-extras-20060115.tar.bz2"
22LICENSE="GPL-2" 69LICENSE="GPL-2"
23IUSE="big-tables berkdb debug minimal perl selinux srvdir ssl static" 70IUSE="big-tables debug embedded minimal perl selinux srvdir ssl static"
24RESTRICT="primaryuri confcache" 71RESTRICT="confcache"
25DEPEND="app-admin/eselect-mysql" 72
73mysql_version_is_at_least "4.01.00.00" \
74&& IUSE="${IUSE} latin1"
26 75
27mysql_version_is_at_least "4.01.03.00" \ 76mysql_version_is_at_least "4.01.03.00" \
28&& IUSE="${IUSE} cluster extraengine" 77&& IUSE="${IUSE} cluster extraengine"
29 78
79mysql_version_is_at_least "5.00.00.00" \
80|| IUSE="${IUSE} raid"
81
30mysql_version_is_at_least "5.00.18.00" \ 82mysql_version_is_at_least "5.00.18.00" \
31&& IUSE="${IUSE} max-idx-128" 83&& IUSE="${IUSE} max-idx-128"
32 84
33mysql_version_is_at_least "5.01.00.00" \ 85mysql_version_is_at_least "5.01.00.00" \
34&& IUSE="${IUSE} innodb" 86&& IUSE="${IUSE} innodb"
35 87
88mysql_version_is_at_least "5.01.00.00" \
89|| IUSE="${IUSE} berkdb"
90
36EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_config pkg_postrm 91EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \
92 pkg_postinst pkg_config pkg_postrm
93
94#
95# HELPER FUNCTIONS:
96#
37 97
38# void mysql_init_vars() 98# void mysql_init_vars()
39# 99#
40# initialize global variables 100# Initialize global variables
41# 2005-11-19 <vivo at gentoo.org> 101# 2005-11-19 <vivo@gentoo.org>
102
42mysql_init_vars() { 103mysql_init_vars() {
43
44 if [[ ${SLOT} -eq 0 ]] ; then
45 MY_SUFFIX=""
46 else
47 MY_SUFFIX=${MY_SUFFIX:-"-${SLOT}"}
48 fi
49 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR:-"/usr/share/mysql${MY_SUFFIX}"} 104 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"}
50 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql${MY_SUFFIX}"} 105 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"}
51 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql${MY_SUFFIX}"} 106 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"}
52 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql${MY_SUFFIX}"} 107 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"}
53 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql${MY_SUFFIX}"} 108 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql"}
54 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql${MY_SUFFIX}"} 109 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql"}
55 110
56 if [ -z "${DATADIR}" ]; then 111 if [[ -z "${DATADIR}" ]] ; then
57 DATADIR="" 112 DATADIR=""
58 if [ -f "${SYSCONFDIR}/my.cnf" ] ; then 113 if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then
59 DATADIR=`"my_print_defaults${MY_SUFFIX}" mysqld 2>/dev/null | sed -ne '/datadir/s|^--datadir=||p' | tail -n1` 114 DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
115 | sed -ne '/datadir/s|^--datadir=||p' \
116 | tail -n1`
60 if [ -z "${DATADIR}" ]; then 117 if [[ -z "${DATADIR}" ]] ; then
61 if useq "srvdir" ; then 118 if useq "srvdir" ; then
62 DATADIR="/srv/localhost/mysql/datadir" 119 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
63 else 120 else
64 DATADIR=`grep ^datadir "${SYSCONFDIR}/my.cnf" | sed -e 's/.*=\s*//'` 121 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \
122 | sed -e 's/.*=\s*//'`
65 fi 123 fi
66 fi 124 fi
67 fi 125 fi
68 if [ -z "${DATADIR}" ]; then 126 if [[ -z "${DATADIR}" ]] ; then
127 if useq "srvdir" ; then
128 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
129 else
69 DATADIR="${MY_LOCALSTATEDIR}" 130 DATADIR="${MY_LOCALSTATEDIR}"
131 fi
70 einfo "Using default DATADIR" 132 einfo "Using default DATADIR"
71 fi 133 fi
72 einfo "MySQL DATADIR is ${DATADIR}" 134 elog "MySQL DATADIR is ${DATADIR}"
73 135
74 if [ -z "${PREVIOUS_DATADIR}" ] ; then 136 if [[ -z "${PREVIOUS_DATADIR}" ]] ; then
75 if [ -a "${DATADIR}" ] ; then 137 if [[ -e "${DATADIR}" ]] ; then
76 ewarn "Previous datadir found, it's YOUR job to change" 138 elog "Previous datadir found, it's YOUR job to change"
77 ewarn "ownership and have care of it" 139 elog "ownership and take care of it"
78 PREVIOUS_DATADIR="yes" 140 PREVIOUS_DATADIR="yes"
79 export PREVIOUS_DATADIR
80 else 141 else
81 PREVIOUS_DATADIR="no" 142 PREVIOUS_DATADIR="no"
82 export PREVIOUS_DATADIR
83 fi 143 fi
84 fi 144 export PREVIOUS_DATADIR
85 fi 145 fi
146 fi
86 147
87 export MY_SUFFIX MY_SHAREDSTATEDIR MY_SYSCONFDIR 148 export MY_SHAREDSTATEDIR MY_SYSCONFDIR
88 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR 149 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
89 export MY_INCLUDEDIR 150 export MY_INCLUDEDIR
90 export DATADIR 151 export DATADIR
91} 152}
92 153
93mysql_pkg_setup() { 154configure_minimal() {
155 # These are things we exclude from a minimal build, please
156 # note that the server actually does get built and installed,
157 # but we then delete it before packaging.
158 local minimal_exclude_list="server embedded-server extra-tools innodb bench berkeley-db row-based-replication"
94 159
95 enewgroup mysql 60 || die "problem adding group mysql" 160 for i in ${minimal_exclude_list} ; do
96 enewuser mysql 60 -1 /dev/null mysql \ 161 myconf="${myconf} --without-${i}"
97 || die "problem adding user mysql"
98}
99
100mysql_src_unpack() {
101
102 mysql_init_vars
103
104 if useq static && useq ssl; then
105 local msg="MySQL does not support building statically with SSL support"
106 eerror "${msg}"
107 die "${msg}"
108 fi
109
110 if mysql_version_is_at_least "4.01.03.00" \
111 && useq cluster \
112 || useq extraengine \
113 && useq minimal ; then
114 die "USEs cluster, extraengine conflicts with \"minimal\""
115 fi
116
117 unpack ${A} || die
118
119 mv -f "${WORKDIR}/${NEWP}" "${S}"
120 cd "${S}"
121
122 EPATCH_SUFFIX="patch"
123 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory"
124 mysql_mv_patches
125 epatch || die "failed to apply all patches"
126
127 # additional check, remove bundled zlib
128 rm -f "${S}/zlib/"*.[ch]
129 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
130 rm -f scripts/mysqlbug
131
132 # Multilib issue with zlib detection
133 mysql_version_is_at_least "5.00.15.00" \
134 && sed -i -e "s:zlib_dir/lib:zlib_dir/$(get_libdir):g" \
135 "${S}/config/ac-macros/zlib.m4"
136
137 # Make charsets install in the right place
138 find . -name 'Makefile.am' \
139 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
140
141 # Manage mysqlmanager
142 mysql_version_is_at_least "5.00.15.00" \
143 && sed -i -e "s!@GENTOO_EXT@!${MY_SUFFIX}!g" \
144 -e "s!@GENTOO_SOCK_PATH@!var/run/mysqld!g" \
145 "${S}/server-tools/instance-manager/Makefile.am"
146
147 # remove what need to be recreated, so we are sure it's actually done
148 find . -name Makefile -o -name Makefile.in -o -name configure -exec rm -f {} \;
149 rm ltmain.sh
150
151 local rebuilddirlist d buildstep bdbdir
152
153 if mysql_version_is_at_least "5.01.00.00" ; then
154 rebuilddirlist=". storage/innobase"
155 bdbdir='storage/bdb/dist'
156 else
157 rebuilddirlist=". innobase"
158 bdbdir='bdb/dist'
159 fi
160
161 for d in ${rebuilddirlist}; do
162 einfo "reconfiguring dir \"${d}\""
163 pushd "${d}" &>/dev/null
164 for buildstep in \
165 'libtoolize --copy --force' \
166 'aclocal --force' \
167 'autoheader --force -Wnone' \
168 'autoconf --force -Wnone' \
169 'automake --force --force-missing -Wnone' \
170 'gnuconfig_update'
171 do
172 einfo "performing ${buildstep}"
173 ${buildstep} || die "failed ${buildstep/ */} dir \"${d}\""
174 done 162 done
175 popd &>/dev/null 163 myconf="${myconf} --with-extra-charsets=none"
176 done
177
178 if useq berkdb && ! mysql_check_version_range "5.01.00.00 to 5.01.06.99"
179 then
180 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh"
181 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" &>/dev/null
182 popd &>/dev/null
183 fi
184
185} 164}
186 165
187mysql_src_compile() { 166configure_common() {
167 myconf="${myconf} $(use_with big-tables)"
168 myconf="${myconf} --enable-local-infile"
169 myconf="${myconf} --with-extra-charsets=all"
170 myconf="${myconf} --with-mysqld-user=mysql"
171 myconf="${myconf} --with-server"
172 myconf="${myconf} --with-unix-socket-path=/var/run/mysqld/mysqld.sock"
173 myconf="${myconf} --without-libwrap"
188 174
189 mysql_init_vars
190 local myconf
191
192 if useq static ; then 175 if useq "static" ; then
193 myconf="${myconf} --with-mysqld-ldflags=-all-static" 176 myconf="${myconf} --with-mysqld-ldflags=-all-static"
194 myconf="${myconf} --with-client-ldflags=-all-static" 177 myconf="${myconf} --with-client-ldflags=-all-static"
195 myconf="${myconf} --disable-shared" 178 myconf="${myconf} --disable-shared"
196 else 179 else
197 myconf="${myconf} --enable-shared --enable-static" 180 myconf="${myconf} --enable-shared --enable-static"
198 fi 181 fi
199 182
200 #myconf="${myconf} `use_with tcpd libwrap`" 183 if useq "debug" ; then
184 myconf="${myconf} --with-debug=full"
185 else
186 myconf="${myconf} --without-debug"
187 mysql_version_is_at_least "4.01.03.00" \
188 && useq "cluster" \
189 && myconf="${myconf} --without-ndb-debug"
190 fi
191
192 if mysql_version_is_at_least "4.01.00.00" && ! useq "latin1" ; then
193 myconf="${myconf} --with-charset=utf8"
194 myconf="${myconf} --with-collation=utf8_general_ci"
195 else
196 myconf="${myconf} --with-charset=latin1"
197 myconf="${myconf} --with-collation=latin1_swedish_ci"
198 fi
199
200 if useq "embedded" ; then
201 myconf="${myconf} --with-embedded-privilege-control"
202 myconf="${myconf} --with-embedded-server"
203 else
204 myconf="${myconf} --without-embedded-privilege-control"
205 myconf="${myconf} --without-embedded-server"
206 fi
207
208}
209
210configure_40_41_50() {
211 myconf="${myconf} $(use_with perl bench)"
212 myconf="${myconf} --enable-assembler"
213 myconf="${myconf} --with-extra-tools"
214 myconf="${myconf} --with-innodb"
201 myconf="${myconf} --without-libwrap" 215 myconf="${myconf} --without-readline"
216 mysql_version_is_at_least "5.00.00.00" || myconf="${myconf} $(use_with raid)"
202 217
203 if useq ssl ; then 218 if useq "ssl" ; then
204 # --with-vio is not needed anymore, it's on by default and 219 # --with-vio is not needed anymore, it's on by default and
205 # has been removed from configure 220 # has been removed from configure
206 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio" 221 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio"
207 if mysql_version_is_at_least "5.00.06.00" ; then 222 if mysql_version_is_at_least "5.00.06.00" ; then
208 # yassl-0.96 is young break with gcc-4.0 || amd64
209 #myconf="${myconf} --with-yassl" 223 # myconf="${myconf} --with-yassl"
210 myconf="${myconf} --with-openssl" 224 myconf="${myconf} --with-openssl"
211 else 225 else
212 myconf="${myconf} --with-openssl" 226 myconf="${myconf} --with-openssl"
213 fi 227 fi
214 else 228 else
215 myconf="${myconf} --without-openssl" 229 myconf="${myconf} --without-openssl"
216 fi 230 fi
217 231
218 if useq debug; then 232 # The following fix is due to a bug with bdb on SPARC's. See:
233 # http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
234 # It comes down to non-64-bit safety problems.
235 if useq "sparc" || useq "alpha" || useq "hppa" || useq "mips" || useq "amd64" ; then
236 elog "Berkeley DB support was disabled due to incompatible arch"
219 myconf="${myconf} --with-debug=full" 237 myconf="${myconf} --without-berkeley-db"
220 else 238 else
221 myconf="${myconf} --without-debug" 239 if useq "berkdb" ; then
222 mysql_version_is_at_least "4.01.03.00" && useq cluster && myconf="${myconf} --without-ndb-debug"
223 fi
224
225 # benchmarking stuff needs perl
226 # and shouldn't be bothered with on minimal builds
227 if useq perl && ! useq minimal; then
228 myconf="${myconf} --with-bench" 240 myconf="${myconf} --with-berkeley-db=./bdb"
229 else
230 myconf="${myconf} --without-bench"
231 fi
232
233 # these are things we exclude from a minimal build
234 # note that the server actually does get built and installed
235 # but we then delete it before packaging.
236 local minimal_exclude_list="server embedded-server extra-tools innodb"
237 if ! useq minimal; then
238 for i in ${minimal_exclude_list}; do
239 myconf="${myconf} --with-${i}"
240 done
241
242 if useq static ; then
243 myconf="${myconf} --without-raid"
244 ewarn "disabling raid support, has problem with static"
245 else 241 else
246 myconf="${myconf} --with-raid"
247 fi
248
249 if ! mysql_version_is_at_least "5.00.00.00" ; then
250 if mysql_version_is_at_least "4.01.00.00" ; then
251 myconf="${myconf} --with-charset=utf8"
252 myconf="${myconf} --with-collation=utf8_general_ci"
253 else
254 myconf="${myconf} --with-charset=latin1"
255 myconf="${myconf} --with-collation=latin1_swedish_ci"
256 fi
257 fi
258
259 # optional again from 2005-12-05
260 if mysql_version_is_at_least "5.01.00.00" ; then
261 myconf="${myconf} $(use_with innodb)"
262 else
263 myconf="${myconf} --with-innodb"
264 fi
265
266 # lots of chars
267 myconf="${myconf} --with-extra-charsets=all"
268
269 #The following fix is due to a bug with bdb on sparc's. See:
270 #http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
271 # it comes down to non-64-bit safety problems
272 if useq sparc || useq alpha || useq hppa || useq mips || useq amd64 \
273 || mysql_check_version_range "5.01.00.00 to 5.01.06.99"
274 then
275 ewarn "bdb berkeley-db disabled due to arch or version"
276 myconf="${myconf} --without-berkeley-db" 242 myconf="${myconf} --without-berkeley-db"
277 else 243 fi
278 useq berkdb \
279 && myconf="${myconf} --with-berkeley-db=./bdb" \
280 || myconf="${myconf} --without-berkeley-db"
281 fi 244 fi
282 245
283 if mysql_version_is_at_least "4.01.03.00" ; then 246 if mysql_version_is_at_least "4.01.03.00" ; then
284 #myconf="${myconf} $(use_with geometry)"
285 myconf="${myconf} --with-geometry" 247 myconf="${myconf} --with-geometry"
286 myconf="${myconf} $(use_with cluster ndbcluster)" 248 myconf="${myconf} $(use_with cluster ndbcluster)"
287 fi 249 fi
288 250
289 mysql_version_is_at_least "4.01.11.00" && myconf="${myconf} `use_with big-tables`"
290 else
291 for i in ${minimal_exclude_list}; do
292 myconf="${myconf} --without-${i}"
293 done
294 myconf="${myconf} --without-berkeley-db"
295 myconf="${myconf} --with-extra-charsets=none"
296 fi
297
298 if mysql_version_is_at_least "4.01.03.00" && useq extraengine; then 251 if mysql_version_is_at_least "4.01.03.00" && useq "extraengine" ; then
299 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html 252 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
300 myconf="${myconf} --with-archive-storage-engine" 253 myconf="${myconf} --with-archive-storage-engine"
254
301 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html 255 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
302
303 mysql_version_is_at_least "4.01.04.00" \
304 && myconf="${myconf} --with-csv-storage-engine" 256 myconf="${myconf} --with-csv-storage-engine"
305 257
306 mysql_version_is_at_least "4.01.11.00" \ 258 # http://dev.mysql.com/doc/mysql/en/blackhole-storage-engine.html
307 && myconf="${myconf} --with-blackhole-storage-engine" 259 myconf="${myconf} --with-blackhole-storage-engine"
308 260
261 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
309 # http://dev.mysql.com/doc/mysql/en/federated-description.html 262 # http://dev.mysql.com/doc/mysql/en/federated-description.html
310 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html 263 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
311 if mysql_version_is_at_least "5.00.03.00" ; then 264 if mysql_version_is_at_least "5.00.03.00" ; then
312 einfo "before to use federated engine be sure to read" 265 elog "Before using the Federated storage engine, please be sure to read"
313 einfo "http://dev.mysql.com/doc/refman/5.0/en/federated-limitations.html" 266 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
314 myconf="${myconf} --with-federated-storage-engine" 267 myconf="${myconf} --with-federated-storage-engine"
315
316 # http://dev.mysql.com/doc/refman/5.1/en/partitioning-overview.html
317 if mysql_version_is_at_least "5.01.00.00" ; then
318 myconf="${myconf} --with-partition"
319 fi 268 fi
320 fi
321
322 fi 269 fi
323 270
324 mysql_version_is_at_least "5.00.18.00" \ 271 mysql_version_is_at_least "5.00.18.00" \
325 && useq "max-idx-128" \ 272 && useq "max-idx-128" \
326 && myconf="${myconf} --with-max-indexes=128" 273 && myconf="${myconf} --with-max-indexes=128"
274}
327 275
328 if mysql_version_is_at_least "5.01.05.00" ; then 276configure_51() {
277 # TODO: !!!! readd --without-readline
278 # the failure depend upon config/ac-macros/readline.m4 checking into
279 # readline.h instead of history.h
280 myconf="${myconf} $(use_with ssl)"
281 myconf="${myconf} --enable-assembler"
282 myconf="${myconf} --with-geometry"
283 myconf="${myconf} --with-readline"
329 myconf="${myconf} --with-row-based-replication" 284 myconf="${myconf} --with-row-based-replication"
285 myconf="${myconf} --with-zlib=/usr/$(get_libdir)"
286 myconf="${myconf} --without-pstack"
287 useq "max-idx-128" && myconf="${myconf} --with-max-indexes=128"
288
289 # 5.1 introduces a new way to manage storage engines (plugins)
290 # like configuration=none
291 local plugins="csv,myisam,myisammrg,heap"
292 if useq "extraengine" ; then
293 # like configuration=max-no-ndb, archive and example removed in 5.1.11
294 plugins="${plugins},archive,blackhole,example,federated,ftexample,partition"
295
296 elog "Before using the Federated storage engine, please be sure to read"
297 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
298 fi
299
300 if useq "innodb" ; then
301 plugins="${plugins},innobase"
302 fi
303
304 # like configuration=max-no-ndb
305 if useq "cluster" ; then
306 plugins="${plugins},ndbcluster"
307 myconf="${myconf} --with-ndb-binlog"
308 fi
309
310 myconf="${myconf} --with-plugins=${plugins}"
311}
312
313#
314# EBUILD FUNCTIONS
315#
316
317mysql_pkg_setup() {
318 enewgroup mysql 60 || die "problem adding 'mysql' group"
319 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
320
321 if mysql_version_is_at_least "5.01.12.00" && useq "innodb" ; then
322 eerror "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
323 die "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
324 fi
325
326 # Check for USE flag problems in pkg_setup
327 if useq "static" && useq "ssl" ; then
328 eerror "MySQL does not support being built statically with SSL support enabled!"
329 die "MySQL does not support being built statically with SSL support enabled!"
330 fi
331
332 if ! mysql_version_is_at_least "5.00.00.00" \
333 && useq "raid" \
334 && useq "static" ; then
335 eerror "USE flags 'raid' and 'static' conflict, you cannot build MySQL statically"
336 eerror "with RAID support enabled."
337 die "USE flags 'raid' and 'static' conflict!"
338 fi
339
340 if mysql_version_is_at_least "4.01.03.00" \
341 && ( useq "cluster" || useq "extraengine" ) \
342 && useq "minimal" ; then
343 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
344 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
345 fi
346
347 mysql_check_version_range "4.00.00.00 to 5.00.99.99" \
348 && useq "berkdb" \
349 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
350}
351
352mysql_src_unpack() {
353 # Initialize the proper variables first
354 mysql_init_vars
355
356 unpack ${A}
357
358 mv -f "${WORKDIR}/${MY_P}${MYSQL_RERELEASE}" "${S}"
359 cd "${S}"
360
361 # Apply the patches for this MySQL version
362 if [[ -d "${WORKDIR}/${MY_FIXED_PV}" ]] ; then
363 EPATCH_SOURCE="${WORKDIR}/${MY_FIXED_PV}" EPATCH_SUFFIX="patch" epatch
364 fi
365
366 # Additional checks, remove bundled zlib
367 rm -f "${S}/zlib/"*.[ch]
368 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
369 rm -f "scripts/mysqlbug"
370
371 # Make charsets install in the right place
372 find . -name 'Makefile.am' \
373 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
374
375 # Manage mysqlmanager
376 mysql_version_is_at_least "5.00.15.00" \
377 && sed -i -e "s!@GENTOO_EXT@!!g" \
378 -e "s!@GENTOO_SOCK_PATH@!var/run/mysqld!g" \
379 "${S}/server-tools/instance-manager/Makefile.am"
380
381 if mysql_version_is_at_least "4.01.00.00" ; then
382 # Remove what needs to be recreated, so we're sure it's actually done
383 find . -name Makefile \
384 -o -name Makefile.in \
385 -o -name configure \
386 -exec rm -f {} \;
387 rm -f "ltmain.sh"
388 rm -f "scripts/mysqlbug"
389 fi
390
391 local rebuilddirlist bdbdir d
392
393 if mysql_version_is_at_least "5.01.12.00" ; then
394 # TODO: innodb is using cmake now?
395 rebuilddirlist="."
396 bdbdir=''
397 else
398 rebuilddirlist=". innobase"
399 bdbdir='bdb/dist'
400 fi
401
402 for d in ${rebuilddirlist} ; do
403 einfo "Reconfiguring dir '${d}'"
404 pushd "${d}" &>/dev/null
405 AT_GNUCONF_UPDATE="yes" eautoreconf
406 popd &>/dev/null
407 done
408
409 if mysql_check_version_range "4.01.00.00 to 5.00.99.99" \
410 && useq "berkdb" ; then
411 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f "ltmain.sh" "${bdbdir}/ltmain.sh"
412 pushd "${bdbdir}" \
413 && sh s_all \
414 || die "Failed bdb reconfigure" \
415 &>/dev/null
416 popd &>/dev/null
417 fi
418}
419
420mysql_src_compile() {
421 # Make sure the vars are correctly initialized
422 mysql_init_vars
423
424 # $myconf is modified by the configure_* functions
425 local myconf=""
426
427 if useq "minimal" ; then
428 configure_minimal
429 else
430 configure_common
431 if mysql_version_is_at_least "5.01.10.00" ; then
432 configure_51
433 else
434 configure_40_41_50
330 fi 435 fi
436 fi
331 437
332 #Bug #114895,Bug #110149 438 # Bug #114895, bug #110149
333 filter-flags "-O" "-O[01]" 439 filter-flags "-O" "-O[01]"
440
334 #glibc-2.3.2_pre fix; bug #16496 441 # glib-2.3.2_pre fix, bug #16496
335 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 442 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
336 443
337 #the compiler flags are as per their "official" spec ;) 444 append-flags "-fno-exceptions -fno-strict-aliasing"
338 #CFLAGS="${CFLAGS/-O?/} -O3" \
339 export CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" 445 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
340 mysql_version_is_at_least "5.00.00.00" \ 446 mysql_version_is_at_least "5.00.00.00" \
341 && export CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 447 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
448 export CXXFLAGS
342 449
343 econf \ 450 econf \
344 --program-suffix="${MY_SUFFIX}" \
345 --libexecdir="/usr/sbin" \ 451 --libexecdir="/usr/sbin" \
346 --sysconfdir="${MY_SYSCONFDIR}" \ 452 --sysconfdir="${MY_SYSCONFDIR}" \
347 --localstatedir="${MY_LOCALSTATEDIR}" \ 453 --localstatedir="${MY_LOCALSTATEDIR}" \
348 --sharedstatedir="${MY_SHAREDSTATEDIR}" \ 454 --sharedstatedir="${MY_SHAREDSTATEDIR}" \
349 --libdir="${MY_LIBDIR}" \ 455 --libdir="${MY_LIBDIR}" \
350 --includedir="${MY_INCLUDEDIR}" \ 456 --includedir="${MY_INCLUDEDIR}" \
351 --with-low-memory \ 457 --with-low-memory \
352 --enable-assembler \
353 --enable-local-infile \
354 --with-mysqld-user=mysql \
355 --with-client-ldflags=-lstdc++ \ 458 --with-client-ldflags=-lstdc++ \
356 --enable-thread-safe-client \ 459 --enable-thread-safe-client \
357 --with-comment="Gentoo Linux ${PF}" \ 460 --with-comment="Gentoo Linux ${PF}" \
358 --with-unix-socket-path="/var/run/mysqld/mysqld${MY_SUFFIX}.sock" \
359 --with-zlib-dir=/usr \
360 --with-lib-ccflags="-fPIC" \
361 --without-readline \
362 --without-docs \ 461 --without-docs \
363 ${myconf} || die "bad ./configure" 462 ${myconf} || die "econf failed"
364 463
365 # TODO Move this before autoreconf !!! 464 # TODO: Move this before autoreconf !!!
366 find . -name 'Makefile' \ 465 find . -type f -name Makefile -print0 \
367 -exec sed --in-place \ 466 | xargs -0 -n100 sed -i \
368 -e 's|^pkglibdir\s*=\s*$(libdir)/mysql|pkglibdir = $(libdir)|' \ 467 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
369 -e 's|^pkgincludedir\s*=\s*$(includedir)/mysql|pkgincludedir = $(includedir)|' \
370 {} \;
371 468
372 emake || die "compile problem" 469 emake || die "emake failed"
373} 470}
374 471
375mysql_src_install() { 472mysql_src_install() {
376 473 # Make sure the vars are correctly initialized
377 mysql_init_vars 474 mysql_init_vars
475
378 make install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die 476 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed"
379 477
380 insinto "${MY_INCLUDEDIR}" 478 insinto "${MY_INCLUDEDIR}"
381 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h 479 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h
382 480
383 # convenience links 481 # Convenience links
384 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlanalyze${MY_SUFFIX}" 482 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
385 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlrepair${MY_SUFFIX}" 483 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
386 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqloptimize${MY_SUFFIX}" 484 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize"
387 485
388 # various junk (my-*.cnf moved elsewhere) 486 # Various junk (my-*.cnf moved elsewhere)
389 rm -rf "${D}/usr/share/info" 487 rm -Rf "${D}/usr/share/info"
390 for removeme in "mysql-log-rotate" mysql.server* \ 488 for removeme in "mysql-log-rotate" mysql.server* \
391 binary-configure* my-*.cnf mi_test_all* 489 binary-configure* my-*.cnf mi_test_all*
392 do 490 do
393 rm -f ${D}/usr/share/mysql/${removeme} 491 rm -f "${D}"/usr/share/mysql/${removeme}
394 done 492 done
395 493
396 # TODO change at Makefile-am level
397 for moveme in "mysql_fix_privilege_tables.sql" \
398 "fill_help_tables.sql" "ndb-config-2-node.ini"
399 do
400 mv -f "${D}/usr/share/mysql/${moveme}" "${D}/usr/share/mysql${MY_SUFFIX}/" 2>/dev/null
401 done
402
403 if [[ -n "${MY_SUFFIX}" ]] ; then
404 local notcatched=$(ls "${D}/usr/share/mysql"/*)
405 if [[ -n "${notcatched}" ]] ; then
406 ewarn "QA notice"
407 ewarn "${notcatched} files in /usr/share/mysql"
408 ewarn "bug mysql-herd to manage them"
409 fi
410 rm -rf "${D}/usr/share/mysql"
411 fi
412
413 # clean up stuff for a minimal build 494 # Clean up stuff for a minimal build
414 # this is anything server-specific
415 if useq minimal; then 495 if useq "minimal" ; then
416 rm -rf ${D}${MY_SHAREDSTATEDIR}/{mysql-test,sql-bench} 496 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
417 rm -f ${D}/usr/bin/{mysql{_install_db,manager*,_secure_installation,_fix_privilege_tables,hotcopy,_convert_table_format,d_multi,_fix_extensions,_zap,_explain_log,_tableinfo,d_safe,_install,_waitpid,binlog,test},myisam*,isam*,pack_isam} 497 rm -f "${D}"/usr/bin/{mysql{_install_db,manager*,_secure_installation,_fix_privilege_tables,hotcopy,_convert_table_format,d_multi,_fix_extensions,_zap,_explain_log,_tableinfo,d_safe,_install,_waitpid,binlog,test},myisam*,isam*,pack_isam}
418 rm -f "${D}/usr/sbin/mysqld${MY_SUFFIX}" 498 rm -f "${D}/usr/sbin/mysqld"
419 rm -f ${D}${MY_LIBDIR}/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a 499 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
420 fi 500 fi
421 501
422 # config stuff 502 # Configuration stuff
503 if mysql_version_is_at_least "4.01.00.00" ; then
504 mysql_mycnf_version="4.1"
505 else
506 mysql_mycnf_version="4.0"
507 fi
423 insinto "${MY_SYSCONFDIR}" 508 insinto "${MY_SYSCONFDIR}"
424 doins scripts/mysqlaccess.conf 509 doins "scripts/mysqlaccess.conf"
425 sed -e "s!@MY_SUFFIX@!${MY_SUFFIX}!g" \
426 -e "s!@DATADIR@!${DATADIR}!g" \ 510 sed -e "s!@DATADIR@!${DATADIR}!g" \
427 "${FILESDIR}/my.cnf-4.1-r1" \ 511 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
428 > "${TMPDIR}/my.cnf.ok" 512 > "${TMPDIR}/my.cnf.ok"
429ls -l ${TMPDIR} ${FILESDIR}/my.cnf-4.1-r1 513 if mysql_version_is_at_least "4.01.00.00" && useq "latin1" ; then
514 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok"
515 fi
430 newins "${TMPDIR}/my.cnf.ok" my.cnf 516 newins "${TMPDIR}/my.cnf.ok" my.cnf
431 517
432 insinto "/etc/conf.d" 518 insinto "/etc/conf.d"
433 newins "${FILESDIR}/mysql-slot.conf.d-r2" "mysql" 519 newins "${FILESDIR}/mysql.conf.d" "mysql"
434 mysql_version_is_at_least "5.00.11.00" \ 520 mysql_version_is_at_least "5.00.11.00" \
435 && newins "${FILESDIR}/mysqlmanager-slot.conf.d" "mysqlmanager" 521 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager"
436 522
437 # minimal builds don't have the server 523 # Minimal builds don't have the MySQL server
438 if ! useq minimal; then 524 if ! useq "minimal" ; then
439 exeinto /etc/init.d 525 exeinto "/etc/init.d"
440 newexe "${FILESDIR}/mysql-slot.rc6-r2" "mysql" 526 newexe "${FILESDIR}/mysql.rc6" "mysql"
441 [[ ${SLOT} -gt 0 ]] && dosym "/etc/init.d/mysql" "/etc/init.d/mysql${MY_SUFFIX}"
442
443 mysql_version_is_at_least "5.00.11.00" \ 527 mysql_version_is_at_least "5.00.11.00" \
444 && newexe "${FILESDIR}/mysqlmanager-slot.rc6" "mysqlmanager" 528 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager"
529
445 insinto /etc/logrotate.d 530 insinto "/etc/logrotate.d"
446 sed -e "s!___MY_SUFFIX___!${MY_SUFFIX}!g" \
447 "${FILESDIR}/logrotate-slot.mysql" \
448 > "${TMPDIR}/logrotate.mysql"
449 newins "${TMPDIR}/logrotate.mysql" "mysql${MY_SUFFIX}" 531 newins "${FILESDIR}/logrotate.mysql" "mysql"
450 532
451 #empty dirs... 533 # Empty directories ...
452 diropts "-m0750" 534 diropts "-m0750"
453 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 535 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
454 dodir "${DATADIR}" 536 dodir "${DATADIR}"
455 keepdir "${DATADIR}" 537 keepdir "${DATADIR}"
456 chown -R mysql:mysql "${D}/${DATADIR}" 538 chown -R mysql:mysql "${D}/${DATADIR}"
462 keepdir "${folder}" 544 keepdir "${folder}"
463 chown -R mysql:mysql "${D}/${folder}" 545 chown -R mysql:mysql "${D}/${folder}"
464 done 546 done
465 fi 547 fi
466 548
467 # docs 549 # Docs
468 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 550 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
551
469 # minimal builds don't have the server 552 # Minimal builds don't have the MySQL server
470 if ! useq minimal; then 553 if ! useq "minimal" ; then
471 docinto "support-files" 554 docinto "support-files"
472 for script in \ 555 for script in \
473 support-files/my-*.cnf \ 556 support-files/my-*.cnf \
474 support-files/magic \ 557 support-files/magic \
475 support-files/ndb-config-2-node.ini 558 support-files/ndb-config-2-node.ini
481 for script in scripts/mysql* ; do 564 for script in scripts/mysql* ; do
482 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 565 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
483 done 566 done
484 fi 567 fi
485 568
486 # oops, temporary fix 569 ROOT="${D}" mysql_lib_symlinks
487 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \
488 && cp -f \
489 "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0" \
490 "${D}/usr/share/mysql${MY_SUFFIX}/fill_help_tables.sql"
491} 570}
492 571
493mysql_pkg_preinst() { 572mysql_pkg_preinst() {
494
495 enewgroup mysql 60 || die "problem adding group mysql" 573 enewgroup mysql 60 || die "problem adding 'mysql' group"
496 enewuser mysql 60 -1 /dev/null mysql \ 574 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
497 || die "problem adding user mysql"
498} 575}
499 576
500mysql_pkg_postinst() { 577mysql_pkg_postinst() {
501 578 # Make sure the vars are correctly initialized
502 mysql_init_vars 579 mysql_init_vars
503 mysql_lib_symlinks
504 580
505 # mind at FEATURES=collision-protect before to remove this 581 # Check FEATURES="collision-protect" before removing this
506 [ -d "${ROOT}/var/log/mysql" ] \ 582 [[ -d "${ROOT}/var/log/mysql" ]] \
507 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}" 583 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
508 584
509 #secure the logfiles... does this bother anybody? 585 # Secure the logfiles
510 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 586 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
511 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 587 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
512 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 588 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
513 589
514 # create a list of files, to be used
515 # by external utilities
516 # uncompressed because of the small size
517 local filelist="${ROOT}/var/lib/eselect/mysql/mysql${MY_SUFFIX}"
518 pushd "${D}/" &>/dev/null
519 mkdir -p "${ROOT}/var/lib/eselect/mysql/"
520 env -i find usr/bin/ usr/sbin/ usr/share/man \
521 -type f -name "*${MY_SUFFIX}*" \
522 -and -not -name "mysql_config${MY_SUFFIX}" \
523 > "${filelist}.filelist"
524 echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}.filelist"
525 echo "${MY_LIBDIR#"/"}" >> "${filelist}.filelist"
526 echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}.filelist"
527 popd &>/dev/null
528
529 if ! useq minimal; then 590 if ! useq "minimal" ; then
530 if [[ ${SLOT} -gt 0 ]] ; then
531 if [[ -f "${ROOT}/usr/sbin/mysqld" ]] ; then
532 einfo "you may want to run unmerge any unslotted MySQL versions with "
533 einfo "emerge -C --pretend dev-db/mysql"
534 einfo "emerge -C =dev-db/mysql-X.Y.Z"
535 einfo "After the unmerge run \"eselect myqsl list\" followed by a "
536 einfo "\"eselect myqsl set 1\" to chose the default mysql server"
537 else
538 local tmpres="$( eselect mysql show )"
539 # "like grep -q unset"
540 if [[ "{$tmpres}" == "{$tmpres/unset/}" ]] ; then
541 eselect mysql set 1
542 else
543 einfo "The version of mysql emerged now stils is _NOT_ the default"
544 einfo "you may want to run \"eselect myqsl list\" followed by a "
545 einfo "\"eselect myqsl set 1\" to chose the default mysql server"
546 fi
547 fi
548 fi
549
550 # your friendly public service announcement... 591 # Your friendly public service announcement ...
551 einfo 592 einfo
552 einfo "You might want to run:" 593 elog "You might want to run:"
553 einfo "\"emerge --config =${CATEGORY}/${PF}\"" 594 elog "\"emerge --config =${CATEGORY}/${PF}\""
554 einfo "if this is a new install." 595 elog "if this is a new install."
555 einfo 596 einfo
597 mysql_version_is_at_least "5.01.00.00" \
556 einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream." 598 || elog "InnoDB is *not* optional as of MySQL-4.0.24, at the request of upstream."
557 fi 599 fi
600 mysql_check_version_range "4.00.00.00 to 5.00.99.99" \
601 && useq "berkdb" \
602 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
558} 603}
559 604
560mysql_pkg_config() { 605mysql_pkg_config() {
606 # Make sure the vars are correctly initialized
561 mysql_init_vars 607 mysql_init_vars
608
562 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR" 609 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR"
563 610
564 if built_with_use dev-db/mysql minimal; then 611 if built_with_use dev-db/mysql minimal ; then
565 die "Minimal builds do NOT include the MySQL server" 612 die "Minimal builds do NOT include the MySQL server"
566 fi 613 fi
567 614
568 local pwd1="a" 615 local pwd1="a"
569 local pwd2="b" 616 local pwd2="b"
575 ewarn "Please rename or delete it if you wish to replace it." 622 ewarn "Please rename or delete it if you wish to replace it."
576 die "MySQL database already exists!" 623 die "MySQL database already exists!"
577 fi 624 fi
578 625
579 einfo "Creating the mysql database and setting proper" 626 einfo "Creating the mysql database and setting proper"
580 einfo "permissions on it..." 627 einfo "permissions on it ..."
581 628
582 einfo "Insert a password for the mysql 'root' user" 629 einfo "Insert a password for the mysql 'root' user"
583 ewarn "Avoid [\"'\\_%] characters in the password" 630 ewarn "Avoid [\"'\\_%] characters in the password"
584
585 read -rsp " >" pwd1 ; echo 631 read -rsp " >" pwd1 ; echo
632
586 einfo "Check the password" 633 einfo "Retype the password"
587 read -rsp " >" pwd2 ; echo 634 read -rsp " >" pwd2 ; echo
588 635
589 if [[ "x$pwd1" != "x$pwd2" ]] ; then 636 if [[ "x$pwd1" != "x$pwd2" ]] ; then
590 die "Passwords are not the same" 637 die "Passwords are not the same"
591 fi 638 fi
592 639
593 local options="" 640 local options=""
594 local sqltmp="$(emktemp)" 641 local sqltmp="$(emktemp)"
595 642
596 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql" 643 local help_tables="${ROOT}${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
597 [[ -r "${help_tables}" ]] \ 644 [[ -r "${help_tables}" ]] \
598 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \ 645 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
599 || touch "${TMPDIR}/fill_help_tables.sql" 646 || touch "${TMPDIR}/fill_help_tables.sql"
600 help_tables="${TMPDIR}/fill_help_tables.sql" 647 help_tables="${TMPDIR}/fill_help_tables.sql"
601 648
602 pushd "${TMPDIR}" &>/dev/null 649 pushd "${TMPDIR}" &>/dev/null
603 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR" 650 "${ROOT}/usr/bin/mysql_install_db" | grep -B5 -A999 -i "ERROR"
604 popd &>/dev/null 651 popd &>/dev/null
605 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] || die "MySQL databases not installed" 652 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \
653 || die "MySQL databases not installed"
606 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null 654 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null
607 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null 655 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null
608 656
609 if mysql_version_is_at_least "4.01.03.00" ; then 657 if mysql_version_is_at_least "4.01.03.00" ; then
610 options="--skip-ndbcluster" 658 options="--skip-ndbcluster"
611 659
612 # Filling timezones, see 660 # Filling timezones, see
613 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 661 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html
614 ${ROOT}/usr/bin/mysql_tzinfo_to_sql${MY_SUFFIX} ${ROOT}/usr/share/zoneinfo \ 662 "${ROOT}/usr/bin/mysql_tzinfo_to_sql" "${ROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
615 > "${sqltmp}" 2>/dev/null
616 663
617 if [[ -r "${help_tables}" ]] ; then 664 if [[ -r "${help_tables}" ]] ; then
618 cat "${help_tables}" >> "${sqltmp}" 665 cat "${help_tables}" >> "${sqltmp}"
619 fi 666 fi
620 fi 667 fi
621 668
622 local socket=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.sock 669 local socket="${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock"
623 local pidfile=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.sock 670 local pidfile="${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid"
624 local mysqld="${ROOT}/usr/sbin/mysqld${MY_SUFFIX} \ 671 local mysqld="${ROOT}/usr/sbin/mysqld \
625 ${options} \ 672 ${options} \
626 --user=mysql \ 673 --user=mysql \
627 --skip-grant-tables \ 674 --skip-grant-tables \
628 --basedir=${ROOT}/usr \ 675 --basedir=${ROOT}/usr \
629 --datadir=${ROOT}/${DATADIR} \ 676 --datadir=${ROOT}/${DATADIR} \
632 --skip-networking \ 679 --skip-networking \
633 --max_allowed_packet=8M \ 680 --max_allowed_packet=8M \
634 --net_buffer_length=16K \ 681 --net_buffer_length=16K \
635 --socket=${socket} \ 682 --socket=${socket} \
636 --pid-file=${pidfile}" 683 --pid-file=${pidfile}"
637 $mysqld & 684 ${mysqld} &
638 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do 685 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do
639 maxtry=$(($maxtry-1)) 686 maxtry=$((${maxtry}-1))
640 echo -n "." 687 echo -n "."
641 sleep 1 688 sleep 1
642 done 689 done
643 690
644 # do this from memory we don't want clear text password in temp files 691 # Do this from memory, as we don't want clear text passwords in temp files
645 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'" 692 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'"
646 ${ROOT}/usr/bin/mysql${MY_SUFFIX} \ 693 "${ROOT}/usr/bin/mysql" \
647 --socket=${socket} \ 694 --socket=${socket} \
648 -hlocalhost \ 695 -hlocalhost \
649 -e "${sql}" 696 -e "${sql}"
650 697
651 einfo "Loading \"zoneinfo\" this step may require few seconds" 698 einfo "Loading \"zoneinfo\", this step may require a few seconds ..."
652 699
653 ${ROOT}/usr/bin/mysql${MY_SUFFIX} \ 700 "${ROOT}/usr/bin/mysql" \
654 --socket=${socket} \ 701 --socket=${socket} \
655 -hlocalhost \ 702 -hlocalhost \
656 -uroot \ 703 -uroot \
657 -p"${pwd1}" \ 704 -p"${pwd1}" \
658 mysql < "${sqltmp}" 705 mysql < "${sqltmp}"
659 706
660 # server stop and cleanup 707 # Stop the server and cleanup
661 kill $(< "${pidfile}" ) 708 kill $(< "${pidfile}" )
662 rm "${sqltmp}" 709 rm -f "${sqltmp}"
663 einfo "stopping the server," 710 einfo "Stopping the server ..."
664 wait %1 711 wait %1
665 einfo "done" 712 einfo "Done"
666} 713}
667 714
668mysql_pkg_postrm() { 715mysql_pkg_postrm() {
669 mysql_lib_symlinks 716 mysql_lib_symlinks
670 if [[ ${SLOT} -gt 0 ]] ; then
671 einfo "you may want to run \"eselect myqsl list\" followed by a "
672 einfo "\"eselect myqsl list\" to chose the default mysql server"
673 fi
674} 717}

Legend:
Removed from v.1.9  
changed lines
  Added in v.1.43

  ViewVC Help
Powered by ViewVC 1.1.20