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

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

  ViewVC Help
Powered by ViewVC 1.1.20