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

Diff of /eclass/mysql.eclass

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

Revision 1.6 Revision 1.18
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2005 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.6 2006/01/14 19:00:32 vivo Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.18 2006/02/12 14:37:46 vivo Exp $
4 4
5# Author: Francesco Riosa <vivo at gentoo.org> 5# Author: Francesco Riosa <vivo at gentoo.org>
6# Maintainer: Francesco Riosa <vivo at gentoo.org> 6# Maintainer: Francesco Riosa <vivo at gentoo.org>
7 7
8inherit eutils flag-o-matic gnuconfig mysql_fx 8inherit eutils flag-o-matic gnuconfig mysql_fx
14# and we will run a mysql server during test phase 14# and we will run a mysql server during test phase
15S="${WORKDIR}/${PN}" 15S="${WORKDIR}/${PN}"
16 16
17DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" 17DESCRIPTION="A fast, multi-threaded, multi-user SQL database server"
18HOMEPAGE="http://www.mysql.com/" 18HOMEPAGE="http://www.mysql.com/"
19NEWP="${PN}-${PV/_/-}" 19NEWP="${P/_/-}"
20SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${NEWP}.tar.gz 20SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${NEWP}.tar.gz
21 mirror://gentoo/mysql-extras-20060114.tar.bz2" 21 mirror://gentoo/mysql-extras-20060115.tar.bz2"
22LICENSE="GPL-2" 22LICENSE="GPL-2"
23IUSE="big-tables berkdb debug minimal perl selinux ssl static" 23IUSE="big-tables berkdb debug minimal perl selinux srvdir ssl static"
24RESTRICT="primaryuri" 24RESTRICT="primaryuri confcache"
25DEPEND="app-admin/eselect-mysql" 25DEPEND="app-admin/eselect-mysql"
26 26
27mysql_version_is_at_least "4.01.03.00" \ 27mysql_version_is_at_least "4.01.03.00" \
28&& IUSE="${IUSE} cluster utf8 extraengine" 28&& IUSE="${IUSE} cluster extraengine"
29 29
30mysql_version_is_at_least "5.00.18.00" \ 30mysql_version_is_at_least "5.00.18.00" \
31&& IUSE="${IUSE} max-idx-128" 31&& IUSE="${IUSE} max-idx-128"
32 32
33mysql_version_is_at_least "5.01.00.00" \ 33mysql_version_is_at_least "5.01.00.00" \
34&& IUSE="${IUSE} innodb" 34&& IUSE="${IUSE} innodb"
35 35
36EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_config pkg_postrm 36EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_config mysql_pkg_prerm pkg_postrm
37
38# void mysql_init_vars()
39#
40# initialize global variables
41# 2005-11-19 <vivo at gentoo.org>
42mysql_init_vars() {
43
44 if [[ ${SLOT} -eq 0 ]] ; then
45 MY_SUFFIX=""
46 else
47 MY_SUFFIX=${MY_SUFFIX:-"-${SLOT}"}
48 fi
49 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR:-"/usr/share/mysql${MY_SUFFIX}"}
50 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql${MY_SUFFIX}"}
51 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql${MY_SUFFIX}"}
52 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql${MY_SUFFIX}"}
53 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql${MY_SUFFIX}"}
54 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql${MY_SUFFIX}"}
55
56 if [ -z "${DATADIR}" ]; then
57 DATADIR=""
58 if [ -f "${MY_SYSCONFDIR}/my.cnf" ] ; then
59 DATADIR=`"my_print_defaults${MY_SUFFIX}" mysqld 2>/dev/null | sed -ne '/datadir/s|^--datadir=||p' | tail -n1`
60 if [ -z "${DATADIR}" ]; then
61 if useq "srvdir" ; then
62 DATADIR="${ROOT}/srv/localhost/mysql${MY_SUFFIX}/datadir"
63 else
64 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" | sed -e 's/.*=\s*//'`
65 fi
66 fi
67 fi
68 if [ -z "${DATADIR}" ]; then
69 if useq "srvdir" ; then
70 DATADIR="${ROOT}/srv/localhost/mysql${MY_SUFFIX}/datadir"
71 else
72 DATADIR="${MY_LOCALSTATEDIR}"
73 fi
74 einfo "Using default DATADIR"
75 fi
76 einfo "MySQL DATADIR is ${DATADIR}"
77
78 if [ -z "${PREVIOUS_DATADIR}" ] ; then
79 if [ -a "${DATADIR}" ] ; then
80 ewarn "Previous datadir found, it's YOUR job to change"
81 ewarn "ownership and have care of it"
82 PREVIOUS_DATADIR="yes"
83 export PREVIOUS_DATADIR
84 else
85 PREVIOUS_DATADIR="no"
86 export PREVIOUS_DATADIR
87 fi
88 fi
89 fi
90
91 export MY_SUFFIX MY_SHAREDSTATEDIR MY_SYSCONFDIR
92 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
93 export MY_INCLUDEDIR
94 export DATADIR
95}
37 96
38mysql_pkg_setup() { 97mysql_pkg_setup() {
39 98
40 enewgroup mysql 60 || die "problem adding group mysql" 99 enewgroup mysql 60 || die "problem adding group mysql"
41 enewuser mysql 60 -1 /dev/null mysql \ 100 enewuser mysql 60 -1 /dev/null mysql \
118 ${buildstep} || die "failed ${buildstep/ */} dir \"${d}\"" 177 ${buildstep} || die "failed ${buildstep/ */} dir \"${d}\""
119 done 178 done
120 popd &>/dev/null 179 popd &>/dev/null
121 done 180 done
122 181
123 if ! useq bdbdir && ! mysql_check_version_range "5.01.00.00 to 5.01.06.99" 182 if useq berkdb && ! mysql_check_version_range "5.01.00.00 to 5.01.06.99"
124 then 183 then
125 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh" 184 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh"
126 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" &>/dev/null 185 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" &>/dev/null
127 popd &>/dev/null 186 popd &>/dev/null
128 fi 187 fi
190 else 249 else
191 myconf="${myconf} --with-raid" 250 myconf="${myconf} --with-raid"
192 fi 251 fi
193 252
194 if ! mysql_version_is_at_least "5.00.00.00" ; then 253 if ! mysql_version_is_at_least "5.00.00.00" ; then
195 if mysql_version_is_at_least "4.01.00.00" && useq utf8; then 254 if mysql_version_is_at_least "4.01.00.00" ; then
196 myconf="${myconf} --with-charset=utf8" 255 myconf="${myconf} --with-charset=utf8"
197 myconf="${myconf} --with-collation=utf8_general_ci" 256 myconf="${myconf} --with-collation=utf8_general_ci"
198 else 257 else
199 myconf="${myconf} --with-charset=latin1" 258 myconf="${myconf} --with-charset=latin1"
200 myconf="${myconf} --with-collation=latin1_swedish_ci" 259 myconf="${myconf} --with-collation=latin1_swedish_ci"
262 if mysql_version_is_at_least "5.01.00.00" ; then 321 if mysql_version_is_at_least "5.01.00.00" ; then
263 myconf="${myconf} --with-partition" 322 myconf="${myconf} --with-partition"
264 fi 323 fi
265 fi 324 fi
266 325
326 fi
327
267 mysql_version_is_at_least "5.00.18.00" \ 328 mysql_version_is_at_least "5.00.18.00" \
268 && useq "max-idx-128" \ 329 && useq "max-idx-128" \
269 && myconf="${myconf} --with-max-indexes=128" 330 && myconf="${myconf} --with-max-indexes=128"
331
332 if mysql_version_is_at_least "5.01.05.00" ; then
333 myconf="${myconf} --with-row-based-replication"
270 fi 334 fi
271 335
272 #Bug #114895,Bug #110149 336 #Bug #114895,Bug #110149
273 filter-flags "-O" "-O[01]" 337 filter-flags "-O" "-O[01]"
274 #glibc-2.3.2_pre fix; bug #16496 338 #glibc-2.3.2_pre fix; bug #16496
293 --enable-local-infile \ 357 --enable-local-infile \
294 --with-mysqld-user=mysql \ 358 --with-mysqld-user=mysql \
295 --with-client-ldflags=-lstdc++ \ 359 --with-client-ldflags=-lstdc++ \
296 --enable-thread-safe-client \ 360 --enable-thread-safe-client \
297 --with-comment="Gentoo Linux ${PF}" \ 361 --with-comment="Gentoo Linux ${PF}" \
298 --with-unix-socket-path="/var/run/mysqld/mysqld${MY_SUFFIX}.sock" \ 362 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
299 --with-zlib-dir=/usr \ 363 --with-zlib-dir=/usr \
300 --with-lib-ccflags="-fPIC" \ 364 --with-lib-ccflags="-fPIC" \
301 --without-readline \ 365 --without-readline \
302 --without-docs \ 366 --without-docs \
303 ${myconf} || die "bad ./configure" 367 ${myconf} || die "bad ./configure"
360 fi 424 fi
361 425
362 # config stuff 426 # config stuff
363 insinto "${MY_SYSCONFDIR}" 427 insinto "${MY_SYSCONFDIR}"
364 doins scripts/mysqlaccess.conf 428 doins scripts/mysqlaccess.conf
429 sed -e "s!@MY_SUFFIX@!${MY_SUFFIX}!g" \
430 -e "s!@DATADIR@!${DATADIR}!g" \
431 "${FILESDIR}/my.cnf-4.1-r1" \
432 > "${TMPDIR}/my.cnf.ok"
365 newins "${FILESDIR}/my.cnf-4.1" my.cnf 433 newins "${TMPDIR}/my.cnf.ok" my.cnf
434
366 insinto "/etc/conf.d" 435 insinto "/etc/conf.d"
367 newins "${FILESDIR}/mysql-slot.conf.d-r2" "mysql" 436 newins "${FILESDIR}/mysql-slot.conf.d-r1" "mysql"
368 mysql_version_is_at_least "5.00.11.00" \ 437 mysql_version_is_at_least "5.00.11.00" \
369 && newins "${FILESDIR}/mysqlmanager-slot.conf.d" "mysqlmanager" 438 && newins "${FILESDIR}/mysqlmanager-slot.conf.d" "mysqlmanager"
370
371 local charset='utf8'
372 ! useq utf8 && local charset='latin1'
373 sed --in-place \
374 -e "s/@MY_SUFFIX@/${MY_SUFFIX}/" \
375 -e "s/@CHARSET@/${charset}/" \
376 "${D}/etc/mysql${MY_SUFFIX}/my.cnf"
377 439
378 # minimal builds don't have the server 440 # minimal builds don't have the server
379 if ! useq minimal; then 441 if ! useq minimal; then
380 exeinto /etc/init.d 442 exeinto /etc/init.d
381 newexe "${FILESDIR}/mysql-slot.rc6-r2" "mysql" 443 newexe "${FILESDIR}/mysql-slot.rc6-r3" "mysql"
382 [[ ${SLOT} -gt 0 ]] && dosym "/etc/init.d/mysql" "/etc/init.d/mysql${MY_SUFFIX}"
383 444
384 mysql_version_is_at_least "5.00.11.00" \ 445 mysql_version_is_at_least "5.00.11.00" \
385 && newexe "${FILESDIR}/mysqlmanager-slot.rc6" "mysqlmanager" 446 && newexe "${FILESDIR}/mysqlmanager-slot.rc6" "mysqlmanager"
386 insinto /etc/logrotate.d 447 insinto /etc/logrotate.d
387 # TODO 448 sed -e "s!___MY_SUFFIX___!${MY_SUFFIX}!g" \
449 "${FILESDIR}/logrotate-slot.mysql" \
450 > "${TMPDIR}/logrotate.mysql"
388 newins "${FILESDIR}/logrotate.mysql" "mysql${MY_SUFFIX}" 451 newins "${TMPDIR}/logrotate.mysql" "mysql${MY_SUFFIX}"
389 452
390 #empty dirs... 453 #empty dirs...
391 diropts "-m0750" 454 diropts "-m0750"
392 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 455 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
393 dodir "${DATADIR}" 456 dodir "${DATADIR}"
425 # oops, temporary fix 488 # oops, temporary fix
426 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \ 489 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \
427 && cp -f \ 490 && cp -f \
428 "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0" \ 491 "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0" \
429 "${D}/usr/share/mysql${MY_SUFFIX}/fill_help_tables.sql" 492 "${D}/usr/share/mysql${MY_SUFFIX}/fill_help_tables.sql"
493
494 # MOVED HERE DUE TO BUG #121445
495 # create a list of files, to be used
496 # by external utilities
497 mkdir -p "${D}/var/lib/eselect/mysql/"
498 local filelist="${D}/var/lib/eselect/mysql/mysql${MY_SUFFIX}.filelist"
499 pushd "${D}/" &>/dev/null
500 env -i find usr/bin/ usr/sbin/ usr/share/man \
501 -type f -name "*${MY_SUFFIX}*" \
502 -and -not -name "mysql_config${MY_SUFFIX}" \
503 > "${filelist}"
504 echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}"
505 echo "${MY_LIBDIR#"/"}" >> "${filelist}"
506 echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}"
507 popd &>/dev/null
508
430} 509}
431 510
432mysql_pkg_preinst() { 511mysql_pkg_preinst() {
512
513 ## create a list of files, to be used
514 ## by external utilities
515 ## will be used in pkg_postinst
516 #local filelist="${TMPDIR}/FILELIST"
517 #pushd "${D}/" &>/dev/null
518 # mkdir -p "${ROOT}/var/lib/eselect/mysql/"
519 # env -i find usr/bin/ usr/sbin/ usr/share/man \
520 # -type f -name "*${MY_SUFFIX}*" \
521 # -and -not -name "mysql_config${MY_SUFFIX}" \
522 # > "${filelist}"
523 # echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}"
524 # echo "${MY_LIBDIR#"/"}" >> "${filelist}"
525 # echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}"
526 #popd &>/dev/null
433 527
434 enewgroup mysql 60 || die "problem adding group mysql" 528 enewgroup mysql 60 || die "problem adding group mysql"
435 enewuser mysql 60 -1 /dev/null mysql \ 529 enewuser mysql 60 -1 /dev/null mysql \
436 || die "problem adding user mysql" 530 || die "problem adding user mysql"
437} 531}
448 #secure the logfiles... does this bother anybody? 542 #secure the logfiles... does this bother anybody?
449 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 543 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
450 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 544 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
451 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 545 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
452 546
453 # create a list of files, to be used 547 ## list of files, to be used
454 # by external utilities 548 ## by external utilities
455 # uncompressed because of the small size
456 local filelist="${ROOT}/var/lib/eselect/mysql/mysql${MY_SUFFIX}"
457 pushd "${D}/" &>/dev/null
458 mkdir -p "${ROOT}/var/lib/eselect/mysql/" 549 #mkdir -p "${ROOT}/var/lib/eselect/mysql/"
459 env -i find usr/bin/ usr/sbin/ usr/share/man \ 550 #cp "${TMPDIR}/FILELIST" "${ROOT}/var/lib/eselect/mysql/mysql${MY_SUFFIX}.filelist"
460 -type f -name "*${MY_SUFFIX}*" \
461 -and -not -name "mysql_config${MY_SUFFIX}" \
462 > "${filelist}.filelist"
463 echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}.filelist"
464 echo "${MY_LIBDIR#"/"}" >> "${filelist}.filelist"
465 echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}.filelist"
466 popd &>/dev/null
467 551
468 if ! useq minimal; then 552 if ! useq minimal; then
469 if [[ ${SLOT} -gt 0 ]] ; then 553 if [[ ${SLOT} -gt 0 ]] ; then
470 if [[ -f "${ROOT}/usr/sbin/mysqld" ]] ; then 554 #if [[ -f "${ROOT}/usr/sbin/mysqld" ]] ; then
471 einfo "you may want to run unmerge any unslotted MySQL versions with " 555 einfo "you may want to read:"
472 einfo "emerge -C --pretend dev-db/mysql" 556 einfo "http://www.gentoo.org/doc/en/mysql-upgrade-slotted.xml"
473 einfo "emerge -C =dev-db/mysql-X.Y.Z"
474 einfo "After the unmerge run \"eselect myqsl list\" followed by a "
475 einfo "\"eselect myqsl set 1\" to chose the default mysql server"
476 else 557 #else
477 local tmpres="$( eselect mysql show )" 558 # local tmpres="$( eselect mysql show )"
478 # "like grep -q unset" 559 # # "like grep -q unset"
479 if [[ "{$tmpres}" == "{$tmpres/unset/}" ]] ; then 560 # if [[ "{$tmpres}" == "{$tmpres/unset/}" ]] ; then
480 eselect mysql set 1 561 # eselect mysql set 1
481 else 562 # else
482 einfo "The version of mysql emerged now stils is _NOT_ the default" 563 # einfo "The version of mysql emerged now stils is _NOT_ the default"
483 einfo "you may want to run \"eselect myqsl list\" followed by a " 564 einfo "you may want to run \"eselect mysql list\" followed by a "
484 einfo "\"eselect myqsl set 1\" to chose the default mysql server" 565 einfo "\"eselect mysql set 1\" to choose the default mysql server"
485 fi 566 # fi
486 fi 567 #fi
487 fi 568 fi
488 569
489 # your friendly public service announcement... 570 # your friendly public service announcement...
490 einfo 571 einfo
491 einfo "You might want to run:" 572 einfo "You might want to run:"
530 fi 611 fi
531 612
532 local options="" 613 local options=""
533 local sqltmp="$(emktemp)" 614 local sqltmp="$(emktemp)"
534 615
535 local help_tables="${ROOT}/usr/share/doc/mysql-${PVR}/scripts/fill_help_tables.sql.gz" 616 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
536 [[ -r "${help_tables}" ]] \ 617 [[ -r "${help_tables}" ]] \
537 && zcat "${help_tables}" > "${TMPDIR}/fill_help_tables.sql" \ 618 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
538 || touch "${TMPDIR}/fill_help_tables.sql" 619 || touch "${TMPDIR}/fill_help_tables.sql"
539 help_tables="${TMPDIR}/fill_help_tables.sql" 620 help_tables="${TMPDIR}/fill_help_tables.sql"
540 621
541 pushd "${TMPDIR}" &>/dev/null 622 pushd "${TMPDIR}" &>/dev/null
542 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR" 623 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR"
556 if [[ -r "${help_tables}" ]] ; then 637 if [[ -r "${help_tables}" ]] ; then
557 cat "${help_tables}" >> "${sqltmp}" 638 cat "${help_tables}" >> "${sqltmp}"
558 fi 639 fi
559 fi 640 fi
560 641
561 local socket=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.sock 642 local socket=${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock
562 local pidfile=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.sock 643 local pidfile=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.pid
563 local mysqld="${ROOT}/usr/sbin/mysqld${MY_SUFFIX} \ 644 local mysqld="${ROOT}/usr/sbin/mysqld${MY_SUFFIX} \
564 ${options} \ 645 ${options} \
565 --user=mysql \ 646 --user=mysql \
566 --skip-grant-tables \ 647 --skip-grant-tables \
567 --basedir=${ROOT}/usr \ 648 --basedir=${ROOT}/usr \
602 einfo "stopping the server," 683 einfo "stopping the server,"
603 wait %1 684 wait %1
604 einfo "done" 685 einfo "done"
605} 686}
606 687
688mysql_pkg_prerm() {
689 # external program
690 eselect mysql slot_remove "${SLOT}"
691}
692
607mysql_pkg_postrm() { 693mysql_pkg_postrm() {
608 mysql_lib_symlinks 694 mysql_lib_symlinks
609 if [[ ${SLOT} -gt 0 ]] ; then 695 if [[ ${SLOT} -gt 0 ]] ; then
610 einfo "you may want to run \"eselect myqsl list\" followed by a " 696 einfo "you may want to run \"eselect mysql list\" followed by a "
611 einfo "\"eselect myqsl list\" to chose the default mysql server" 697 einfo "\"eselect mysql list\" to choose the default mysql server"
612 fi 698 fi
613} 699}

Legend:
Removed from v.1.6  
changed lines
  Added in v.1.18

  ViewVC Help
Powered by ViewVC 1.1.20