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

Diff of /eclass/mysql.eclass

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

Revision 1.25 Revision 1.82
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2007 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.25 2006/03/16 20:39:00 vivo Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.82 2007/10/02 10:00:07 robbat2 Exp $
4 4
5# Author: Francesco Riosa <vivo at gentoo.org> 5# Author: Francesco Riosa (Retired) <vivo@gentoo.org>
6# Maintainer: Francesco Riosa <vivo at gentoo.org> 6# Maintainer: Luca Longinotti <chtekk@gentoo.org>
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
11WANT_AUTOCONF="latest"
12WANT_AUTOMAKE="latest"
7 13
8inherit eutils flag-o-matic gnuconfig autotools mysql_fx 14inherit eutils flag-o-matic gnuconfig autotools mysql_fx
9 15
10#major, minor only in the slot
11SLOT=$(( ${MYSQL_VERSION_ID} / 10000 ))
12
13# shorten the path because the socket path length must be shorter than 107 chars 16# 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 17# and we will run a mysql server during test phase
15S="${WORKDIR}/${PN}" 18S="${WORKDIR}/mysql"
16 19
20[[ "${MY_EXTRAS_VER}" == "latest" ]] && MY_EXTRAS_VER="20070108"
21
22if [[ ${PR#r} -lt 60 ]] ; then
23 IS_BITKEEPER=0
24elif [[ ${PR#r} -lt 90 ]] ; then
25 IS_BITKEEPER=60
26else
27 IS_BITKEEPER=90
28fi
29
30# MYSQL_VERSION_ID will be:
31# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99]
32# This is an important part, because many of the choices the MySQL ebuild will do
33# depend on this variable.
34# In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803"
35
36MYSQL_VERSION_ID=""
37tpv=( ${PV//[-._]/ } ) ; tpv[3]="${PVR:${#PV}}" ; tpv[3]="${tpv[3]##*-r}"
38for vatom in 0 1 2 3 ; do
39 # pad to length 2
40 tpv[${vatom}]="00${tpv[${vatom}]}"
41 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}"
42done
43# strip leading "0" (otherwise it's considered an octal number by BASH)
44MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"}
45
46# Be warned, *DEPEND are version-dependant
47DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d )
48 userland_GNU? ( sys-process/procps )
49 >=sys-apps/sed-4
50 >=sys-apps/texinfo-4.7-r1
51 >=sys-libs/readline-4.1
52 >=sys-libs/zlib-1.2.3"
53
54# Having different flavours at the same time is not a good idea
55for i in "" "-community" ; do
56 [[ "${i}" == ${PN#mysql} ]] ||
57 DEPEND="${DEPEND} !dev-db/mysql${i}"
58done
59
60mysql_version_is_at_least "5.1" \
61|| DEPEND="${DEPEND} berkdb? ( sys-apps/ed )"
62
63mysql_version_is_at_least "5.1.12" \
64&& DEPEND="${DEPEND} innodb? ( >=dev-util/cmake-2.4.3 )"
65
66# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
67PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
68
69# BitKeeper dependency, compile-time only
70[[ ${IS_BITKEEPER} -eq 90 ]] && DEPEND="${DEPEND} dev-util/bk_client"
71
72# Work out the default SERVER_URI correctly
73if [ -z "${SERVER_URI}" ]; then
74 # The community build is on the mirrors
75 if [ "${PN}" == "mysql-community" ]; then
76 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${PV//_/-}.tar.gz"
77 # The enterprise source is on the primary site only
78 elif [ "${PN}" == "mysql" ]; then
79 SERVER_URI="ftp://ftp.mysql.com/pub/mysql/src/mysql-${PV//_/-}.tar.gz"
80 fi
81fi
82
83# Define correct SRC_URIs
84SRC_URI="${SERVER_URI}
85 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
86 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
87mysql_version_is_at_least "5.1.12" \
88&& [[ -n "${PBXT_VERSION}" ]] \
89&& SRC_URI="${SRC_URI} pbxt? ( mirror://sourceforge/pbxt/pbxt-${PBXT_VERSION}.tar.gz )"
90
17DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" 91DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
18HOMEPAGE="http://www.mysql.com/" 92HOMEPAGE="http://www.mysql.com/"
19NEWP="${P/_/-}"
20SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${NEWP}.tar.gz
21 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
22LICENSE="GPL-2" 93LICENSE="GPL-2"
94SLOT="0"
23IUSE="big-tables berkdb debug embedded minimal perl selinux srvdir ssl static" 95IUSE="big-tables debug embedded minimal perl selinux ssl static"
24RESTRICT="primaryuri confcache"
25 96
97mysql_version_is_at_least "4.1" \
98&& IUSE="${IUSE} latin1"
99
26mysql_version_is_at_least "4.01.03.00" \ 100mysql_version_is_at_least "4.1.3" \
27&& IUSE="${IUSE} cluster extraengine" 101&& IUSE="${IUSE} cluster extraengine"
28 102
29mysql_version_is_at_least "5.00.00.00" \ 103mysql_version_is_at_least "5.0" \
30|| IUSE="${IUSE} raid" 104|| IUSE="${IUSE} raid"
31 105
32mysql_version_is_at_least "5.00.18.00" \ 106mysql_version_is_at_least "5.0.18" \
33&& IUSE="${IUSE} max-idx-128" 107&& IUSE="${IUSE} max-idx-128"
34 108
35mysql_version_is_at_least "5.01.00.00" \ 109mysql_version_is_at_least "5.1" \
36&& IUSE="${IUSE} innodb" 110&& IUSE="${IUSE} innodb"
37 111
112mysql_version_is_at_least "5.1" \
113|| IUSE="${IUSE} berkdb"
114
115mysql_version_is_at_least "5.1.12" \
116&& IUSE="${IUSE} pbxt"
117
118RDEPEND="${DEPEND}
119 !minimal? ( dev-db/mysql-init-scripts )
120 selinux? ( sec-policy/selinux-mysql )"
121
38EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_config pkg_prerm pkg_postrm 122EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \
123 pkg_postinst pkg_config pkg_postrm
124
125#
126# HELPER FUNCTIONS:
127#
128
129bitkeeper_fetch() {
130 local reposuf
131 if [[ -z "${1}" ]] ; then
132 local tpv
133 tpv=( ${PV//[-._]/ } )
134 reposuf="mysql-${tpv[0]}.${tpv[1]}"
135 else
136 reposuf="${1}"
137 fi
138 einfo "Using '${reposuf}' repository."
139 local repo_uri="bk://mysql.bkbits.net/${reposuf}"
140 ## -- ebk_store_dir: bitkeeper sources store directory
141 local ebk_store_dir="${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}/bk-src"
142 ## -- ebk_fetch_cmd: bitkeeper fetch command
143 # always fetch the latest revision, use -r<revision> if a specified revision is wanted
144 # hint: does not work
145 local ebk_fetch_cmd="sfioball"
146 ## -- ebk_update_cmd: bitkeeper update command
147 local ebk_update_cmd="update"
148
149 # addread "/etc/bitkeeper"
150 addwrite "${ebk_store_dir}"
151
152 if [[ ! -d "${ebk_store_dir}" ]] ; then
153 debug-print "${FUNCNAME}: initial checkout, creating bitkeeper directory ..."
154 mkdir -p "${ebk_store_dir}" || die "BK: couldn't mkdir ${ebk_store_dir}"
155 fi
156
157 pushd "${ebk_store_dir}" || die "BK: couldn't chdir to ${ebk_store_dir}"
158
159 local wc_path=${reposuf}
160
161 if [[ ! -d "${wc_path}" ]] ; then
162 local options="-r+"
163
164 # first checkout
165 einfo "bitkeeper checkout start -->"
166 einfo " repository: ${repo_uri}"
167
168 ${ebk_fetch_cmd} ${options} "${repo_uri}" "${wc_path}" \
169 || die "BK: couldn't fetch from ${repo_uri}"
170 else
171 if [[ ! -d "${wc_path}/BK" ]] ; then
172 popd
173 die "Looks like ${wc_path} is not a bitkeeper path"
174 fi
175
176 # update working copy
177 einfo "bitkeeper update start -->"
178 einfo " repository: ${repo_uri}"
179
180 ${ebk_update_cmd} "${repo_uri}" "${wc_path}" \
181 || die "BK: couldn't update from ${repo_uri} to ${wc_path}"
182 fi
183
184 einfo " working copy: ${wc_path}"
185 cd "${wc_path}"
186 rsync -rlpgo --exclude="BK/" . "${S}" || die "BK: couldn't export to ${S}"
187
188 echo
189 popd
190}
191
192mysql_disable_test() {
193 local testname="${1}" ; shift
194 local reason="${@}"
195 local mysql_disable_file="${S}/mysql-test/t/disabled.def"
196 echo ${testname} : ${reason} >> "${mysql_disable_file}"
197 ewarn "test '${testname}' disabled: '${reason}'"
198}
39 199
40# void mysql_init_vars() 200# void mysql_init_vars()
41# 201#
42# initialize global variables 202# Initialize global variables
43# 2005-11-19 <vivo at gentoo.org> 203# 2005-11-19 <vivo@gentoo.org>
204
44mysql_init_vars() { 205mysql_init_vars() {
45
46 if [[ ${SLOT} -eq 0 ]] ; then
47 MY_SUFFIX=""
48 else
49 MY_SUFFIX=${MY_SUFFIX:-"-${SLOT}"}
50 fi
51 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR:-"/usr/share/mysql${MY_SUFFIX}"} 206 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"}
52 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql${MY_SUFFIX}"} 207 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"}
53 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql${MY_SUFFIX}"} 208 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"}
54 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql${MY_SUFFIX}"} 209 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"}
55 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql${MY_SUFFIX}"} 210 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql"}
56 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql${MY_SUFFIX}"} 211 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql"}
57 212
58 if [ -z "${DATADIR}" ]; then 213 if [[ -z "${MY_DATADIR}" ]] ; then
59 DATADIR="" 214 MY_DATADIR=""
60 if [ -f "${MY_SYSCONFDIR}/my.cnf" ] ; then 215 if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then
61 DATADIR=`"my_print_defaults${MY_SUFFIX}" mysqld 2>/dev/null | sed -ne '/datadir/s|^--datadir=||p' | tail -n1` 216 MY_DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
217 | sed -ne '/datadir/s|^--datadir=||p' \
218 | tail -n1`
62 if [ -z "${DATADIR}" ]; then 219 if [[ -z "${MY_DATADIR}" ]] ; then
63 if useq "srvdir" ; then
64 DATADIR="${ROOT}/srv/localhost/mysql${MY_SUFFIX}/datadir"
65 else
66 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" | sed -e 's/.*=\s*//'` 220 MY_DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \
67 fi 221 | sed -e 's/.*=\s*//'`
68 fi 222 fi
69 fi 223 fi
70 if [ -z "${DATADIR}" ]; then 224 if [[ -z "${MY_DATADIR}" ]] ; then
71 if useq "srvdir" ; then
72 DATADIR="${ROOT}/srv/localhost/mysql${MY_SUFFIX}/datadir"
73 else
74 DATADIR="${MY_LOCALSTATEDIR}" 225 MY_DATADIR="${MY_LOCALSTATEDIR}"
75 fi
76 einfo "Using default DATADIR" 226 einfo "Using default MY_DATADIR"
77 fi 227 fi
78 einfo "MySQL DATADIR is ${DATADIR}" 228 elog "MySQL MY_DATADIR is ${MY_DATADIR}"
79 229
80 if [ -z "${PREVIOUS_DATADIR}" ] ; then 230 if [[ -z "${PREVIOUS_DATADIR}" ]] ; then
81 if [ -a "${DATADIR}" ] ; then 231 if [[ -e "${MY_DATADIR}" ]] ; then
82 ewarn "Previous datadir found, it's YOUR job to change" 232 elog "Previous datadir found, it's YOUR job to change"
83 ewarn "ownership and have care of it" 233 elog "ownership and take care of it"
84 PREVIOUS_DATADIR="yes" 234 PREVIOUS_DATADIR="yes"
85 export PREVIOUS_DATADIR
86 else 235 else
87 PREVIOUS_DATADIR="no" 236 PREVIOUS_DATADIR="no"
88 export PREVIOUS_DATADIR
89 fi 237 fi
90 fi 238 export PREVIOUS_DATADIR
91 fi 239 fi
240 fi
92 241
242 MY_SOURCEDIR=${SERVER_URI##*/}
243 MY_SOURCEDIR=${MY_SOURCEDIR%.tar*}
244
93 export MY_SUFFIX MY_SHAREDSTATEDIR MY_SYSCONFDIR 245 export MY_SHAREDSTATEDIR MY_SYSCONFDIR
94 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR 246 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
95 export MY_INCLUDEDIR 247 export MY_INCLUDEDIR MY_DATADIR MY_SOURCEDIR
96 export DATADIR
97} 248}
249
250configure_minimal() {
251 # These are things we exclude from a minimal build, please
252 # note that the server actually does get built and installed,
253 # but we then delete it before packaging.
254 local minimal_exclude_list="server embedded-server extra-tools innodb bench berkeley-db row-based-replication"
255
256 for i in ${minimal_exclude_list} ; do
257 myconf="${myconf} --without-${i}"
258 done
259 myconf="${myconf} --with-extra-charsets=none"
260 myconf="${myconf} --enable-local-infile"
261
262 if use static ; then
263 myconf="${myconf} --with-client-ldflags=-all-static"
264 myconf="${myconf} --disable-shared --with-pic"
265 else
266 myconf="${myconf} --enable-shared --enable-static"
267 fi
268
269 if mysql_version_is_at_least "4.1" && ! use latin1 ; then
270 myconf="${myconf} --with-charset=utf8"
271 myconf="${myconf} --with-collation=utf8_general_ci"
272 else
273 myconf="${myconf} --with-charset=latin1"
274 myconf="${myconf} --with-collation=latin1_swedish_ci"
275 fi
276}
277
278configure_common() {
279 myconf="${myconf} $(use_with big-tables)"
280 myconf="${myconf} --enable-local-infile"
281 myconf="${myconf} --with-extra-charsets=all"
282 myconf="${myconf} --with-mysqld-user=mysql"
283 myconf="${myconf} --with-server"
284 myconf="${myconf} --with-unix-socket-path=/var/run/mysqld/mysqld.sock"
285 myconf="${myconf} --without-libwrap"
286
287 if use static ; then
288 myconf="${myconf} --with-mysqld-ldflags=-all-static"
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 use debug ; then
296 myconf="${myconf} --with-debug=full"
297 else
298 myconf="${myconf} --without-debug"
299 mysql_version_is_at_least "4.1.3" \
300 && use cluster \
301 && myconf="${myconf} --without-ndb-debug"
302 fi
303
304 if mysql_version_is_at_least "4.1" && ! use latin1 ; then
305 myconf="${myconf} --with-charset=utf8"
306 myconf="${myconf} --with-collation=utf8_general_ci"
307 else
308 myconf="${myconf} --with-charset=latin1"
309 myconf="${myconf} --with-collation=latin1_swedish_ci"
310 fi
311
312 if use embedded ; then
313 myconf="${myconf} --with-embedded-privilege-control"
314 myconf="${myconf} --with-embedded-server"
315 else
316 myconf="${myconf} --without-embedded-privilege-control"
317 myconf="${myconf} --without-embedded-server"
318 fi
319
320}
321
322configure_40_41_50() {
323 myconf="${myconf} $(use_with perl bench)"
324 myconf="${myconf} --enable-assembler"
325 myconf="${myconf} --with-extra-tools"
326 myconf="${myconf} --with-innodb"
327 myconf="${myconf} --without-readline"
328 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)"
329
330 # --with-vio is not needed anymore, it's on by default and
331 # has been removed from configure
332 if use ssl ; then
333 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio"
334 fi
335
336 if mysql_version_is_at_least "5.1.11" ; then
337 myconf="${myconf} $(use_with ssl)"
338 else
339 myconf="${myconf} $(use_with ssl openssl)"
340 fi
341
342 if use berkdb ; then
343 # The following fix is due to a bug with bdb on SPARC's. See:
344 # http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
345 # It comes down to non-64-bit safety problems.
346 if use alpha || use amd64 || use hppa || use mips || use sparc ; then
347 elog "Berkeley DB support was disabled due to compatibility issues on this arch"
348 myconf="${myconf} --without-berkeley-db"
349 else
350 myconf="${myconf} --with-berkeley-db=./bdb"
351 fi
352 else
353 myconf="${myconf} --without-berkeley-db"
354 fi
355
356 if mysql_version_is_at_least "4.1.3" ; then
357 myconf="${myconf} --with-geometry"
358 myconf="${myconf} $(use_with cluster ndbcluster)"
359 fi
360
361 if mysql_version_is_at_least "4.1.3" && use extraengine ; then
362 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
363 myconf="${myconf} --with-archive-storage-engine"
364
365 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
366 myconf="${myconf} --with-csv-storage-engine"
367
368 # http://dev.mysql.com/doc/mysql/en/blackhole-storage-engine.html
369 myconf="${myconf} --with-blackhole-storage-engine"
370
371 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
372 # http://dev.mysql.com/doc/mysql/en/federated-description.html
373 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
374 if mysql_version_is_at_least "5.0.3" ; then
375 elog "Before using the Federated storage engine, please be sure to read"
376 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
377 myconf="${myconf} --with-federated-storage-engine"
378 fi
379 fi
380
381 mysql_version_is_at_least "5.0.18" \
382 && use max-idx-128 \
383 && myconf="${myconf} --with-max-indexes=128"
384}
385
386configure_51() {
387 # TODO: !!!! readd --without-readline
388 # the failure depend upon config/ac-macros/readline.m4 checking into
389 # readline.h instead of history.h
390 myconf="${myconf} $(use_with ssl)"
391 myconf="${myconf} --enable-assembler"
392 myconf="${myconf} --with-geometry"
393 myconf="${myconf} --with-readline"
394 myconf="${myconf} --with-row-based-replication"
395 myconf="${myconf} --with-zlib=/usr/$(get_libdir)"
396 myconf="${myconf} --without-pstack"
397 use max-idx-128 && myconf="${myconf} --with-max-indexes=128"
398
399 # 5.1 introduces a new way to manage storage engines (plugins)
400 # like configuration=none
401 local plugins="csv,myisam,myisammrg,heap"
402 if use extraengine ; then
403 # like configuration=max-no-ndb, archive and example removed in 5.1.11
404 plugins="${plugins},archive,blackhole,example,federated,partition"
405
406 elog "Before using the Federated storage engine, please be sure to read"
407 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
408 fi
409
410 if use innodb ; then
411 plugins="${plugins},innobase"
412 fi
413
414 # like configuration=max-no-ndb
415 if use cluster ; then
416 plugins="${plugins},ndbcluster"
417 myconf="${myconf} --with-ndb-binlog"
418 fi
419
420 if mysql_version_is_at_least "5.2" ; then
421 plugins="${plugins},falcon"
422 fi
423
424 myconf="${myconf} --with-plugins=${plugins}"
425}
426
427pbxt_src_compile() {
428 mysql_init_vars
429
430 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
431
432 einfo "Reconfiguring dir '${PWD}'"
433 AT_GNUCONF_UPDATE="yes" eautoreconf
434
435 local myconf=""
436 myconf="${myconf} --with-mysql=${S} --libdir=${D}/${MY_LIBDIR}"
437 use debug && myconf="${myconf} --with-debug=full"
438 # TODO: is it safe/needed to use econf here ?
439 ./configure ${myconf} || die "Problem configuring PBXT storage engine"
440 # TODO: is it safe/needed to use emake here ?
441 make || die "Problem making PBXT storage engine (${myconf})"
442
443 popd
444 # TODO: modify test suite for PBXT
445}
446
447pbxt_src_install() {
448 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
449 make install || die "Failed to install PBXT"
450 popd
451}
452
453#
454# EBUILD FUNCTIONS
455#
98 456
99mysql_pkg_setup() { 457mysql_pkg_setup() {
100
101 enewgroup mysql 60 || die "problem adding group mysql" 458 enewgroup mysql 60 || die "problem adding 'mysql' group"
102 enewuser mysql 60 -1 /dev/null mysql \ 459 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
103 || die "problem adding user mysql" 460
461 # Check for USE flag problems in pkg_setup
462 if use static && use ssl ; then
463 eerror "MySQL does not support being built statically with SSL support enabled!"
464 die "MySQL does not support being built statically with SSL support enabled!"
465 fi
466
467 if ! mysql_version_is_at_least "5.0" \
468 && use raid \
469 && use static ; then
470 eerror "USE flags 'raid' and 'static' conflict, you cannot build MySQL statically"
471 eerror "with RAID support enabled."
472 die "USE flags 'raid' and 'static' conflict!"
473 fi
474
475 if mysql_version_is_at_least "4.1.3" \
476 && ( use cluster || use extraengine ) \
477 && use minimal ; then
478 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
479 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
480 fi
481
482 mysql_check_version_range "4.0 to 5.0.99.99" \
483 && use berkdb \
484 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
104} 485}
105 486
106mysql_src_unpack() { 487mysql_src_unpack() {
107 488 # Initialize the proper variables first
108 mysql_init_vars 489 mysql_init_vars
109 490
110 if useq static && useq ssl; then 491 unpack ${A}
111 local msg="MySQL does not support building statically with SSL support" 492 if [[ ${IS_BITKEEPER} -eq 90 ]] ; then
112 eerror "${msg}" 493 if mysql_check_version_range "5.1 to 5.1.99" ; then
113 die "${msg}" 494 bitkeeper_fetch "mysql-5.1-ndb"
495 elif mysql_check_version_range "5.2 to 5.2.99" ; then
496 bitkeeper_fetch "mysql-5.2-falcon"
497 else
498 bitkeeper_fetch
114 fi 499 fi
115
116 if mysql_version_is_at_least "4.01.03.00" \
117 && useq cluster \
118 || useq extraengine \
119 && useq minimal ; then
120 die "USEs cluster, extraengine conflicts with \"minimal\""
121 fi
122
123 unpack ${A} || die
124
125 mv -f "${WORKDIR}/${NEWP}" "${S}"
126 cd "${S}" 500 cd "${S}"
501 einfo "Running upstream autorun over BK sources ..."
502 BUILD/autorun.sh
503 else
504 mv -f "${WORKDIR}/${MY_SOURCEDIR}" "${S}"
505 cd "${S}"
506 fi
127 507
508 # Apply the patches for this MySQL version
128 EPATCH_SUFFIX="patch" 509 EPATCH_SUFFIX="patch"
129 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory" 510 mkdir -p "${EPATCH_SOURCE}" || die "Unable to create epatch directory"
130 mysql_mv_patches 511 mysql_mv_patches
131 epatch || die "failed to apply all patches" 512 epatch
132 513
133 # additional check, remove bundled zlib 514 # Additional checks, remove bundled zlib
134 rm -f "${S}/zlib/"*.[ch] 515 rm -f "${S}/zlib/"*.[ch]
135 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in" 516 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
136 rm -f scripts/mysqlbug 517 rm -f "scripts/mysqlbug"
137 518
138 # Make charsets install in the right place 519 # Make charsets install in the right place
139 find . -name 'Makefile.am' \ 520 find . -name 'Makefile.am' \
140 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \; 521 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
141 522
142 # Manage mysqlmanager
143 mysql_version_is_at_least "5.00.15.00" \ 523 if mysql_version_is_at_least "4.1" ; then
144 && sed -i -e "s!@GENTOO_EXT@!${MY_SUFFIX}!g" \
145 -e "s!@GENTOO_SOCK_PATH@!var/run/mysqld!g" \
146 "${S}/server-tools/instance-manager/Makefile.am"
147
148 # remove what need to be recreated, so we are sure it's actually done 524 # Remove what needs to be recreated, so we're sure it's actually done
149 find . -name Makefile -o -name Makefile.in -o -name configure -exec rm -f {} \; 525 find . -name Makefile \
526 -o -name Makefile.in \
527 -o -name configure \
528 -exec rm -f {} \;
150 rm ltmain.sh 529 rm -f "ltmain.sh"
530 rm -f "scripts/mysqlbug"
531 fi
151 532
152 local rebuilddirlist d buildstep bdbdir 533 local rebuilddirlist d
153 534
154 if mysql_version_is_at_least "5.01.00.00" ; then 535 if mysql_version_is_at_least "5.1.12" ; then
155 rebuilddirlist=". storage/innobase" 536 rebuilddirlist="."
156 bdbdir='storage/bdb/dist' 537 # TODO: check this with a cmake expert
538 use innodb \
539 && cmake \
540 -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \
541 -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \
542 "storage/innobase"
157 else 543 else
158 rebuilddirlist=". innobase" 544 rebuilddirlist=". innobase"
159 bdbdir='bdb/dist'
160 fi 545 fi
161 546
162 for d in ${rebuilddirlist}; do 547 for d in ${rebuilddirlist} ; do
163 einfo "reconfiguring dir \"${d}\"" 548 einfo "Reconfiguring dir '${d}'"
164 pushd "${d}" &>/dev/null 549 pushd "${d}" &>/dev/null
165 AT_GNUCONF_UPDATE="yes" eautoreconf 550 AT_GNUCONF_UPDATE="yes" eautoreconf
166 popd &>/dev/null 551 popd &>/dev/null
167 done 552 done
168 553
169 #TODO berkdb in 5.1 need to be worked on 554 if mysql_check_version_range "4.1 to 5.0.99.99" \
170 if useq berkdb && ! mysql_check_version_range "5.01.00.00 to 5.01.08.99" 555 && use berkdb ; then
171 then
172 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh" 556 [[ -w "bdb/dist/ltmain.sh" ]] && cp -f "ltmain.sh" "bdb/dist/ltmain.sh"
173 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" &>/dev/null 557 cp -f "/usr/share/aclocal/libtool.m4" "bdb/dist/aclocal/libtool.ac" \
558 || die "Could not copy libtool.m4 to bdb/dist/"
559 pushd "bdb/dist" &>/dev/null
560 sh s_all \
561 || die "Failed bdb reconfigure"
174 popd &>/dev/null 562 popd &>/dev/null
175 fi 563 fi
176
177} 564}
178 565
179mysql_src_compile() { 566mysql_src_compile() {
180 567 # Make sure the vars are correctly initialized
181 mysql_init_vars 568 mysql_init_vars
569
570 # $myconf is modified by the configure_* functions
182 local myconf 571 local myconf=""
183 572
184 if useq static ; then 573 if use minimal ; then
185 myconf="${myconf} --with-mysqld-ldflags=-all-static" 574 configure_minimal
186 myconf="${myconf} --with-client-ldflags=-all-static"
187 myconf="${myconf} --disable-shared"
188 else 575 else
189 myconf="${myconf} --enable-shared --enable-static" 576 configure_common
190 fi
191
192 #myconf="${myconf} `use_with tcpd libwrap`"
193 myconf="${myconf} --without-libwrap"
194
195 if useq ssl ; then
196 # --with-vio is not needed anymore, it's on by default and
197 # has been removed from configure
198 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio"
199 if mysql_version_is_at_least "5.00.06.00" ; then 577 if mysql_version_is_at_least "5.1.10" ; then
200 # yassl-0.96 is young break with gcc-4.0 || amd64 578 configure_51
201 #myconf="${myconf} --with-yassl"
202 myconf="${myconf} --with-openssl"
203 else 579 else
204 myconf="${myconf} --with-openssl" 580 configure_40_41_50
205 fi
206 else
207 myconf="${myconf} --without-openssl"
208 fi
209
210 if useq debug; then
211 myconf="${myconf} --with-debug=full"
212 else
213 myconf="${myconf} --without-debug"
214 mysql_version_is_at_least "4.01.03.00" && useq cluster && myconf="${myconf} --without-ndb-debug"
215 fi
216
217 # benchmarking stuff needs perl
218 # and shouldn't be bothered with on minimal builds
219 if useq perl && ! useq minimal; then
220 myconf="${myconf} --with-bench"
221 else
222 myconf="${myconf} --without-bench"
223 fi
224
225 # these are things we exclude from a minimal build
226 # note that the server actually does get built and installed
227 # but we then delete it before packaging.
228 local minimal_exclude_list="server embedded-server extra-tools innodb"
229 if ! useq minimal; then
230 for i in ${minimal_exclude_list}; do
231 myconf="${myconf} --with-${i}"
232 done
233
234 if useq static ; then
235 myconf="${myconf} --without-raid"
236 ewarn "disabling raid support, has problem with static"
237 else
238 if mysql_version_is_at_least "5.00.00.00" ; then
239 myconf="${myconf} --without-raid"
240 else
241 myconf="${myconf} `use_with raid`"
242 fi 581 fi
243 fi 582 fi
244 583
245 if ! mysql_version_is_at_least "5.00.00.00" ; then
246 if mysql_version_is_at_least "4.01.00.00" ; then
247 myconf="${myconf} --with-charset=utf8"
248 myconf="${myconf} --with-collation=utf8_general_ci"
249 else
250 myconf="${myconf} --with-charset=latin1"
251 myconf="${myconf} --with-collation=latin1_swedish_ci"
252 fi
253 fi
254
255 # optional again from 2005-12-05
256 if mysql_version_is_at_least "5.01.00.00" ; then
257 myconf="${myconf} $(use_with innodb)"
258 else
259 myconf="${myconf} --with-innodb"
260 fi
261
262 # lots of chars
263 myconf="${myconf} --with-extra-charsets=all"
264
265 #The following fix is due to a bug with bdb on sparc's. See:
266 #http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
267 # it comes down to non-64-bit safety problems
268 if useq sparc || useq alpha || useq hppa || useq mips || useq amd64 \
269 || mysql_check_version_range "5.01.00.00 to 5.01.06.99"
270 then
271 ewarn "bdb berkeley-db disabled due to arch or version"
272 myconf="${myconf} --without-berkeley-db"
273 else
274 #TODO berkdb in 5.1 need to be worked on
275 useq berkdb && \
276 ! mysql_check_version_range "5.01.00.00 to 5.01.08.99" \
277 && myconf="${myconf} --with-berkeley-db=./bdb" \
278 || myconf="${myconf} --without-berkeley-db"
279 fi
280
281 if mysql_version_is_at_least "4.01.03.00" ; then
282 #myconf="${myconf} $(use_with geometry)"
283 myconf="${myconf} --with-geometry"
284 myconf="${myconf} $(use_with cluster ndbcluster)"
285 fi
286
287 mysql_version_is_at_least "4.01.11.00" && myconf="${myconf} `use_with big-tables`"
288
289 mysql_version_is_at_least "5.01.06.00" && myconf="${myconf} --with-ndb-binlog"
290
291 if useq embedded ; then
292 #REMIND, need the privilege control enabled ?
293 myconf="${myconf} --without-embedded-privilege-control"
294 myconf="${myconf} --with-embedded-server"
295 else
296 myconf="${myconf} --without-embedded-privilege-control"
297 myconf="${myconf} --without-embedded-server"
298 fi
299 else
300 for i in ${minimal_exclude_list}; do
301 myconf="${myconf} --without-${i}"
302 done
303 myconf="${myconf} --without-berkeley-db"
304 myconf="${myconf} --with-extra-charsets=none"
305 fi
306
307 if mysql_version_is_at_least "4.01.03.00" && useq extraengine; then
308 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
309 myconf="${myconf} --with-archive-storage-engine"
310 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
311
312 mysql_version_is_at_least "4.01.04.00" \
313 && myconf="${myconf} --with-csv-storage-engine"
314
315 mysql_version_is_at_least "4.01.11.00" \
316 && myconf="${myconf} --with-blackhole-storage-engine"
317
318 # http://dev.mysql.com/doc/mysql/en/federated-description.html
319 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
320 if mysql_version_is_at_least "5.00.03.00" ; then
321 einfo "before to use federated engine be sure to read"
322 einfo "http://dev.mysql.com/doc/refman/5.0/en/federated-limitations.html"
323 myconf="${myconf} --with-federated-storage-engine"
324
325 # http://dev.mysql.com/doc/refman/5.1/en/partitioning-overview.html
326 if mysql_version_is_at_least "5.01.00.00" ; then
327 myconf="${myconf} --with-partition"
328 fi
329 fi
330
331 fi
332
333 mysql_version_is_at_least "5.00.18.00" \
334 && useq "max-idx-128" \
335 && myconf="${myconf} --with-max-indexes=128"
336
337 if mysql_version_is_at_least "5.01.05.00" ; then
338 myconf="${myconf} --with-row-based-replication"
339 fi
340
341 #TODO rechek again later, had problem with assembler enabled
342 # and some combination of use-flags with 5.1
343 if mysql_check_version_range "5.01.00.00 to 5.01.08.99" ; then
344 myconf="${myconf} --disable-assembler"
345 else
346 myconf="${myconf} --enable-assembler"
347 fi
348
349 #Bug #114895,Bug #110149 584 # Bug #114895, bug #110149
350 filter-flags "-O" "-O[01]" 585 filter-flags "-O" "-O[01]"
586
351 #glibc-2.3.2_pre fix; bug #16496 587 # glib-2.3.2_pre fix, bug #16496
352 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 588 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
353 589
354 #the compiler flags are as per their "official" spec ;) 590 CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-strict-aliasing"
355 #CFLAGS="${CFLAGS/-O?/} -O3" \
356 export CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" 591 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
357 mysql_version_is_at_least "5.00.00.00" \ 592 mysql_version_is_at_least "5.0" \
358 && export CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 593 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
594 export CXXFLAGS
359 595
360 econf \ 596 econf \
361 --program-suffix="${MY_SUFFIX}" \
362 --libexecdir="/usr/sbin" \ 597 --libexecdir="/usr/sbin" \
363 --sysconfdir="${MY_SYSCONFDIR}" \ 598 --sysconfdir="${MY_SYSCONFDIR}" \
364 --localstatedir="${MY_LOCALSTATEDIR}" \ 599 --localstatedir="${MY_LOCALSTATEDIR}" \
365 --sharedstatedir="${MY_SHAREDSTATEDIR}" \ 600 --sharedstatedir="${MY_SHAREDSTATEDIR}" \
366 --libdir="${MY_LIBDIR}" \ 601 --libdir="${MY_LIBDIR}" \
367 --includedir="${MY_INCLUDEDIR}" \ 602 --includedir="${MY_INCLUDEDIR}" \
368 --with-low-memory \ 603 --with-low-memory \
369 --enable-local-infile \
370 --with-mysqld-user=mysql \
371 --with-client-ldflags=-lstdc++ \ 604 --with-client-ldflags=-lstdc++ \
372 --enable-thread-safe-client \ 605 --enable-thread-safe-client \
373 --with-comment="Gentoo Linux ${PF}" \ 606 --with-comment="Gentoo Linux ${PF}" \
374 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
375 --with-lib-ccflags="-fPIC" \
376 --without-readline \
377 --without-docs \ 607 --without-docs \
378 ${myconf} || die "bad ./configure" 608 ${myconf} || die "econf failed"
379 609
380 # TODO Move this before autoreconf !!! 610 # TODO: Move this before autoreconf !!!
381 find . -type f -name Makefile -print0 \ 611 find . -type f -name Makefile -print0 \
382 | xargs -0 -n100 sed -i \ 612 | xargs -0 -n100 sed -i \
383 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|' 613 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
384 614
385 emake || die "compile problem" 615 emake || die "emake failed"
616
617 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_compile
386} 618}
387 619
388mysql_src_install() { 620mysql_src_install() {
389 621 # Make sure the vars are correctly initialized
390 mysql_init_vars 622 mysql_init_vars
623
391 make install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die 624 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed"
625
626 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_install
392 627
393 insinto "${MY_INCLUDEDIR}" 628 insinto "${MY_INCLUDEDIR}"
394 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h 629 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h
395 630
396 # convenience links 631 # Convenience links
397 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlanalyze${MY_SUFFIX}" 632 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
398 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlrepair${MY_SUFFIX}" 633 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
399 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqloptimize${MY_SUFFIX}" 634 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize"
400 635
401 # various junk (my-*.cnf moved elsewhere) 636 # Various junk (my-*.cnf moved elsewhere)
402 rm -rf "${D}/usr/share/info" 637 rm -Rf "${D}/usr/share/info"
403 for removeme in "mysql-log-rotate" mysql.server* \ 638 for removeme in "mysql-log-rotate" mysql.server* \
404 binary-configure* my-*.cnf mi_test_all* 639 binary-configure* my-*.cnf mi_test_all*
405 do 640 do
406 rm -f ${D}/usr/share/mysql/${removeme} 641 rm -f "${D}"/usr/share/mysql/${removeme}
407 done 642 done
408 643
409 # TODO change at Makefile-am level
410 for moveme in "mysql_fix_privilege_tables.sql" \
411 "fill_help_tables.sql" "ndb-config-2-node.ini"
412 do
413 mv -f "${D}/usr/share/mysql/${moveme}" "${D}/usr/share/mysql${MY_SUFFIX}/" 2>/dev/null
414 done
415
416 if [[ -n "${MY_SUFFIX}" ]] ; then
417 local notcatched=$(ls "${D}/usr/share/mysql"/*)
418 if [[ -n "${notcatched}" ]] ; then
419 ewarn "QA notice"
420 ewarn "${notcatched} files in /usr/share/mysql"
421 ewarn "bug mysql-herd to manage them"
422 fi
423 rm -rf "${D}/usr/share/mysql"
424 fi
425
426 # clean up stuff for a minimal build 644 # Clean up stuff for a minimal build
427 # this is anything server-specific
428 if useq minimal; then 645 if use minimal ; then
429 rm -rf ${D}${MY_SHAREDSTATEDIR}/{mysql-test,sql-bench} 646 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
430 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} 647 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}
431 rm -f "${D}/usr/sbin/mysqld${MY_SUFFIX}" 648 rm -f "${D}/usr/sbin/mysqld"
432 rm -f ${D}${MY_LIBDIR}/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a 649 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
433 fi 650 fi
434 651
435 # config stuff 652 # Configuration stuff
653 if mysql_version_is_at_least "4.1" ; then
654 mysql_mycnf_version="4.1"
655 else
656 mysql_mycnf_version="4.0"
657 fi
436 insinto "${MY_SYSCONFDIR}" 658 insinto "${MY_SYSCONFDIR}"
437 doins scripts/mysqlaccess.conf 659 doins scripts/mysqlaccess.conf
438 sed -e "s!@MY_SUFFIX@!${MY_SUFFIX}!g" \
439 -e "s!@DATADIR@!${DATADIR}!g" \ 660 sed -e "s!@DATADIR@!${MY_DATADIR}!g" \
440 "${FILESDIR}/my.cnf-4.1-r1" \ 661 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
441 > "${TMPDIR}/my.cnf.ok" 662 > "${TMPDIR}/my.cnf.ok"
663 if mysql_version_is_at_least "4.1" && use latin1 ; then
664 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok"
665 fi
442 newins "${TMPDIR}/my.cnf.ok" my.cnf 666 newins "${TMPDIR}/my.cnf.ok" my.cnf
443 667
444 insinto "/etc/conf.d"
445 newins "${FILESDIR}/mysql.conf.d-r1" "mysql"
446 mysql_version_is_at_least "5.00.11.00" \
447 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager"
448
449 # minimal builds don't have the server 668 # Minimal builds don't have the MySQL server
450 if ! useq minimal; then 669 if ! use minimal ; then
451 exeinto /etc/init.d 670 # Empty directories ...
452 newexe "${FILESDIR}/mysql.rc6-r3" "mysql"
453
454 mysql_version_is_at_least "5.00.11.00" \
455 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager"
456 insinto /etc/logrotate.d
457 sed -e "s!___MY_SUFFIX___!${MY_SUFFIX}!g" \
458 "${FILESDIR}/logrotate-slot.mysql" \
459 > "${TMPDIR}/logrotate.mysql"
460 newins "${TMPDIR}/logrotate.mysql" "mysql${MY_SUFFIX}"
461
462 #empty dirs...
463 diropts "-m0750" 671 diropts "-m0750"
464 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 672 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
465 dodir "${DATADIR}" 673 dodir "${MY_DATADIR}"
466 keepdir "${DATADIR}" 674 keepdir "${MY_DATADIR}"
467 chown -R mysql:mysql "${D}/${DATADIR}" 675 chown -R mysql:mysql "${D}/${MY_DATADIR}"
468 fi 676 fi
469 677
470 diropts "-m0755" 678 diropts "-m0755"
471 for folder in "${MY_LOGDIR}" "/var/run/mysqld" ; do 679 for folder in "${MY_LOGDIR}" "/var/run/mysqld" ; do
472 dodir "${folder}" 680 dodir "${folder}"
473 keepdir "${folder}" 681 keepdir "${folder}"
474 chown -R mysql:mysql "${D}/${folder}" 682 chown -R mysql:mysql "${D}/${folder}"
475 done 683 done
476 fi 684 fi
477 685
478 # docs 686 # Docs
479 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 687 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
688 doinfo ${S}/Docs/mysql.info
689
480 # minimal builds don't have the server 690 # Minimal builds don't have the MySQL server
481 if ! useq minimal; then 691 if ! use minimal ; then
482 docinto "support-files" 692 docinto "support-files"
483 for script in \ 693 for script in \
484 support-files/my-*.cnf \ 694 support-files/my-*.cnf \
485 support-files/magic \ 695 support-files/magic \
486 support-files/ndb-config-2-node.ini 696 support-files/ndb-config-2-node.ini
490 700
491 docinto "scripts" 701 docinto "scripts"
492 for script in scripts/mysql* ; do 702 for script in scripts/mysql* ; do
493 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 703 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
494 done 704 done
495 fi
496 705
497 # oops, temporary fix
498 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \
499 && cp -f \
500 "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0" \
501 "${D}/usr/share/mysql${MY_SUFFIX}/fill_help_tables.sql"
502
503 if [[ ${SLOT} -gt 0 ]] ; then
504 # MOVED HERE DUE TO BUG #121445
505 # create a list of files, to be used
506 # by external utilities
507 mkdir -p "${D}/var/lib/eselect/mysql/"
508 local filelist="${D}/var/lib/eselect/mysql/mysql${MY_SUFFIX}.filelist"
509 pushd "${D}/" &>/dev/null
510 find usr/bin/ usr/sbin/ \
511 -type f -name "*${MY_SUFFIX}*" \
512 -and -not -name "mysql_config${MY_SUFFIX}" \
513 > "${filelist}"
514 find usr/share/man \
515 -type f -name "*${MY_SUFFIX}*" \
516 | sed -e 's/$/.gz/' \
517 >> "${filelist}"
518 echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}"
519 echo "${MY_LIBDIR#"/"}" >> "${filelist}"
520 echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}"
521 popd &>/dev/null
522 fi 706 fi
523 707
524 # It's safer portage wis doing this in instal, but we can't 708 mysql_lib_symlinks "${D}"
525 # if it's a slotted install
526 [[ ${SLOT} -eq 0 ]] && ROOT="${D}" mysql_lib_symlinks
527} 709}
528 710
529mysql_pkg_preinst() { 711mysql_pkg_preinst() {
530
531 enewgroup mysql 60 || die "problem adding group mysql" 712 enewgroup mysql 60 || die "problem adding 'mysql' group"
532 enewuser mysql 60 -1 /dev/null mysql \ 713 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
533 || die "problem adding user mysql"
534} 714}
535 715
536mysql_pkg_postinst() { 716mysql_pkg_postinst() {
537 717 # Make sure the vars are correctly initialized
538 mysql_init_vars 718 mysql_init_vars
539 # slotted, manage lib symlinks on the real file-system
540 # to cope with other version installed
541 [[ ${SLOT} -ne 0 ]] && mysql_lib_symlinks
542 719
543 # mind at FEATURES=collision-protect before to remove this 720 # Check FEATURES="collision-protect" before removing this
544 [ -d "${ROOT}/var/log/mysql" ] \
545 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}" 721 [[ -d "${ROOT}/var/log/mysql" ]] || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
546 722
547 #secure the logfiles... does this bother anybody? 723 # Secure the logfiles
548 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 724 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
549 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 725 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
550 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 726 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
551 727
728 # Minimal builds don't have the MySQL server
552 if ! useq minimal; then 729 if ! use minimal ; then
553 if [[ ${SLOT} -gt 0 ]] ; then 730 docinto "support-files"
554 einfo "you may want to read:" 731 for script in \
555 einfo "http://www.gentoo.org/doc/en/mysql-upgrade-slotted.xml" 732 support-files/my-*.cnf \
556 einfo "you may want to run \"eselect mysql list\" followed by a " 733 support-files/magic \
557 einfo "\"eselect mysql set 1\" to choose the default mysql server" 734 support-files/ndb-config-2-node.ini
558 fi 735 do
736 dodoc "${script}"
737 done
559 738
560 # your friendly public service announcement... 739 docinto "scripts"
740 for script in scripts/mysql* ; do
741 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
742 done
743
561 einfo 744 einfo
562 einfo "You might want to run:" 745 elog "You might want to run:"
563 einfo "\"emerge --config =${CATEGORY}/${PF}\"" 746 elog "\"emerge --config =${CATEGORY}/${PF}\""
564 einfo "if this is a new install." 747 elog "if this is a new install."
565 einfo 748 einfo
566 mysql_version_is_at_least "5.01.00.00" \
567 || einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream."
568 fi 749 fi
750
751 if mysql_version_is_at_least "5.1.12" && use pbxt ; then
752 # TODO: explain it better
753 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';"
754 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;"
755 elog "if, after that, you cannot start the MySQL server,"
756 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then"
757 elog "use the MySQL upgrade script to restore the table"
758 elog "or execute the following SQL command:"
759 elog " CREATE TABLE IF NOT EXISTS plugin ("
760 elog " name char(64) binary DEFAULT '' NOT NULL,"
761 elog " dl char(128) DEFAULT '' NOT NULL,"
762 elog " PRIMARY KEY (name)"
763 elog " ) CHARACTER SET utf8 COLLATE utf8_bin;"
764 fi
765
766 mysql_check_version_range "4.0 to 5.0.99.99" \
767 && use berkdb \
768 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
569} 769}
570 770
571mysql_pkg_config() { 771mysql_pkg_config() {
772 # Make sure the vars are correctly initialized
572 mysql_init_vars 773 mysql_init_vars
774
573 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR" 775 [[ -z "${MY_DATADIR}" ]] && die "Sorry, unable to find MY_DATADIR"
574 776
575 if built_with_use dev-db/mysql minimal; then 777 if built_with_use ${CATEGORY}/${PN} minimal ; then
576 die "Minimal builds do NOT include the MySQL server" 778 die "Minimal builds do NOT include the MySQL server"
577 fi 779 fi
578 780
579 local pwd1="a" 781 local pwd1="a"
580 local pwd2="b" 782 local pwd2="b"
581 local maxtry=5 783 local maxtry=5
582 784
583 if [[ -d "${ROOT}/${DATADIR}/mysql" ]] ; then 785 if [[ -d "${ROOT}/${MY_DATADIR}/mysql" ]] ; then
584 ewarn "You have already a MySQL database in place." 786 ewarn "You have already a MySQL database in place."
585 ewarn "(${ROOT}/${DATADIR}/*)" 787 ewarn "(${ROOT}/${MY_DATADIR}/*)"
586 ewarn "Please rename or delete it if you wish to replace it." 788 ewarn "Please rename or delete it if you wish to replace it."
587 die "MySQL database already exists!" 789 die "MySQL database already exists!"
588 fi 790 fi
589 791
590 einfo "Creating the mysql database and setting proper" 792 einfo "Creating the mysql database and setting proper"
591 einfo "permissions on it..." 793 einfo "permissions on it ..."
592 794
593 einfo "Insert a password for the mysql 'root' user" 795 einfo "Insert a password for the mysql 'root' user"
594 ewarn "Avoid [\"'\\_%] characters in the password" 796 ewarn "Avoid [\"'\\_%] characters in the password"
595
596 read -rsp " >" pwd1 ; echo 797 read -rsp " >" pwd1 ; echo
798
597 einfo "Check the password" 799 einfo "Retype the password"
598 read -rsp " >" pwd2 ; echo 800 read -rsp " >" pwd2 ; echo
599 801
600 if [[ "x$pwd1" != "x$pwd2" ]] ; then 802 if [[ "x$pwd1" != "x$pwd2" ]] ; then
601 die "Passwords are not the same" 803 die "Passwords are not the same"
602 fi 804 fi
603 805
604 local options="" 806 local options=""
605 local sqltmp="$(emktemp)" 807 local sqltmp="$(emktemp)"
606 808
607 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql" 809 local help_tables="${ROOT}${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
608 [[ -r "${help_tables}" ]] \ 810 [[ -r "${help_tables}" ]] \
609 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \ 811 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
610 || touch "${TMPDIR}/fill_help_tables.sql" 812 || touch "${TMPDIR}/fill_help_tables.sql"
611 help_tables="${TMPDIR}/fill_help_tables.sql" 813 help_tables="${TMPDIR}/fill_help_tables.sql"
612 814
613 pushd "${TMPDIR}" &>/dev/null 815 pushd "${TMPDIR}" &>/dev/null
614 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR" 816 "${ROOT}/usr/bin/mysql_install_db" | grep -B5 -A999 -i "ERROR"
615 popd &>/dev/null 817 popd &>/dev/null
616 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] || die "MySQL databases not installed" 818 [[ -f "${ROOT}/${MY_DATADIR}/mysql/user.frm" ]] \
819 || die "MySQL databases not installed"
617 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null 820 chown -R mysql:mysql "${ROOT}/${MY_DATADIR}" 2> /dev/null
618 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null 821 chmod 0750 "${ROOT}/${MY_DATADIR}" 2> /dev/null
619 822
620 if mysql_version_is_at_least "4.01.03.00" ; then 823 if mysql_version_is_at_least "4.1.3" ; then
621 options="--skip-ndbcluster" 824 options="--skip-ndbcluster"
622 825
623 # Filling timezones, see 826 # Filling timezones, see
624 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 827 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html
625 ${ROOT}/usr/bin/mysql_tzinfo_to_sql${MY_SUFFIX} ${ROOT}/usr/share/zoneinfo \ 828 "${ROOT}/usr/bin/mysql_tzinfo_to_sql" "${ROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
626 > "${sqltmp}" 2>/dev/null
627 829
628 if [[ -r "${help_tables}" ]] ; then 830 if [[ -r "${help_tables}" ]] ; then
629 cat "${help_tables}" >> "${sqltmp}" 831 cat "${help_tables}" >> "${sqltmp}"
630 fi 832 fi
631 fi 833 fi
632 834
633 local socket=${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock 835 local socket="${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock"
634 local pidfile=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.pid 836 local pidfile="${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid"
635 local mysqld="${ROOT}/usr/sbin/mysqld${MY_SUFFIX} \ 837 local mysqld="${ROOT}/usr/sbin/mysqld \
636 ${options} \ 838 ${options} \
637 --user=mysql \ 839 --user=mysql \
638 --skip-grant-tables \ 840 --skip-grant-tables \
639 --basedir=${ROOT}/usr \ 841 --basedir=${ROOT}/usr \
640 --datadir=${ROOT}/${DATADIR} \ 842 --datadir=${ROOT}/${MY_DATADIR} \
641 --skip-innodb \ 843 --skip-innodb \
642 --skip-bdb \ 844 --skip-bdb \
643 --skip-networking \ 845 --skip-networking \
644 --max_allowed_packet=8M \ 846 --max_allowed_packet=8M \
645 --net_buffer_length=16K \ 847 --net_buffer_length=16K \
646 --socket=${socket} \ 848 --socket=${socket} \
647 --pid-file=${pidfile}" 849 --pid-file=${pidfile}"
648 $mysqld & 850 ${mysqld} &
649 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do 851 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do
650 maxtry=$(($maxtry-1)) 852 maxtry=$((${maxtry}-1))
651 echo -n "." 853 echo -n "."
652 sleep 1 854 sleep 1
653 done 855 done
654 856
655 # do this from memory we don't want clear text password in temp files 857 # Do this from memory, as we don't want clear text passwords in temp files
656 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'" 858 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'"
657 ${ROOT}/usr/bin/mysql${MY_SUFFIX} \ 859 "${ROOT}/usr/bin/mysql" \
658 --socket=${socket} \ 860 --socket=${socket} \
659 -hlocalhost \ 861 -hlocalhost \
660 -e "${sql}" 862 -e "${sql}"
661 863
662 einfo "Loading \"zoneinfo\" this step may require few seconds" 864 einfo "Loading \"zoneinfo\", this step may require a few seconds ..."
663 865
664 ${ROOT}/usr/bin/mysql${MY_SUFFIX} \ 866 "${ROOT}/usr/bin/mysql" \
665 --socket=${socket} \ 867 --socket=${socket} \
666 -hlocalhost \ 868 -hlocalhost \
667 -uroot \ 869 -uroot \
668 -p"${pwd1}" \ 870 -p"${pwd1}" \
669 mysql < "${sqltmp}" 871 mysql < "${sqltmp}"
670 872
671 # server stop and cleanup 873 # Stop the server and cleanup
672 kill $(< "${pidfile}" ) 874 kill $(< "${pidfile}" )
673 rm "${sqltmp}" 875 rm -f "${sqltmp}"
674 einfo "stopping the server," 876 einfo "Stopping the server ..."
675 wait %1 877 wait %1
676 einfo "done" 878 einfo "Done"
677}
678
679mysql_pkg_prerm() {
680 if [[ ${SLOT} -gt 0 ]] ; then
681 # external program
682 eselect mysql slot_remove "${SLOT}"
683 fi
684} 879}
685 880
686mysql_pkg_postrm() { 881mysql_pkg_postrm() {
687 mysql_lib_symlinks 882 : # mysql_lib_symlinks "${D}"
688 if [[ ${SLOT} -gt 0 ]] ; then
689 einfo "you may want to run \"eselect mysql list\" followed by a "
690 einfo "\"eselect mysql list\" to choose the default mysql server"
691 fi
692} 883}

Legend:
Removed from v.1.25  
changed lines
  Added in v.1.82

  ViewVC Help
Powered by ViewVC 1.1.20