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

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

  ViewVC Help
Powered by ViewVC 1.1.20