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

Diff of /eclass/mysql.eclass

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

Revision 1.28 Revision 1.120
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2009 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.28 2006/04/11 17:23:42 vivo Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.120 2009/12/09 18:46:53 robbat2 Exp $
4# $ID: $
5 4
5# @ECLASS: mysql.eclass
6# @MAINTAINER:
6# Author: Francesco Riosa <vivo at gentoo.org> 7# Author: Francesco Riosa (Retired) <vivo@gentoo.org>
8# Maintainers: MySQL Team <mysql-bugs@gentoo.org>
7# Maintainer: Luca Longinotti <chtekk at gentoo.org> 9# - Luca Longinotti <chtekk@gentoo.org>
10# - Robin H. Johnson <robbat2@gentoo.org>
11# @BLURB: This eclass provides most of the functions for mysql ebuilds
12# @DESCRIPTION:
13# The mysql.eclass provides almost all the code to build the mysql ebuilds
14# including the src_unpack, src_prepare, src_configure, src_compile,
15# scr_install, pkg_preinst, pkg_postinst, pkg_config and pkg_postrm
16# phase hooks.
8 17
9# MYSQL_VERSION_ID will be 18WANT_AUTOCONF="latest"
10# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo magic number, all [0..99] 19WANT_AUTOMAKE="latest"
11# this is an important piece, becouse from this variable depends many of the 20
12# choices the ebuild will do. 21inherit eutils flag-o-matic gnuconfig autotools mysql_fx versionator
13# in particular the code below work only with PVR like "5.0.18-r3" 22
14# the result with the previous PVR is "5001803" 23case "${EAPI:-0}" in
15if [[ -z ${MYSQL_VERSION_ID} ]] ; then 24 2)
16 tpv=( ${PV//[-._]/ } ) ; tpv[3]="${PVR:${#PV}}" ; tpv[3]="${tpv[3]##*-r}" 25 EXPORT_FUNCTIONS pkg_setup \
17 for vatom in 0 1 2 3; do 26 src_unpack src_prepare \
18 # pad to lenght 2 27 src_configure src_compile \
19 tpv[${vatom}]="00${tpv[${vatom}]}" 28 src_install \
20 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}" 29 pkg_preinst pkg_postinst \
21 done 30 pkg_config pkg_postrm
22 # strip leading "0" (otherwise it's considered an octal number from bash) 31 IUSE_DEFAULT_ON='+'
23 MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"} 32 ;;
33 0 | 1)
34 EXPORT_FUNCTIONS pkg_setup \
35 src_unpack \
36 src_compile \
37 src_install \
38 pkg_preinst pkg_postinst \
39 pkg_config pkg_postrm
40 ;;
41 *)
42 die "Unsupported EAPI: ${EAPI}" ;;
43esac
44
45# Shorten the path because the socket path length must be shorter than 107 chars
46# and we will run a mysql server during test phase
47S="${WORKDIR}/mysql"
48
49[[ "${MY_EXTRAS_VER}" == "latest" ]] && MY_EXTRAS_VER="20090228-0714Z"
50if [[ "${MY_EXTRAS_VER}" == "live" ]]; then
51 EGIT_PROJECT=mysql-extras
52 EGIT_REPO_URI="git://git.overlays.gentoo.org/proj/mysql-extras.git"
53 inherit git
24fi 54fi
25 55
26[[ -z ${MY_EXTRAS_VER} ]] && MY_EXTRAS_VER="20060411" 56# @ECLASS-VARIABLE: MYSQL_VERSION_ID
57# @DESCRIPTION:
58# MYSQL_VERSION_ID will be:
59# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99]
60# This is an important part, because many of the choices the MySQL ebuild will do
61# depend on this variable.
62# In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803"
63# We also strip off upstream's trailing letter that they use to respin tarballs
27 64
28DEPEND="${DEPEND} 65MYSQL_VERSION_ID=""
29 >=sys-libs/readline-4.1 66tpv="${PV%[a-z]}"
30 berkdb? ( sys-apps/ed ) 67tpv=( ${tpv//[-._]/ } ) ; tpv[3]="${PVR:${#PV}}" ; tpv[3]="${tpv[3]##*-r}"
68for vatom in 0 1 2 3 ; do
69 # pad to length 2
70 tpv[${vatom}]="00${tpv[${vatom}]}"
71 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}"
72done
73# strip leading "0" (otherwise it's considered an octal number by BASH)
74MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"}
75
76# @ECLASS-VARIABLE: MYSQL_COMMUNITY_FEATURES
77# @DESCRIPTION:
78# Specifiy if community features are available. Possible values are 1 (yes)
79# and 0 (no).
80# Community features are available in mysql-community
81# AND in the re-merged mysql-5.0.82 and newer
82if [ "${PN}" == "mysql-community" ]; then
83 MYSQL_COMMUNITY_FEATURES=1
84elif [ "${PV#5.0}" != "${PV}" ] && mysql_version_is_at_least "5.0.82"; then
85 MYSQL_COMMUNITY_FEATURES=1
86elif [ "${PV#5.1}" != "${PV}" ] && mysql_version_is_at_least "5.1.28"; then
87 MYSQL_COMMUNITY_FEATURES=1
88elif [ "${PV#5.4}" != "${PV}" ]; then
89 MYSQL_COMMUNITY_FEATURES=1
90else
91 MYSQL_COMMUNITY_FEATURES=0
92fi
93
94# @ECLASS-VARIABLE: XTRADB_VER
95# @DESCRIPTION:
96# Version of the XTRADB storage engine
97XTRADB_VER="${XTRADB_VER}"
98
99# @ECLASS-VARIABLE: PERCONA_VER
100# @DESCRIPTION:
101# Designation by PERCONA for a MySQL version to apply an XTRADB release
102PERCONA_VER="${PERCONA_VER}"
103
104# Be warned, *DEPEND are version-dependant
105# These are used for both runtime and compiletime
31 ssl? ( >=dev-libs/openssl-0.9.6d ) 106DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d )
32 userland_GNU? ( sys-process/procps ) 107 userland_GNU? ( sys-process/procps )
33 >=sys-libs/zlib-1.2.3 108 >=sys-apps/sed-4
34 >=sys-apps/texinfo-4.7-r1 109 >=sys-apps/texinfo-4.7-r1
35 >=sys-apps/sed-4" 110 >=sys-libs/readline-4.1
111 >=sys-libs/zlib-1.2.3"
112
113# Having different flavours at the same time is not a good idea
114for i in "" "-community" ; do
115 [[ "${i}" == ${PN#mysql} ]] ||
116 DEPEND="${DEPEND} !dev-db/mysql${i}"
117done
118
119RDEPEND="${DEPEND}
120 !minimal? ( dev-db/mysql-init-scripts )
36RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )" 121 selinux? ( sec-policy/selinux-mysql )"
122
123# compile-time-only
124mysql_version_is_at_least "5.1" \
125|| DEPEND="${DEPEND} berkdb? ( sys-apps/ed )"
126
127# compile-time-only
128mysql_version_is_at_least "5.1.12" \
129&& DEPEND="${DEPEND} >=dev-util/cmake-2.4.3"
130
37# dev-perl/DBD-mysql is needed by some scripts installed by MySQL 131# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
38PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )" 132PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
39 133
40inherit eutils flag-o-matic gnuconfig autotools mysql_fx 134# For other stuff to bring us in
135PDEPEND="${PDEPEND} =virtual/mysql-$(get_version_component_range 1-2 ${PV})"
41 136
42SLOT=0 137# Work out the default SERVER_URI correctly
138if [ -z "${SERVER_URI}" ]; then
139 # The community build is on the mirrors
140 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
141 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${PV//_/-}.tar.gz"
142 # The (old) enterprise source is on the primary site only
143 elif [ "${PN}" == "mysql" ]; then
144 SERVER_URI="ftp://ftp.mysql.com/pub/mysql/src/mysql-${PV//_/-}.tar.gz"
145 fi
146fi
43 147
44# shorten the path because the socket path length must be shorter than 107 chars 148# Define correct SRC_URIs
45# and we will run a mysql server during test phase 149SRC_URI="${SERVER_URI}"
46S="${WORKDIR}/${PN}"
47 150
151[[ ${MY_EXTRAS_VER} != live ]] && SRC_URI="${SRC_URI}
152 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
153 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
154PBXT_SRC_URI="mirror://sourceforge/pbxt/pbxt-${PBXT_VERSION}.tar.gz"
155mysql_version_is_at_least "5.1.12" \
156&& [[ -n "${PBXT_VERSION}" ]] \
157&& SRC_URI="${SRC_URI} pbxt? ( ${PBXT_SRC_URIPBXT_SRC_URI} )"
158
159# Get the percona tarball if XTRADB_VER and PERCONA_VER are both set
160XTRADB_SRC_URI="http://www.percona.com/${PN}/xtradb/${PERCONA_VER}/source/percona-xtradb-${XTRADB_VER}.tar.gz"
161mysql_version_is_at_least "5.1.26" \
162&& [[ -n ${XTRADB_VER} && -n ${PERCONA_VER} ]] \
163&& SRC_URI="${SRC_URI} xtradb? ( ${XTRADB_SRC_URI} )"
164
48DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" 165DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
49HOMEPAGE="http://www.mysql.com/" 166HOMEPAGE="http://www.mysql.com/"
50NEWP="${P/_/-}"
51SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${NEWP}.tar.gz
52 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
53LICENSE="GPL-2" 167LICENSE="GPL-2"
168SLOT="0"
54IUSE="big-tables berkdb debug embedded minimal perl selinux srvdir ssl static" 169IUSE="big-tables debug embedded minimal ${IUSE_DEFAULT_ON}perl selinux ssl static"
55RESTRICT="primaryuri confcache"
56 170
171mysql_version_is_at_least "4.1" \
172&& IUSE="${IUSE} latin1"
173
57mysql_version_is_at_least "4.01.03.00" \ 174mysql_version_is_at_least "4.1.3" \
58&& IUSE="${IUSE} cluster extraengine" 175&& IUSE="${IUSE} cluster extraengine"
59 176
60mysql_version_is_at_least "5.00.00.00" \ 177mysql_version_is_at_least "5.0" \
61|| IUSE="${IUSE} raid" 178|| IUSE="${IUSE} raid"
62 179
63mysql_version_is_at_least "5.00.18.00" \ 180mysql_version_is_at_least "5.0.18" \
64&& IUSE="${IUSE} max-idx-128" 181&& IUSE="${IUSE} max-idx-128"
65 182
66mysql_version_is_at_least "5.01.00.00" \ 183mysql_version_is_at_least "5.1" \
184|| IUSE="${IUSE} berkdb"
185
186mysql_version_is_at_least "5.1.12" \
187&& IUSE="${IUSE} pbxt"
188
189mysql_version_is_at_least "5.1.26" \
67&& IUSE="${IUSE} innodb" 190&& IUSE="${IUSE} xtradb"
68 191
69EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \ 192[ "${MYSQL_COMMUNITY_FEATURES}" == "1" ] \
70 pkg_postinst pkg_config pkg_postrm 193&& IUSE="${IUSE} ${IUSE_DEFAULT_ON}community profiling"
71 194
195#
196# HELPER FUNCTIONS:
197#
198
199# @FUNCTION: mysql_disable_test
200# @DESCRIPTION:
201# Helper function to disable specific tests.
202mysql_disable_test() {
203 local testname="${1}" ; shift
204 local reason="${@}"
205 local mysql_disable_file="${S}/mysql-test/t/disabled.def"
206 echo ${testname} : ${reason} >> "${mysql_disable_file}"
207 ewarn "test '${testname}' disabled: '${reason}'"
208}
209
210# @FUNCTION: mysql_init_vars
211# @DESCRIPTION:
72# void mysql_init_vars() 212# void mysql_init_vars()
73#
74# initialize global variables 213# Initialize global variables
75# 2005-11-19 <vivo at gentoo.org> 214# 2005-11-19 <vivo@gentoo.org>
76mysql_init_vars() { 215mysql_init_vars() {
77
78 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR:-"/usr/share/mysql"} 216 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"}
79 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"} 217 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"}
80 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql$"} 218 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"}
81 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"} 219 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"}
82 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql"} 220 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql"}
83 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql"} 221 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql"}
84 222
85 if [ -z "${DATADIR}" ]; then 223 if [[ -z "${MY_DATADIR}" ]] ; then
86 DATADIR="" 224 MY_DATADIR=""
87 if [ -f "${MY_SYSCONFDIR}/my.cnf" ] ; then 225 if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then
88 DATADIR=`"my_print_defaults" mysqld 2>/dev/null \ 226 MY_DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
89 | sed -ne '/datadir/s|^--datadir=||p' \ 227 | sed -ne '/datadir/s|^--datadir=||p' \
90 | tail -n1` 228 | tail -n1`
91 if [ -z "${DATADIR}" ]; then 229 if [[ -z "${MY_DATADIR}" ]] ; then
92 if useq "srvdir" ; then
93 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
94 else
95 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \ 230 MY_DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \
96 | sed -e 's/.*=\s*//'` 231 | sed -e 's/.*=\s*//' \
97 fi 232 | tail -n1`
98 fi 233 fi
99 fi 234 fi
100 if [ -z "${DATADIR}" ]; then 235 if [[ -z "${MY_DATADIR}" ]] ; then
101 if useq "srvdir" ; then
102 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
103 else
104 DATADIR="${MY_LOCALSTATEDIR}" 236 MY_DATADIR="${MY_LOCALSTATEDIR}"
105 fi
106 einfo "Using default DATADIR" 237 einfo "Using default MY_DATADIR"
107 fi 238 fi
108 einfo "MySQL DATADIR is ${DATADIR}" 239 elog "MySQL MY_DATADIR is ${MY_DATADIR}"
109 240
110 if [ -z "${PREVIOUS_DATADIR}" ] ; then 241 if [[ -z "${PREVIOUS_DATADIR}" ]] ; then
111 if [ -a "${DATADIR}" ] ; then 242 if [[ -e "${MY_DATADIR}" ]] ; then
112 ewarn "Previous datadir found, it's YOUR job to change" 243 # If you get this and you're wondering about it, see bug #207636
113 ewarn "ownership and have care of it" 244 elog "MySQL datadir found in ${MY_DATADIR}"
245 elog "A new one will not be created."
114 PREVIOUS_DATADIR="yes" 246 PREVIOUS_DATADIR="yes"
115 export PREVIOUS_DATADIR
116 else 247 else
117 PREVIOUS_DATADIR="no" 248 PREVIOUS_DATADIR="no"
118 export PREVIOUS_DATADIR
119 fi 249 fi
250 export PREVIOUS_DATADIR
251 fi
252 else
253 if [[ ${EBUILD_PHASE} == "config" ]]; then
254 local new_MY_DATADIR
255 new_MY_DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
256 | sed -ne '/datadir/s|^--datadir=||p' \
257 | tail -n1`
258
259 if [[ ( -n "${new_MY_DATADIR}" ) && ( "${new_MY_DATADIR}" != "${MY_DATADIR}" ) ]]; then
260 ewarn "MySQL MY_DATADIR has changed"
261 ewarn "from ${MY_DATADIR}"
262 ewarn "to ${new_MY_DATADIR}"
263 MY_DATADIR="${new_MY_DATADIR}"
120 fi 264 fi
121 fi 265 fi
266 fi
267
268 MY_SOURCEDIR=${SERVER_URI##*/}
269 MY_SOURCEDIR=${MY_SOURCEDIR%.tar*}
122 270
123 export MY_SHAREDSTATEDIR MY_SYSCONFDIR 271 export MY_SHAREDSTATEDIR MY_SYSCONFDIR
124 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR 272 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
125 export MY_INCLUDEDIR 273 export MY_INCLUDEDIR MY_DATADIR MY_SOURCEDIR
126 export DATADIR
127} 274}
128 275
276configure_minimal() {
277 # These are things we exclude from a minimal build, please
278 # note that the server actually does get built and installed,
279 # but we then delete it before packaging.
280 local minimal_exclude_list="server embedded-server extra-tools innodb bench berkeley-db row-based-replication readline"
281
282 for i in ${minimal_exclude_list} ; do
283 myconf="${myconf} --without-${i}"
284 done
285 myconf="${myconf} --with-extra-charsets=none"
286 myconf="${myconf} --enable-local-infile"
287
288 if use static ; then
289 myconf="${myconf} --with-client-ldflags=-all-static"
290 myconf="${myconf} --disable-shared --with-pic"
291 else
292 myconf="${myconf} --enable-shared --enable-static"
293 fi
294
295 if mysql_version_is_at_least "4.1" && ! use latin1 ; then
296 myconf="${myconf} --with-charset=utf8"
297 myconf="${myconf} --with-collation=utf8_general_ci"
298 else
299 myconf="${myconf} --with-charset=latin1"
300 myconf="${myconf} --with-collation=latin1_swedish_ci"
301 fi
302}
303
304configure_common() {
305 myconf="${myconf} $(use_with big-tables)"
306 myconf="${myconf} --enable-local-infile"
307 myconf="${myconf} --with-extra-charsets=all"
308 myconf="${myconf} --with-mysqld-user=mysql"
309 myconf="${myconf} --with-server"
310 myconf="${myconf} --with-unix-socket-path=/var/run/mysqld/mysqld.sock"
311 myconf="${myconf} --without-libwrap"
312
313 if use static ; then
314 myconf="${myconf} --with-mysqld-ldflags=-all-static"
315 myconf="${myconf} --with-client-ldflags=-all-static"
316 myconf="${myconf} --disable-shared --with-pic"
317 else
318 myconf="${myconf} --enable-shared --enable-static"
319 fi
320
321 if use debug ; then
322 myconf="${myconf} --with-debug=full"
323 else
324 myconf="${myconf} --without-debug"
325 mysql_version_is_at_least "4.1.3" \
326 && use cluster \
327 && myconf="${myconf} --without-ndb-debug"
328 fi
329
330 if [ -n "${MYSQL_DEFAULT_CHARSET}" -a -n "${MYSQL_DEFAULT_COLLATION}" ]; then
331 ewarn "You are using a custom charset of ${MYSQL_DEFAULT_CHARSET}"
332 ewarn "and a collation of ${MYSQL_DEFAULT_COLLATION}."
333 ewarn "You MUST file bugs without these variables set."
334 myconf="${myconf} --with-charset=${MYSQL_DEFAULT_CHARSET}"
335 myconf="${myconf} --with-collation=${MYSQL_DEFAULT_COLLATION}"
336 elif mysql_version_is_at_least "4.1" && ! use latin1 ; then
337 myconf="${myconf} --with-charset=utf8"
338 myconf="${myconf} --with-collation=utf8_general_ci"
339 else
340 myconf="${myconf} --with-charset=latin1"
341 myconf="${myconf} --with-collation=latin1_swedish_ci"
342 fi
343
344 if use embedded ; then
345 myconf="${myconf} --with-embedded-privilege-control"
346 myconf="${myconf} --with-embedded-server"
347 else
348 myconf="${myconf} --without-embedded-privilege-control"
349 myconf="${myconf} --without-embedded-server"
350 fi
351
352}
353
354configure_40_41_50() {
355 myconf="${myconf} $(use_with perl bench)"
356 myconf="${myconf} --enable-assembler"
357 myconf="${myconf} --with-extra-tools"
358 myconf="${myconf} --with-innodb"
359 myconf="${myconf} --without-readline"
360 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)"
361
362 # --with-vio is not needed anymore, it's on by default and
363 # has been removed from configure
364 if use ssl ; then
365 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio"
366 fi
367
368 if mysql_version_is_at_least "5.1.11" ; then
369 myconf="${myconf} $(use_with ssl)"
370 else
371 myconf="${myconf} $(use_with ssl openssl)"
372 fi
373
374 if mysql_version_is_at_least "5.0.60" ; then
375 if use berkdb ; then
376 elog "Berkeley DB support was disabled due to build failures"
377 elog "on multiple arches, go to a version earlier than 5.0.60"
378 elog "if you want it again. Gentoo bug #224067."
379 fi
380 myconf="${myconf} --without-berkeley-db"
381 elif use berkdb ; then
382 # The following fix is due to a bug with bdb on SPARC's. See:
383 # http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
384 # It comes down to non-64-bit safety problems.
385 if use alpha || use amd64 || use hppa || use mips || use sparc ; then
386 elog "Berkeley DB support was disabled due to compatibility issues on this arch"
387 myconf="${myconf} --without-berkeley-db"
388 else
389 myconf="${myconf} --with-berkeley-db=./bdb"
390 fi
391 else
392 myconf="${myconf} --without-berkeley-db"
393 fi
394
395 if mysql_version_is_at_least "4.1.3" ; then
396 myconf="${myconf} --with-geometry"
397 myconf="${myconf} $(use_with cluster ndbcluster)"
398 fi
399
400 if mysql_version_is_at_least "4.1.3" && use extraengine ; then
401 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
402 myconf="${myconf} --with-archive-storage-engine"
403
404 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
405 myconf="${myconf} --with-csv-storage-engine"
406
407 # http://dev.mysql.com/doc/mysql/en/blackhole-storage-engine.html
408 myconf="${myconf} --with-blackhole-storage-engine"
409
410 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
411 # http://dev.mysql.com/doc/mysql/en/federated-description.html
412 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
413 if mysql_version_is_at_least "5.0.3" ; then
414 elog "Before using the Federated storage engine, please be sure to read"
415 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
416 myconf="${myconf} --with-federated-storage-engine"
417 fi
418 fi
419
420 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
421 myconf="${myconf} `use_enable community community-features`"
422 if use community; then
423 myconf="${myconf} `use_enable profiling`"
424 else
425 myconf="${myconf} --disable-profiling"
426 fi
427 fi
428
429 mysql_version_is_at_least "5.0.18" \
430 && use max-idx-128 \
431 && myconf="${myconf} --with-max-indexes=128"
432}
433
434configure_51() {
435 # TODO: !!!! readd --without-readline
436 # the failure depend upon config/ac-macros/readline.m4 checking into
437 # readline.h instead of history.h
438 myconf="${myconf} $(use_with ssl)"
439 myconf="${myconf} --enable-assembler"
440 myconf="${myconf} --with-geometry"
441 myconf="${myconf} --with-readline"
442 myconf="${myconf} --with-row-based-replication"
443 myconf="${myconf} --with-zlib=/usr/$(get_libdir)"
444 myconf="${myconf} --without-pstack"
445 use max-idx-128 && myconf="${myconf} --with-max-indexes=128"
446
447 # 5.1 introduces a new way to manage storage engines (plugins)
448 # like configuration=none
449 local plugins="csv,myisam,myisammrg,heap"
450 if use extraengine ; then
451 # like configuration=max-no-ndb, archive and example removed in 5.1.11
452 plugins="${plugins},archive,blackhole,example,federated,partition"
453
454 elog "Before using the Federated storage engine, please be sure to read"
455 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
456 fi
457
458 # Upstream specifically requests that InnoDB always be built.
459 plugins="${plugins},innobase"
460
461 # like configuration=max-no-ndb
462 if use cluster ; then
463 plugins="${plugins},ndbcluster"
464 myconf="${myconf} --with-ndb-binlog"
465 fi
466
467 if mysql_version_is_at_least "5.2" ; then
468 plugins="${plugins},falcon"
469 fi
470
471 myconf="${myconf} --with-plugins=${plugins}"
472}
473
474pbxt_src_configure() {
475 mysql_init_vars
476
477 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
478
479 einfo "Reconfiguring dir '${PWD}'"
480 AT_GNUCONF_UPDATE="yes" eautoreconf
481
482 local myconf=""
483 myconf="${myconf} --with-mysql=${S} --libdir=${D}/${MY_LIBDIR}"
484 use debug && myconf="${myconf} --with-debug=full"
485 # TODO: is it safe/needed to use econf here ?
486 ./configure ${myconf} || die "Problem configuring PBXT storage engine"
487}
488
489pbxt_src_compile() {
490 # Be backwards compatible for now
491 if [[ $EAPI != 2 ]]; then
492 pbxt_src_configure
493 fi
494 # TODO: is it safe/needed to use emake here ?
495 make || die "Problem making PBXT storage engine (${myconf})"
496
497 popd
498 # TODO: modify test suite for PBXT
499}
500
501pbxt_src_install() {
502 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
503 make install || die "Failed to install PBXT"
504 popd
505}
506
507#
508# EBUILD FUNCTIONS
509#
510# @FUNCTION: mysql_pkg_setup
511# @DESCRIPTION:
512# Perform some basic tests and tasks during pkg_setup phase:
513# die if FEATURES="test", USE="-minimal" and not using FEATURES="userpriv"
514# check for conflicting use flags
515# create new user and group for mysql
516# warn about deprecated features
129mysql_pkg_setup() { 517mysql_pkg_setup() {
518 if hasq test ${FEATURES} ; then
519 if ! use minimal ; then
520 if [[ $UID -eq 0 ]]; then
521 eerror "Testing with FEATURES=-userpriv is no longer supported by upstream. Tests MUST be run as non-root."
522 fi
523 fi
524 fi
130 525
526 # Check for USE flag problems in pkg_setup
527 if use static && use ssl ; then
528 eerror "MySQL does not support being built statically with SSL support enabled!"
529 die "MySQL does not support being built statically with SSL support enabled!"
530 fi
531
532 if ! mysql_version_is_at_least "5.0" \
533 && use raid \
534 && use static ; then
535 eerror "USE flags 'raid' and 'static' conflict, you cannot build MySQL statically"
536 eerror "with RAID support enabled."
537 die "USE flags 'raid' and 'static' conflict!"
538 fi
539
540 if mysql_version_is_at_least "4.1.3" \
541 && ( use cluster || use extraengine ) \
542 && use minimal ; then
543 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
544 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
545 fi
546
547 # This should come after all of the die statements
131 enewgroup mysql 60 || die "problem adding group mysql" 548 enewgroup mysql 60 || die "problem adding 'mysql' group"
132 enewuser mysql 60 -1 /dev/null mysql \ 549 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
133 || die "problem adding user mysql"
134}
135 550
551 mysql_check_version_range "4.0 to 5.0.99.99" \
552 && use berkdb \
553 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
554}
555
556# @FUNCTION: mysql_src_unpack
557# @DESCRIPTION:
558# Unpack the source code and call mysql_src_prepare for EAPI < 2.
136mysql_src_unpack() { 559mysql_src_unpack() {
137 560 # Initialize the proper variables first
138 mysql_init_vars 561 mysql_init_vars
139 562
140 if useq "static" && useq "ssl" ; then
141 local msg="MySQL does not support building statically with SSL support"
142 eerror "${msg}"
143 die "${msg}"
144 fi
145
146 if mysql_version_is_at_least "4.01.03.00" \
147 && useq "cluster" \
148 || useq "extraengine" \
149 && useq "minimal" ; then
150 die "USEs cluster, extraengine conflicts with \"minimal\""
151 fi
152
153 unpack ${A} || die 563 unpack ${A}
564 # Grab the patches
565 [[ "${MY_EXTRAS_VER}" == "live" ]] && S="${WORKDIR}/mysql-extras" git_src_unpack
154 566
155 mv -f "${WORKDIR}/${NEWP}" "${S}" 567 mv -f "${WORKDIR}/${MY_SOURCEDIR}" "${S}"
568
569 # Be backwards compatible for now
570 case ${EAPI:-0} in
571 2) : ;;
572 0 | 1) mysql_src_prepare ;;
573 esac
574}
575
576# @FUNCTION: mysql_src_prepare
577# @DESCRIPTION:
578# Apply patches to the source code and remove unneeded bundled libs.
579mysql_src_prepare() {
156 cd "${S}" 580 cd "${S}"
157 581
582 # Apply the patches for this MySQL version
158 EPATCH_SUFFIX="patch" 583 EPATCH_SUFFIX="patch"
159 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory" 584 mkdir -p "${EPATCH_SOURCE}" || die "Unable to create epatch directory"
585 # Clean out old items
586 rm -f "${EPATCH_SOURCE}"/*
587 # Now link in right patches
160 mysql_mv_patches 588 mysql_mv_patches
161 epatch || die "failed to apply all patches" 589 # And apply
590 epatch
162 591
163 # additional check, remove bundled zlib 592 # Additional checks, remove bundled zlib
164 rm -f "${S}/zlib/"*.[ch] 593 rm -f "${S}/zlib/"*.[ch]
165 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in" 594 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
166 rm -f scripts/mysqlbug 595 rm -f "scripts/mysqlbug"
167 596
168 # Make charsets install in the right place 597 # Make charsets install in the right place
169 find . -name 'Makefile.am' \ 598 find . -name 'Makefile.am' \
170 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \; 599 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
171 600
172 # Manage mysqlmanager
173 mysql_version_is_at_least "5.00.15.00" \ 601 if mysql_version_is_at_least "4.1" ; then
174 && sed -i -e "s!@GENTOO_EXT@!!g" \
175 -e "s!@GENTOO_SOCK_PATH@!var/run/mysqld!g" \
176 "${S}/server-tools/instance-manager/Makefile.am"
177
178 # remove what need to be recreated, so we are sure it's actually done 602 # Remove what needs to be recreated, so we're sure it's actually done
179 find . -name Makefile \ 603 find . -name Makefile \
180 -o -name Makefile.in \ 604 -o -name Makefile.in \
181 -o -name configure \ 605 -o -name configure \
182 -exec rm -f {} \; 606 -exec rm -f {} \;
183 rm ltmain.sh 607 rm -f "ltmain.sh"
608 rm -f "scripts/mysqlbug"
609 fi
184 610
185 local rebuilddirlist d buildstep bdbdir 611 local rebuilddirlist d
186 612
187 if mysql_version_is_at_least "5.01.00.00" ; then 613 if mysql_version_is_at_least "5.1.12" ; then
188 rebuilddirlist=". storage/innobase" 614 rebuilddirlist="."
189 bdbdir='storage/bdb/dist' 615 # TODO: check this with a cmake expert
616 cmake \
617 -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \
618 -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \
619 "storage/innobase"
190 else 620 else
191 rebuilddirlist=". innobase" 621 rebuilddirlist=". innobase"
192 bdbdir='bdb/dist'
193 fi 622 fi
194 623
195 for d in ${rebuilddirlist}; do 624 for d in ${rebuilddirlist} ; do
196 einfo "reconfiguring dir \"${d}\"" 625 einfo "Reconfiguring dir '${d}'"
197 pushd "${d}" &>/dev/null 626 pushd "${d}" &>/dev/null
198 AT_GNUCONF_UPDATE="yes" eautoreconf 627 AT_GNUCONF_UPDATE="yes" eautoreconf
199 popd &>/dev/null 628 popd &>/dev/null
200 done 629 done
201 630
202 #TODO berkdb in 5.1 need to be worked on 631 if mysql_check_version_range "4.1 to 5.0.99.99" \
203 if useq "berkdb" && ! mysql_check_version_range "5.01.00.00 to 5.01.08.99" 632 && use berkdb ; then
204 then
205 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh" 633 [[ -w "bdb/dist/ltmain.sh" ]] && cp -f "ltmain.sh" "bdb/dist/ltmain.sh"
206 pushd "${bdbdir}" \ 634 cp -f "/usr/share/aclocal/libtool.m4" "bdb/dist/aclocal/libtool.ac" \
635 || die "Could not copy libtool.m4 to bdb/dist/"
636 #These files exist only with libtool-2*, and need to be included.
637 if [ -f '/usr/share/aclocal/ltsugar.m4' ]; then
638 cat "/usr/share/aclocal/ltsugar.m4" >> "bdb/dist/aclocal/libtool.ac"
639 cat "/usr/share/aclocal/ltversion.m4" >> "bdb/dist/aclocal/libtool.ac"
640 cat "/usr/share/aclocal/lt~obsolete.m4" >> "bdb/dist/aclocal/libtool.ac"
641 cat "/usr/share/aclocal/ltoptions.m4" >> "bdb/dist/aclocal/libtool.ac"
642 fi
643 pushd "bdb/dist" &>/dev/null
207 && sh s_all \ 644 sh s_all \
208 || die "failed bdb reconfigure" \ 645 || die "Failed bdb reconfigure"
209 &>/dev/null
210 popd &>/dev/null 646 popd &>/dev/null
211 fi 647 fi
212
213} 648}
214 649
650# @FUNCTION: mysql_src_configure
651# @DESCRIPTION:
652# Configure mysql to build the code for Gentoo respecting the use flags.
215mysql_src_compile() { 653mysql_src_configure() {
216 654 # Make sure the vars are correctly initialized
217 mysql_init_vars 655 mysql_init_vars
656
657 # $myconf is modified by the configure_* functions
218 local myconf 658 local myconf=""
219 659
220 if useq "static" ; then 660 if use minimal ; then
221 myconf="${myconf} --with-mysqld-ldflags=-all-static" 661 configure_minimal
222 myconf="${myconf} --with-client-ldflags=-all-static"
223 myconf="${myconf} --disable-shared"
224 else 662 else
225 myconf="${myconf} --enable-shared --enable-static" 663 configure_common
226 fi
227
228 #myconf="${myconf} `use_with tcpd libwrap`"
229 myconf="${myconf} --without-libwrap"
230
231 if useq "ssl" ; then
232 # --with-vio is not needed anymore, it's on by default and
233 # has been removed from configure
234 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio"
235 if mysql_version_is_at_least "5.00.06.00" ; then 664 if mysql_version_is_at_least "5.1.10" ; then
236 # yassl-0.96 is young break with gcc-4.0 || amd64 665 configure_51
237 #myconf="${myconf} --with-yassl"
238 myconf="${myconf} --with-openssl"
239 else 666 else
240 myconf="${myconf} --with-openssl" 667 configure_40_41_50
241 fi
242 else
243 myconf="${myconf} --without-openssl"
244 fi
245
246 if useq "debug"; then
247 myconf="${myconf} --with-debug=full"
248 else
249 myconf="${myconf} --without-debug"
250 mysql_version_is_at_least "4.01.03.00" \
251 && useq "cluster" \
252 && myconf="${myconf} --without-ndb-debug"
253 fi
254
255 # these are things we exclude from a minimal build
256 # note that the server actually does get built and installed
257 # but we then delete it before packaging.
258 local minimal_exclude_list="server embedded-server extra-tools innodb bench"
259
260 if ! useq "minimal" ; then
261 myconf="${myconf} --with-server"
262 myconf="${myconf} --with-extra-tools"
263
264 if useq "static" ; then
265 myconf="${myconf} --without-raid"
266 ewarn "disabling raid support, has problem with static"
267 else
268 if mysql_version_is_at_least "5.00.00.00" ; then
269 myconf="${myconf} --without-raid"
270 else
271 myconf="${myconf} `use_with raid`"
272 fi 668 fi
273 fi 669 fi
274 670
275 if ! mysql_version_is_at_least "5.00.00.00" ; then
276 if mysql_version_is_at_least "4.01.00.00" ; then
277 myconf="${myconf} --with-charset=utf8"
278 myconf="${myconf} --with-collation=utf8_general_ci"
279 else
280 myconf="${myconf} --with-charset=latin1"
281 myconf="${myconf} --with-collation=latin1_swedish_ci"
282 fi
283 fi
284
285 # optional again from 2005-12-05
286 if mysql_version_is_at_least "5.01.00.00" ; then
287 myconf="${myconf} $(use_with innodb)"
288 else
289 myconf="${myconf} --with-innodb"
290 fi
291
292 # lots of chars
293 myconf="${myconf} --with-extra-charsets=all"
294
295 #The following fix is due to a bug with bdb on sparc's. See:
296 #http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
297 # it comes down to non-64-bit safety problems
298 if useq "sparc" || useq "alpha" || useq "hppa" || useq "mips" \
299 || useq "amd64" || mysql_check_version_range "5.01.00.00 to 5.01.06.99"
300 then
301 ewarn "bdb berkeley-db disabled due to arch or version"
302 myconf="${myconf} --without-berkeley-db"
303 else
304 #TODO berkdb in 5.1 need to be worked on
305 useq "berkdb" && \
306 ! mysql_check_version_range "5.01.00.00 to 5.01.08.99" \
307 && myconf="${myconf} --with-berkeley-db=./bdb" \
308 || myconf="${myconf} --without-berkeley-db"
309 fi
310
311 if mysql_version_is_at_least "4.01.03.00" ; then
312 #myconf="${myconf} $(use_with geometry)"
313 myconf="${myconf} --with-geometry"
314 myconf="${myconf} $(use_with cluster ndbcluster)"
315 fi
316
317 mysql_version_is_at_least "4.01.11.00" \
318 && myconf="${myconf} `use_with big-tables`"
319
320 mysql_version_is_at_least "5.01.06.00" \
321 && myconf="${myconf} --with-ndb-binlog"
322
323 if useq "embedded" ; then
324 #REMIND, need the privilege control enabled ?
325 myconf="${myconf} --without-embedded-privilege-control"
326 myconf="${myconf} --with-embedded-server"
327 else
328 myconf="${myconf} --without-embedded-privilege-control"
329 myconf="${myconf} --without-embedded-server"
330 fi
331
332 # benchmarking stuff needs perl
333 if useq "perl" ; then
334 myconf="${myconf} --with-bench"
335 else
336 myconf="${myconf} --without-bench"
337 fi
338 else
339 for i in ${minimal_exclude_list}; do
340 myconf="${myconf} --without-${i}"
341 done
342 myconf="${myconf} --without-berkeley-db"
343 myconf="${myconf} --with-extra-charsets=none"
344 fi
345
346 if mysql_version_is_at_least "4.01.03.00" && useq "extraengine"; then
347 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
348 myconf="${myconf} --with-archive-storage-engine"
349 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
350
351 mysql_version_is_at_least "4.01.04.00" \
352 && myconf="${myconf} --with-csv-storage-engine"
353
354 mysql_version_is_at_least "4.01.11.00" \
355 && myconf="${myconf} --with-blackhole-storage-engine"
356
357 # http://dev.mysql.com/doc/mysql/en/federated-description.html
358 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
359 if mysql_version_is_at_least "5.00.03.00" ; then
360 einfo "before to use federated engine be sure to read"
361 einfo "http://dev.mysql.com/doc/refman/5.0/en/federated-limitations.html"
362 myconf="${myconf} --with-federated-storage-engine"
363
364 # http://dev.mysql.com/doc/refman/5.1/en/partitioning-overview.html
365 if mysql_version_is_at_least "5.01.00.00" ; then
366 myconf="${myconf} --with-partition"
367 fi
368 fi
369
370 fi
371
372 mysql_version_is_at_least "5.00.18.00" \
373 && useq "max-idx-128" \
374 && myconf="${myconf} --with-max-indexes=128"
375
376 if mysql_version_is_at_least "5.01.05.00" ; then
377 myconf="${myconf} --with-row-based-replication"
378 fi
379
380 #TODO rechek again later, had problem with assembler enabled
381 # and some combination of use-flags with 5.1
382 if mysql_check_version_range "5.01.00.00 to 5.01.08.99" ; then
383 myconf="${myconf} --disable-assembler"
384 else
385 myconf="${myconf} --enable-assembler"
386 fi
387
388 #Bug #114895,Bug #110149 671 # Bug #114895, bug #110149
389 filter-flags "-O" "-O[01]" 672 filter-flags "-O" "-O[01]"
673
390 #glibc-2.3.2_pre fix; bug #16496 674 # glib-2.3.2_pre fix, bug #16496
391 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 675 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
392 676
393 #the compiler flags are as per their "official" spec ;) 677 # As discovered by bug #246652, doing a double-level of SSP causes NDB to
394 #CFLAGS="${CFLAGS/-O?/} -O3" \ 678 # fail badly during cluster startup.
679 if [[ $(gcc-major-version) -lt 4 ]]; then
680 filter-flags "-fstack-protector-all"
681 fi
682
683 CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-strict-aliasing"
395 export CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" 684 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
396 mysql_version_is_at_least "5.00.00.00" \ 685 mysql_version_is_at_least "5.0" \
397 && export CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 686 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
687 export CXXFLAGS
688
689 # bug #283926, with GCC4.4, this is required to get correct behavior.
690 append-flags -fno-strict-aliasing
398 691
399 econf \ 692 econf \
400 --libexecdir="/usr/sbin" \ 693 --libexecdir="/usr/sbin" \
401 --sysconfdir="${MY_SYSCONFDIR}" \ 694 --sysconfdir="${MY_SYSCONFDIR}" \
402 --localstatedir="${MY_LOCALSTATEDIR}" \ 695 --localstatedir="${MY_LOCALSTATEDIR}" \
403 --sharedstatedir="${MY_SHAREDSTATEDIR}" \ 696 --sharedstatedir="${MY_SHAREDSTATEDIR}" \
404 --libdir="${MY_LIBDIR}" \ 697 --libdir="${MY_LIBDIR}" \
405 --includedir="${MY_INCLUDEDIR}" \ 698 --includedir="${MY_INCLUDEDIR}" \
406 --with-low-memory \ 699 --with-low-memory \
407 --enable-local-infile \
408 --with-mysqld-user=mysql \
409 --with-client-ldflags=-lstdc++ \ 700 --with-client-ldflags=-lstdc++ \
410 --enable-thread-safe-client \ 701 --enable-thread-safe-client \
411 --with-comment="Gentoo Linux ${PF}" \ 702 --with-comment="Gentoo Linux ${PF}" \
412 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
413 --without-readline \
414 --without-docs \ 703 --without-docs \
415 ${myconf} || die "bad ./configure" 704 ${myconf} || die "econf failed"
416 705
417 # TODO Move this before autoreconf !!! 706 # TODO: Move this before autoreconf !!!
418 find . -type f -name Makefile -print0 \ 707 find . -type f -name Makefile -print0 \
419 | xargs -0 -n100 sed -i \ 708 | xargs -0 -n100 sed -i \
420 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|' 709 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
421 710
422 emake || die "compile problem" 711 if [[ $EAPI == 2 ]]; then
712 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_configure
713 fi
423} 714}
424 715
716# @FUNCTION: mysql_src_compile
717# @DESCRIPTION:
718# Compile the mysql code.
719mysql_src_compile() {
720 # Be backwards compatible for now
721 case ${EAPI:-0} in
722 2) : ;;
723 0 | 1) mysql_src_configure ;;
724 esac
725
726 emake || die "emake failed"
727
728 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_compile
729}
730
731# @FUNCTION: mysql_src_install
732# @DESCRIPTION:
733# Install mysql.
425mysql_src_install() { 734mysql_src_install() {
426 735 # Make sure the vars are correctly initialized
427 mysql_init_vars 736 mysql_init_vars
737
428 make install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die 738 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed"
429 739
430 insinto "${MY_INCLUDEDIR}" 740 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_install
431 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h
432 741
433 # convenience links 742 # Convenience links
743 einfo "Making Convenience links for mysqlcheck multi-call binary"
434 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze" 744 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
435 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair" 745 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
436 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize" 746 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize"
437 747
438 # various junk (my-*.cnf moved elsewhere) 748 # Various junk (my-*.cnf moved elsewhere)
749 einfo "Removing duplicate /usr/share/mysql files"
439 rm -rf "${D}/usr/share/info" 750 rm -Rf "${D}/usr/share/info"
440 for removeme in "mysql-log-rotate" mysql.server* \ 751 for removeme in "mysql-log-rotate" mysql.server* \
441 binary-configure* my-*.cnf mi_test_all* 752 binary-configure* my-*.cnf mi_test_all*
442 do 753 do
443 rm -f ${D}/usr/share/mysql/${removeme} 754 rm -f "${D}"/usr/share/mysql/${removeme}
444 done 755 done
445 756
446 # clean up stuff for a minimal build 757 # Clean up stuff for a minimal build
447 # this is anything server-specific
448 if useq "minimal" ; then 758 if use minimal ; then
759 einfo "Remove all extra content for minimal build"
449 rm -rf ${D}${MY_SHAREDSTATEDIR}/{mysql-test,sql-bench} 760 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
450 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} 761 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}
451 rm -f "${D}/usr/sbin/mysqld" 762 rm -f "${D}/usr/sbin/mysqld"
452 rm -f ${D}${MY_LIBDIR}/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a 763 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
453 fi 764 fi
454 765
455 # config stuff 766 # Configuration stuff
767 if mysql_version_is_at_least "4.1" ; then
768 mysql_mycnf_version="4.1"
769 else
770 mysql_mycnf_version="4.0"
771 fi
772 einfo "Building default my.cnf"
456 insinto "${MY_SYSCONFDIR}" 773 insinto "${MY_SYSCONFDIR}"
457 doins scripts/mysqlaccess.conf 774 doins scripts/mysqlaccess.conf
458 sed -e "s!@MY_SUFFIX@!!g" \
459 -e "s!@DATADIR@!${DATADIR}!g" \ 775 sed -e "s!@DATADIR@!${MY_DATADIR}!g" \
460 "${FILESDIR}/my.cnf-4.1-r1" \ 776 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
461 > "${TMPDIR}/my.cnf.ok" 777 > "${TMPDIR}/my.cnf.ok"
778 if mysql_version_is_at_least "4.1" && use latin1 ; then
779 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok"
780 fi
462 newins "${TMPDIR}/my.cnf.ok" my.cnf 781 newins "${TMPDIR}/my.cnf.ok" my.cnf
463 782
464 insinto "/etc/conf.d"
465 newins "${FILESDIR}/mysql.conf.d-r1" "mysql"
466 mysql_version_is_at_least "5.00.11.00" \
467 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager"
468
469 # minimal builds don't have the server 783 # Minimal builds don't have the MySQL server
470 if ! useq "minimal" ; then 784 if ! use minimal ; then
471 exeinto /etc/init.d 785 einfo "Creating initial directories"
472 newexe "${FILESDIR}/mysql.rc6-r3" "mysql" 786 # Empty directories ...
473
474 mysql_version_is_at_least "5.00.11.00" \
475 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager"
476 insinto /etc/logrotate.d
477 newins "${FILESDIR}/logrotate.mysql" "mysql"
478
479 #empty dirs...
480 diropts "-m0750" 787 diropts "-m0750"
481 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 788 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
482 dodir "${DATADIR}" 789 dodir "${MY_DATADIR}"
483 keepdir "${DATADIR}" 790 keepdir "${MY_DATADIR}"
484 chown -R mysql:mysql "${D}/${DATADIR}" 791 chown -R mysql:mysql "${D}/${MY_DATADIR}"
485 fi 792 fi
486 793
487 diropts "-m0755" 794 diropts "-m0755"
488 for folder in "${MY_LOGDIR}" "/var/run/mysqld" ; do 795 for folder in "${MY_LOGDIR}" "/var/run/mysqld" ; do
489 dodir "${folder}" 796 dodir "${folder}"
490 keepdir "${folder}" 797 keepdir "${folder}"
491 chown -R mysql:mysql "${D}/${folder}" 798 chown -R mysql:mysql "${D}/${folder}"
492 done 799 done
493 fi 800 fi
494 801
495 # docs 802 # Docs
803 einfo "Installing docs"
496 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 804 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
805 doinfo "${S}"/Docs/mysql.info
806
497 # minimal builds don't have the server 807 # Minimal builds don't have the MySQL server
498 if ! useq "minimal" ; then 808 if ! use minimal ; then
809 einfo "Including support files and sample configurations"
810 docinto "support-files"
811 for script in \
812 "${S}"/support-files/my-*.cnf \
813 "${S}"/support-files/magic \
814 "${S}"/support-files/ndb-config-2-node.ini
815 do
816 dodoc "${script}"
817 done
818
819 docinto "scripts"
820 for script in "${S}"/scripts/mysql* ; do
821 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
822 done
823
824 fi
825
826 mysql_lib_symlinks "${D}"
827}
828
829# @FUNCTION: mysql_pkg_preinst
830# @DESCRIPTION:
831# Create the user and groups for mysql - die if that fails.
832mysql_pkg_preinst() {
833 enewgroup mysql 60 || die "problem adding 'mysql' group"
834 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
835}
836
837# @FUNCTION: mysql_pkg_postinst
838# @DESCRIPTION:
839# Run post-installation tasks:
840# create the dir for logfiles if non-existant
841# touch the logfiles and secure them
842# install scripts
843# issue required steps for optional features
844# issue deprecation warnings
845mysql_pkg_postinst() {
846 # Make sure the vars are correctly initialized
847 mysql_init_vars
848
849 # Check FEATURES="collision-protect" before removing this
850 [[ -d "${ROOT}/var/log/mysql" ]] || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
851
852 # Secure the logfiles
853 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
854 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
855 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
856
857 # Minimal builds don't have the MySQL server
858 if ! use minimal ; then
499 docinto "support-files" 859 docinto "support-files"
500 for script in \ 860 for script in \
501 support-files/my-*.cnf \ 861 support-files/my-*.cnf \
502 support-files/magic \ 862 support-files/magic \
503 support-files/ndb-config-2-node.ini 863 support-files/ndb-config-2-node.ini
507 867
508 docinto "scripts" 868 docinto "scripts"
509 for script in scripts/mysql* ; do 869 for script in scripts/mysql* ; do
510 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 870 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
511 done 871 done
512 fi
513 872
514 ROOT="${D}" mysql_lib_symlinks 873 einfo
515} 874 elog "You might want to run:"
875 elog "\"emerge --config =${CATEGORY}/${PF}\""
876 elog "if this is a new install."
877 einfo
878 fi
516 879
517mysql_pkg_preinst() { 880 if mysql_version_is_at_least "5.1.12" && use pbxt ; then
881 # TODO: explain it better
882 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';"
883 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;"
884 elog "if, after that, you cannot start the MySQL server,"
885 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then"
886 elog "use the MySQL upgrade script to restore the table"
887 elog "or execute the following SQL command:"
888 elog " CREATE TABLE IF NOT EXISTS plugin ("
889 elog " name char(64) binary DEFAULT '' NOT NULL,"
890 elog " dl char(128) DEFAULT '' NOT NULL,"
891 elog " PRIMARY KEY (name)"
892 elog " ) CHARACTER SET utf8 COLLATE utf8_bin;"
893 fi
518 894
519 enewgroup mysql 60 || die "problem adding group mysql" 895 mysql_check_version_range "4.0 to 5.0.99.99" \
520 enewuser mysql 60 -1 /dev/null mysql \ 896 && use berkdb \
521 || die "problem adding user mysql" 897 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
522} 898}
523 899
900# @FUNCTION: mysql_pkg_config
901# @DESCRIPTION:
902# Configure mysql environment.
524mysql_pkg_postinst() { 903mysql_pkg_config() {
904 local old_MY_DATADIR="${MY_DATADIR}"
525 905
906 # Make sure the vars are correctly initialized
526 mysql_init_vars 907 mysql_init_vars
527 908
528 # mind at FEATURES=collision-protect before to remove this
529 [ -d "${ROOT}/var/log/mysql" ] \
530 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
531
532 #secure the logfiles... does this bother anybody?
533 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
534 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
535 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
536
537 if ! useq "minimal" ; then
538 # your friendly public service announcement...
539 einfo
540 einfo "You might want to run:"
541 einfo "\"emerge --config =${CATEGORY}/${PF}\""
542 einfo "if this is a new install."
543 einfo
544 mysql_version_is_at_least "5.01.00.00" \
545 || einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream."
546 fi
547}
548
549mysql_pkg_config() {
550 mysql_init_vars
551 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR" 909 [[ -z "${MY_DATADIR}" ]] && die "Sorry, unable to find MY_DATADIR"
552 910
553 if built_with_use dev-db/mysql minimal; then 911 if built_with_use ${CATEGORY}/${PN} minimal ; then
554 die "Minimal builds do NOT include the MySQL server" 912 die "Minimal builds do NOT include the MySQL server"
913 fi
914
915 if [[ ( -n "${MY_DATADIR}" ) && ( "${MY_DATADIR}" != "${old_MY_DATADIR}" ) ]]; then
916 local MY_DATADIR_s="$(strip_duplicate_slashes ${ROOT}/${MY_DATADIR})"
917 local old_MY_DATADIR_s="$(strip_duplicate_slashes ${ROOT}/${old_MY_DATADIR})"
918
919 if [[ -d "${old_MY_DATADIR_s}" ]]; then
920 if [[ -d "${MY_DATADIR_s}" ]]; then
921 ewarn "Both ${old_MY_DATADIR_s} and ${MY_DATADIR_s} exist"
922 ewarn "Attempting to use ${MY_DATADIR_s} and preserving ${old_MY_DATADIR_s}"
923 else
924 elog "Moving MY_DATADIR from ${old_MY_DATADIR_s} to ${MY_DATADIR_s}"
925 mv --strip-trailing-slashes -T "${old_MY_DATADIR_s}" "${MY_DATADIR_s}" \
926 || die "Moving MY_DATADIR failed"
927 fi
928 else
929 ewarn "Previous MY_DATADIR (${old_MY_DATADIR_s}) does not exist"
930 if [[ -d "${MY_DATADIR_s}" ]]; then
931 ewarn "Attempting to use ${MY_DATADIR_s}"
932 else
933 eerror "New MY_DATADIR (${MY_DATADIR_s}) does not exist"
934 die "Configuration Failed! Please reinstall ${CATEGORY}/${PN}"
935 fi
936 fi
555 fi 937 fi
556 938
557 local pwd1="a" 939 local pwd1="a"
558 local pwd2="b" 940 local pwd2="b"
559 local maxtry=5 941 local maxtry=5
560 942
561 if [[ -d "${ROOT}/${DATADIR}/mysql" ]] ; then 943 if [[ -d "${ROOT}/${MY_DATADIR}/mysql" ]] ; then
562 ewarn "You have already a MySQL database in place." 944 ewarn "You have already a MySQL database in place."
563 ewarn "(${ROOT}/${DATADIR}/*)" 945 ewarn "(${ROOT}/${MY_DATADIR}/*)"
564 ewarn "Please rename or delete it if you wish to replace it." 946 ewarn "Please rename or delete it if you wish to replace it."
565 die "MySQL database already exists!" 947 die "MySQL database already exists!"
566 fi 948 fi
567 949
950 # Bug #213475 - MySQL _will_ object strenously if your machine is named
951 # localhost. Also causes weird failures.
952 [[ "${HOSTNAME}" == "localhost" ]] && die "Your machine must NOT be named localhost"
953
568 einfo "Creating the mysql database and setting proper" 954 einfo "Creating the mysql database and setting proper"
569 einfo "permissions on it..." 955 einfo "permissions on it ..."
570 956
571 einfo "Insert a password for the mysql 'root' user" 957 einfo "Insert a password for the mysql 'root' user"
572 ewarn "Avoid [\"'\\_%] characters in the password" 958 ewarn "Avoid [\"'\\_%] characters in the password"
573
574 read -rsp " >" pwd1 ; echo 959 read -rsp " >" pwd1 ; echo
960
575 einfo "Check the password" 961 einfo "Retype the password"
576 read -rsp " >" pwd2 ; echo 962 read -rsp " >" pwd2 ; echo
577 963
578 if [[ "x$pwd1" != "x$pwd2" ]] ; then 964 if [[ "x$pwd1" != "x$pwd2" ]] ; then
579 die "Passwords are not the same" 965 die "Passwords are not the same"
580 fi 966 fi
581 967
582 local options="" 968 local options=""
583 local sqltmp="$(emktemp)" 969 local sqltmp="$(emktemp)"
584 970
585 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql" 971 local help_tables="${ROOT}${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
586 [[ -r "${help_tables}" ]] \ 972 [[ -r "${help_tables}" ]] \
587 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \ 973 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
588 || touch "${TMPDIR}/fill_help_tables.sql" 974 || touch "${TMPDIR}/fill_help_tables.sql"
589 help_tables="${TMPDIR}/fill_help_tables.sql" 975 help_tables="${TMPDIR}/fill_help_tables.sql"
590 976
591 pushd "${TMPDIR}" &>/dev/null 977 pushd "${TMPDIR}" &>/dev/null
592 ${ROOT}/usr/bin/mysql_install_db | grep -B5 -A999 -i "ERROR" 978 "${ROOT}/usr/bin/mysql_install_db" >"${TMPDIR}"/mysql_install_db.log 2>&1
979 if [ $? -ne 0 ]; then
980 grep -B5 -A999 -i "ERROR" "${TMPDIR}"/mysql_install_db.log 1>&2
981 die "Failed to run mysql_install_db. Please review /var/log/mysql/mysqld.err AND ${TMPDIR}/mysql_install_db.log"
982 fi
593 popd &>/dev/null 983 popd &>/dev/null
594 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] \ 984 [[ -f "${ROOT}/${MY_DATADIR}/mysql/user.frm" ]] \
595 || die "MySQL databases not installed" 985 || die "MySQL databases not installed"
596 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null 986 chown -R mysql:mysql "${ROOT}/${MY_DATADIR}" 2>/dev/null
597 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null 987 chmod 0750 "${ROOT}/${MY_DATADIR}" 2>/dev/null
598 988
599 if mysql_version_is_at_least "4.01.03.00" ; then 989 if mysql_version_is_at_least "4.1.3" ; then
600 options="--skip-ndbcluster" 990 options="--skip-ndbcluster"
601 991
602 # Filling timezones, see 992 # Filling timezones, see
603 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 993 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html
604 ${ROOT}/usr/bin/mysql_tzinfo_to_sql ${ROOT}/usr/share/zoneinfo \ 994 "${ROOT}/usr/bin/mysql_tzinfo_to_sql" "${ROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
605 > "${sqltmp}" 2>/dev/null
606 995
607 if [[ -r "${help_tables}" ]] ; then 996 if [[ -r "${help_tables}" ]] ; then
608 cat "${help_tables}" >> "${sqltmp}" 997 cat "${help_tables}" >> "${sqltmp}"
609 fi 998 fi
610 fi 999 fi
611 1000
612 local socket=${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock 1001 local socket="${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock"
613 local pidfile=${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid 1002 local pidfile="${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid"
614 local mysqld="${ROOT}/usr/sbin/mysqld \ 1003 local mysqld="${ROOT}/usr/sbin/mysqld \
615 ${options} \ 1004 ${options} \
616 --user=mysql \ 1005 --user=mysql \
617 --skip-grant-tables \ 1006 --skip-grant-tables \
618 --basedir=${ROOT}/usr \ 1007 --basedir=${ROOT}/usr \
619 --datadir=${ROOT}/${DATADIR} \ 1008 --datadir=${ROOT}/${MY_DATADIR} \
620 --skip-innodb \ 1009 --skip-innodb \
621 --skip-bdb \ 1010 --skip-bdb \
622 --skip-networking \ 1011 --skip-networking \
623 --max_allowed_packet=8M \ 1012 --max_allowed_packet=8M \
624 --net_buffer_length=16K \ 1013 --net_buffer_length=16K \
625 --socket=${socket} \ 1014 --socket=${socket} \
626 --pid-file=${pidfile}" 1015 --pid-file=${pidfile}"
627 $mysqld & 1016 ${mysqld} &
628 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do 1017 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do
629 maxtry=$(($maxtry-1)) 1018 maxtry=$((${maxtry}-1))
630 echo -n "." 1019 echo -n "."
631 sleep 1 1020 sleep 1
632 done 1021 done
633 1022
634 # do this from memory we don't want clear text password in temp files 1023 # Do this from memory, as we don't want clear text passwords in temp files
635 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'" 1024 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'"
636 ${ROOT}/usr/bin/mysql \ 1025 "${ROOT}/usr/bin/mysql" \
637 --socket=${socket} \ 1026 --socket=${socket} \
638 -hlocalhost \ 1027 -hlocalhost \
639 -e "${sql}" 1028 -e "${sql}"
640 1029
641 einfo "Loading \"zoneinfo\" this step may require few seconds" 1030 einfo "Loading \"zoneinfo\", this step may require a few seconds ..."
642 1031
643 ${ROOT}/usr/bin/mysql \ 1032 "${ROOT}/usr/bin/mysql" \
644 --socket=${socket} \ 1033 --socket=${socket} \
645 -hlocalhost \ 1034 -hlocalhost \
646 -uroot \ 1035 -uroot \
647 -p"${pwd1}" \ 1036 -p"${pwd1}" \
648 mysql < "${sqltmp}" 1037 mysql < "${sqltmp}"
649 1038
650 # server stop and cleanup 1039 # Stop the server and cleanup
651 kill $(< "${pidfile}" ) 1040 kill $(< "${pidfile}" )
652 rm "${sqltmp}" 1041 rm -f "${sqltmp}"
653 einfo "stopping the server," 1042 einfo "Stopping the server ..."
654 wait %1 1043 wait %1
655 einfo "done" 1044 einfo "Done"
656} 1045}
657 1046
1047# @FUNCTION: mysql_pkg_postrm
1048# @DESCRIPTION:
1049# Remove mysql symlinks.
658mysql_pkg_postrm() { 1050mysql_pkg_postrm() {
659 mysql_lib_symlinks 1051 : # mysql_lib_symlinks "${D}"
660} 1052}

Legend:
Removed from v.1.28  
changed lines
  Added in v.1.120

  ViewVC Help
Powered by ViewVC 1.1.20