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

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

  ViewVC Help
Powered by ViewVC 1.1.20