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

Diff of /eclass/mysql.eclass

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

Revision 1.1 Revision 1.8
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/Attic/mysql.eclass,v 1.1 2006/01/01 18:45:38 vivo Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/Attic/mysql.eclass,v 1.8 2006/01/24 19:14:00 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
9 9
10#major, minor only in the slot 10#major, minor only in the slot
11SLOT=$(( ${MYSQL_VERSION_ID} / 10000 )) 11SLOT=$(( ${MYSQL_VERSION_ID} / 10000 ))
12 12
13# shorten the path because the socket path length must be shorter than 107 chars 13# 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 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-20051220.tar.bz2" 21 mirror://gentoo/mysql-extras-20060115.tar.bz2"
22
23LICENSE="GPL-2" 22LICENSE="GPL-2"
24KEYWORDS="-*"
25IUSE="big-tables berkdb debug minimal perl selinux ssl static" 23IUSE="big-tables berkdb debug minimal perl selinux srvdir ssl static"
26RESTRICT="primaryuri" 24RESTRICT="primaryuri confcache"
25DEPEND="app-admin/eselect-mysql"
27 26
28mysql_version_is_at_least "4.01.03.00" \ 27mysql_version_is_at_least "4.01.03.00" \
29&& IUSE="${IUSE} cluster utf8 extraengine" 28&& IUSE="${IUSE} cluster extraengine"
30 29
31mysql_version_is_at_least "5.00.18.00" \ 30mysql_version_is_at_least "5.00.18.00" \
32&& IUSE="${IUSE} max-idx-128" 31&& IUSE="${IUSE} max-idx-128"
33 32
34mysql_version_is_at_least "5.01.00.00" \ 33mysql_version_is_at_least "5.01.00.00" \
35&& IUSE="${IUSE} innodb" 34&& IUSE="${IUSE} innodb"
36 35
37EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_postrm 36EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_config 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 "${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="/srv/localhost/mysql/datadir"
63 else
64 DATADIR=`grep ^datadir "${SYSCONFDIR}/my.cnf" | sed -e 's/.*=\s*//'`
65 fi
66 fi
67 fi
68 if [ -z "${DATADIR}" ]; then
69 DATADIR="${MY_LOCALSTATEDIR}"
70 einfo "Using default DATADIR"
71 fi
72 einfo "MySQL DATADIR is ${DATADIR}"
73
74 if [ -z "${PREVIOUS_DATADIR}" ] ; then
75 if [ -a "${DATADIR}" ] ; then
76 ewarn "Previous datadir found, it's YOUR job to change"
77 ewarn "ownership and have care of it"
78 PREVIOUS_DATADIR="yes"
79 export PREVIOUS_DATADIR
80 else
81 PREVIOUS_DATADIR="no"
82 export PREVIOUS_DATADIR
83 fi
84 fi
85 fi
86
87 export MY_SUFFIX MY_SHAREDSTATEDIR MY_SYSCONFDIR
88 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
89 export MY_INCLUDEDIR
90 export DATADIR
91}
38 92
39mysql_pkg_setup() { 93mysql_pkg_setup() {
40 94
41 enewgroup mysql 60 || die "problem adding group mysql" 95 enewgroup mysql 60 || die "problem adding group mysql"
42 enewuser mysql 60 -1 /dev/null mysql \ 96 enewuser mysql 60 -1 /dev/null mysql \
60 die "USEs cluster, extraengine conflicts with \"minimal\"" 114 die "USEs cluster, extraengine conflicts with \"minimal\""
61 fi 115 fi
62 116
63 unpack ${A} || die 117 unpack ${A} || die
64 118
65 mv "${WORKDIR}/${NEWP}" "${S}" 119 mv -f "${WORKDIR}/${NEWP}" "${S}"
66 cd "${S}" 120 cd "${S}"
67 121
68 EPATCH_SUFFIX="patch" 122 EPATCH_SUFFIX="patch"
69 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory" 123 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory"
70 mysql_mv_patches 124 mysql_mv_patches
104 bdbdir='bdb/dist' 158 bdbdir='bdb/dist'
105 fi 159 fi
106 160
107 for d in ${rebuilddirlist}; do 161 for d in ${rebuilddirlist}; do
108 einfo "reconfiguring dir \"${d}\"" 162 einfo "reconfiguring dir \"${d}\""
109 pushd "${d}" 163 pushd "${d}" &>/dev/null
110 for buildstep in \ 164 for buildstep in \
111 'libtoolize --copy --force' \ 165 'libtoolize --copy --force' \
112 'aclocal --force' \ 166 'aclocal --force' \
113 'autoheader --force -Wnone' \ 167 'autoheader --force -Wnone' \
114 'autoconf --force -Wnone' \ 168 'autoconf --force -Wnone' \
116 'gnuconfig_update' 170 'gnuconfig_update'
117 do 171 do
118 einfo "performing ${buildstep}" 172 einfo "performing ${buildstep}"
119 ${buildstep} || die "failed ${buildstep/ */} dir \"${d}\"" 173 ${buildstep} || die "failed ${buildstep/ */} dir \"${d}\""
120 done 174 done
121 popd 175 popd &>/dev/null
122 done 176 done
123 177
124 if ! mysql_check_version_range "5.01.00.00 to 5.01.06.99" ; then 178 if useq berkdb && ! mysql_check_version_range "5.01.00.00 to 5.01.06.99"
179 then
125 [[ -w "${bdbdir}/ltmain.sh" ]] && cp ltmain.sh "${bdbdir}/ltmain.sh" 180 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh"
126 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" 181 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" &>/dev/null
127 popd 182 popd &>/dev/null
128 fi 183 fi
129 184
130} 185}
131 186
132src_compile() { 187mysql_src_compile() {
133 188
134 mysql_init_vars 189 mysql_init_vars
135 local myconf 190 local myconf
136 191
137 if useq static ; then 192 if useq static ; then
190 else 245 else
191 myconf="${myconf} --with-raid" 246 myconf="${myconf} --with-raid"
192 fi 247 fi
193 248
194 if ! mysql_version_is_at_least "5.00.00.00" ; then 249 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 250 if mysql_version_is_at_least "4.01.00.00" ; then
196 myconf="${myconf} --with-charset=utf8" 251 myconf="${myconf} --with-charset=utf8"
197 myconf="${myconf} --with-collation=utf8_general_ci" 252 myconf="${myconf} --with-collation=utf8_general_ci"
198 else 253 else
199 myconf="${myconf} --with-charset=latin1" 254 myconf="${myconf} --with-charset=latin1"
200 myconf="${myconf} --with-collation=latin1_swedish_ci" 255 myconf="${myconf} --with-collation=latin1_swedish_ci"
262 if mysql_version_is_at_least "5.01.00.00" ; then 317 if mysql_version_is_at_least "5.01.00.00" ; then
263 myconf="${myconf} --with-partition" 318 myconf="${myconf} --with-partition"
264 fi 319 fi
265 fi 320 fi
266 321
322 fi
323
267 mysql_version_is_at_least "5.00.18.00" \ 324 mysql_version_is_at_least "5.00.18.00" \
268 && useq "max-idx-128" \ 325 && useq "max-idx-128" \
269 && myconf="${myconf} --with-max-indexes=128" 326 && myconf="${myconf} --with-max-indexes=128"
327
328 if mysql_version_is_at_least "5.01.05.00" ; then
329 myconf="${myconf} --with-row-based-replication"
270 fi 330 fi
271 331
272 #Bug #114895,Bug #110149 332 #Bug #114895,Bug #110149
273 filter-flags "-O" "-O[01]" 333 filter-flags "-O" "-O[01]"
274 #glibc-2.3.2_pre fix; bug #16496 334 #glibc-2.3.2_pre fix; bug #16496
331 binary-configure* my-*.cnf mi_test_all* 391 binary-configure* my-*.cnf mi_test_all*
332 do 392 do
333 rm -f ${D}/usr/share/mysql/${removeme} 393 rm -f ${D}/usr/share/mysql/${removeme}
334 done 394 done
335 395
336 # oops
337 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \
338 && cp "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0.15" "${D}/usr/share/mysql${MY_SUFFIX}/"
339
340 # TODO change at Makefile-am level 396 # TODO change at Makefile-am level
341 for moveme in "mysql_fix_privilege_tables.sql" \ 397 for moveme in "mysql_fix_privilege_tables.sql" \
342 "fill_help_tables.sql" "ndb-config-2-node.ini" 398 "fill_help_tables.sql" "ndb-config-2-node.ini"
343 do 399 do
344 mv "${D}/usr/share/mysql/${moveme}" "${D}/usr/share/mysql${MY_SUFFIX}/" 2>/dev/null 400 mv -f "${D}/usr/share/mysql/${moveme}" "${D}/usr/share/mysql${MY_SUFFIX}/" 2>/dev/null
345 done 401 done
346 402
347 if [[ -n "${MY_SUFFIX}" ]] ; then 403 if [[ -n "${MY_SUFFIX}" ]] ; then
348 local notcatched=$(ls "${D}/usr/share/mysql"/*) 404 local notcatched=$(ls "${D}/usr/share/mysql"/*)
349 if [[ -n "${notcatched}" ]] ; then 405 if [[ -n "${notcatched}" ]] ; then
364 fi 420 fi
365 421
366 # config stuff 422 # config stuff
367 insinto "${MY_SYSCONFDIR}" 423 insinto "${MY_SYSCONFDIR}"
368 doins scripts/mysqlaccess.conf 424 doins scripts/mysqlaccess.conf
369 newins "${FILESDIR}/my.cnf-4.1" my.cnf 425 newins "${FILESDIR}/my.cnf-4.1-r1" my.cnf
370 insinto "/etc/conf.d" 426 insinto "/etc/conf.d"
371 newins "${FILESDIR}/mysql-slot.conf.d-r1" "mysql" 427 newins "${FILESDIR}/mysql-slot.conf.d-r2" "mysql"
372 mysql_version_is_at_least "5.00.11.00" \ 428 mysql_version_is_at_least "5.00.11.00" \
373 && newins "${FILESDIR}/mysqlmanager-slot.conf.d" "mysqlmanager" 429 && newins "${FILESDIR}/mysqlmanager-slot.conf.d" "mysqlmanager"
374 430
375 local charset='utf8'
376 ! useq utf8 && local charset='latin1'
377 sed --in-place \ 431 sed --in-place \
378 -e "s/@MY_SUFFIX@/${MY_SUFFIX}/" \ 432 -e "s/@MY_SUFFIX@/${MY_SUFFIX}/" \
379 -e "s/@CHARSET@/${charset}/" \ 433 -e "s/@DATADIR@/${DATADIR}/" \
380 "${D}/etc/mysql${MY_SUFFIX}/my.cnf" 434 "${D}/etc/mysql${MY_SUFFIX}/my.cnf"
381 435
382 # minimal builds don't have the server 436 # minimal builds don't have the server
383 if ! useq minimal; then 437 if ! useq minimal; then
384 exeinto /etc/init.d 438 exeinto /etc/init.d
385 newexe "${FILESDIR}/mysql-slot.rc6-r1" "mysql" 439 newexe "${FILESDIR}/mysql-slot.rc6-r2" "mysql"
440 [[ ${SLOT} -gt 0 ]] && dosym "/etc/init.d/mysql" "/etc/init.d/mysql${MY_SUFFIX}"
441
386 mysql_version_is_at_least "5.00.11.00" \ 442 mysql_version_is_at_least "5.00.11.00" \
387 && newexe "${FILESDIR}/mysqlmanager-slot.rc6" "mysqlmanager" 443 && newexe "${FILESDIR}/mysqlmanager-slot.rc6" "mysqlmanager"
388 insinto /etc/logrotate.d 444 insinto /etc/logrotate.d
389 # TODO 445 sed -e "s!___MY_SUFFIX___!${MY_SUFFIX}!" \
446 "${FILESDIR}/logrotate-slot.mysql" \
447 > "${TMPDIR}/logrotate.mysql"
390 newins "${FILESDIR}/logrotate.mysql" "mysql${MY_SUFFIX}" 448 newins "${TMPDIR}/logrotate.mysql" "mysql${MY_SUFFIX}"
391 449
392 #empty dirs... 450 #empty dirs...
393 diropts "-m0750" 451 diropts "-m0750"
394 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 452 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
395 dodir "${DATADIR}" 453 dodir "${DATADIR}"
417 do 475 do
418 dodoc "${script}" 476 dodoc "${script}"
419 done 477 done
420 478
421 docinto "scripts" 479 docinto "scripts"
422 for script in \ 480 for script in scripts/mysql* ; do
423 $(ls scripts/mysql* | grep -v '.sh$') 481 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
424 do
425 dodoc "${script}"
426 done 482 done
427 fi 483 fi
484
485 # oops, temporary fix
486 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \
487 && cp -f \
488 "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0" \
489 "${D}/usr/share/mysql${MY_SUFFIX}/fill_help_tables.sql"
428} 490}
429 491
430mysql_pkg_preinst() { 492mysql_pkg_preinst() {
431 493
432 enewgroup mysql 60 || die "problem adding group mysql" 494 enewgroup mysql 60 || die "problem adding group mysql"
446 #secure the logfiles... does this bother anybody? 508 #secure the logfiles... does this bother anybody?
447 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 509 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
448 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 510 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
449 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 511 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
450 512
513 # create a list of files, to be used
514 # by external utilities
515 # uncompressed because of the small size
516 local filelist="${ROOT}/var/lib/eselect/mysql/mysql${MY_SUFFIX}"
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}.filelist"
523 echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}.filelist"
524 echo "${MY_LIBDIR#"/"}" >> "${filelist}.filelist"
525 echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}.filelist"
526 popd &>/dev/null
527
451 if ! useq minimal; then 528 if ! useq minimal; then
529 if [[ ${SLOT} -gt 0 ]] ; then
530 if [[ -f "${ROOT}/usr/sbin/mysqld" ]] ; then
531 einfo "you may want to run unmerge any unslotted MySQL versions with "
532 einfo "emerge -C --pretend dev-db/mysql"
533 einfo "emerge -C =dev-db/mysql-X.Y.Z"
534 einfo "After the unmerge run \"eselect myqsl list\" followed by a "
535 einfo "\"eselect myqsl set 1\" to chose the default mysql server"
536 else
537 local tmpres="$( eselect mysql show )"
538 # "like grep -q unset"
539 if [[ "{$tmpres}" == "{$tmpres/unset/}" ]] ; then
540 eselect mysql set 1
541 else
542 einfo "The version of mysql emerged now stils is _NOT_ the default"
543 einfo "you may want to run \"eselect myqsl list\" followed by a "
544 einfo "\"eselect myqsl set 1\" to chose the default mysql server"
545 fi
546 fi
547 fi
548
452 # your friendly public service announcement... 549 # your friendly public service announcement...
453 einfo 550 einfo
454 einfo "You might want to run:" 551 einfo "You might want to run:"
455 einfo "\"emerge --config =${CATEGORY}/${PF}\"" 552 einfo "\"emerge --config =${CATEGORY}/${PF}\""
456 einfo "if this is a new install." 553 einfo "if this is a new install."
457 einfo 554 einfo
458 fi
459
460 einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream." 555 einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream."
556 fi
461} 557}
462 558
463mysql_pkg_config() { 559mysql_pkg_config() {
464 mysql_init_vars 560 mysql_init_vars
465 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR" 561 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR"
494 fi 590 fi
495 591
496 local options="" 592 local options=""
497 local sqltmp="$(emktemp)" 593 local sqltmp="$(emktemp)"
498 594
499 local help_tables="${ROOT}/usr/share/doc/mysql-${PVR}/scripts/fill_help_tables.sql.gz" 595 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
500 [[ -r "${help_tables}" ]] \ 596 [[ -r "${help_tables}" ]] \
501 && zcat "${help_tables}" > "${TMPDIR}/fill_help_tables.sql" \ 597 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
502 || touch "${TMPDIR}/fill_help_tables.sql" 598 || touch "${TMPDIR}/fill_help_tables.sql"
503 help_tables="${TMPDIR}/fill_help_tables.sql" 599 help_tables="${TMPDIR}/fill_help_tables.sql"
504 600
505 pushd "${TMPDIR}" 601 pushd "${TMPDIR}" &>/dev/null
506 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR" 602 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR"
507 popd 603 popd &>/dev/null
508 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] || die "MySQL databases not installed" 604 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] || die "MySQL databases not installed"
509 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null 605 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null
510 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null 606 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null
511 607
512 if mysql_version_is_at_least "4.01.03.00" ; then 608 if mysql_version_is_at_least "4.01.03.00" ; then
568 einfo "done" 664 einfo "done"
569} 665}
570 666
571mysql_pkg_postrm() { 667mysql_pkg_postrm() {
572 mysql_lib_symlinks 668 mysql_lib_symlinks
669 if [[ ${SLOT} -gt 0 ]] ; then
670 einfo "you may want to run \"eselect myqsl list\" followed by a "
671 einfo "\"eselect myqsl list\" to chose the default mysql server"
672 fi
573} 673}

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.8

  ViewVC Help
Powered by ViewVC 1.1.20