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

Diff of /eclass/mysql.eclass

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

Revision 1.127 Revision 1.136
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2009 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.127 2010/02/01 01:07:08 robbat2 Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/Attic/mysql.eclass,v 1.136 2010/03/09 20:37:34 robbat2 Exp $
4 4
5# @ECLASS: mysql.eclass 5# @ECLASS: mysql.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Author: Francesco Riosa (Retired) <vivo@gentoo.org> 7# Author: Francesco Riosa (Retired) <vivo@gentoo.org>
8# Maintainers: MySQL Team <mysql-bugs@gentoo.org> 8# Maintainers: MySQL Team <mysql-bugs@gentoo.org>
83 MYSQL_COMMUNITY_FEATURES=1 83 MYSQL_COMMUNITY_FEATURES=1
84elif [ "${PV#5.0}" != "${PV}" ] && mysql_version_is_at_least "5.0.82"; then 84elif [ "${PV#5.0}" != "${PV}" ] && mysql_version_is_at_least "5.0.82"; then
85 MYSQL_COMMUNITY_FEATURES=1 85 MYSQL_COMMUNITY_FEATURES=1
86elif [ "${PV#5.1}" != "${PV}" ] && mysql_version_is_at_least "5.1.28"; then 86elif [ "${PV#5.1}" != "${PV}" ] && mysql_version_is_at_least "5.1.28"; then
87 MYSQL_COMMUNITY_FEATURES=1 87 MYSQL_COMMUNITY_FEATURES=1
88elif [ "${PV#5.4}" != "${PV}" ]; then 88elif [ "${PV#5.4}" != "${PV}" ] ; then
89 MYSQL_COMMUNITY_FEATURES=1
90elif [ "${PV#5.5}" != "${PV}" ] ; then
91 MYSQL_COMMUNITY_FEATURES=1
92elif [ "${PV#6.0}" != "${PV}" ] ; then
89 MYSQL_COMMUNITY_FEATURES=1 93 MYSQL_COMMUNITY_FEATURES=1
90else 94else
91 MYSQL_COMMUNITY_FEATURES=0 95 MYSQL_COMMUNITY_FEATURES=0
92fi 96fi
93 97
134# For other stuff to bring us in 138# For other stuff to bring us in
135PDEPEND="${PDEPEND} =virtual/mysql-$(get_version_component_range 1-2 ${PV})" 139PDEPEND="${PDEPEND} =virtual/mysql-$(get_version_component_range 1-2 ${PV})"
136 140
137# Work out the default SERVER_URI correctly 141# Work out the default SERVER_URI correctly
138if [ -z "${SERVER_URI}" ]; then 142if [ -z "${SERVER_URI}" ]; then
143 [ -z "${MY_PV}" ] && MY_PV="${PV//_/-}"
139 # The community build is on the mirrors 144 # The community build is on the mirrors
140 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then 145 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
141 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${PV//_/-}.tar.gz" 146 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${MY_PV}.tar.gz"
142 # The (old) enterprise source is on the primary site only 147 # The (old) enterprise source is on the primary site only
143 elif [ "${PN}" == "mysql" ]; then 148 elif [ "${PN}" == "mysql" ]; then
144 SERVER_URI="ftp://ftp.mysql.com/pub/mysql/src/mysql-${PV//_/-}.tar.gz" 149 SERVER_URI="ftp://ftp.mysql.com/pub/mysql/src/mysql-${MY_PV}.tar.gz"
145 fi 150 fi
146fi 151fi
147 152
148# Define correct SRC_URIs 153# Define correct SRC_URIs
149SRC_URI="${SERVER_URI}" 154SRC_URI="${SERVER_URI}"
153&& SRC_URI="${SRC_URI} 158&& SRC_URI="${SRC_URI}
154 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 159 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
155 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 160 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
156 http://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2" 161 http://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
157 162
163DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
164HOMEPAGE="http://www.mysql.com/"
165LICENSE="GPL-2"
166SLOT="0"
167IUSE="big-tables debug embedded minimal ${IUSE_DEFAULT_ON}perl selinux ssl static test"
168
169mysql_version_is_at_least "4.1" \
170&& IUSE="${IUSE} latin1"
171
172mysql_version_is_at_least "4.1.3" \
173&& IUSE="${IUSE} cluster extraengine"
174
175mysql_version_is_at_least "5.0" \
176|| IUSE="${IUSE} raid"
177
178mysql_version_is_at_least "5.0.18" \
179&& IUSE="${IUSE} max-idx-128"
180
181mysql_version_is_at_least "5.1" \
182|| IUSE="${IUSE} berkdb"
183
184[ "${MYSQL_COMMUNITY_FEATURES}" == "1" ] \
185&& IUSE="${IUSE} ${IUSE_DEFAULT_ON}community profiling"
186
158# PBXT engine 187# PBXT engine
159mysql_version_is_at_least "5.1.12" \ 188mysql_version_is_at_least "5.1.12" \
160&& [[ -n "${PBXT_VERSION}" ]] \ 189&& [[ -n "${PBXT_VERSION}" ]] \
161&& PBXT_P="pbxt-${PBXT_VERSION}" \ 190&& PBXT_P="pbxt-${PBXT_VERSION}" \
162&& PBXT_SRC_URI="mirror://sourceforge/pbxt/${PBXT_P}.tar.gz" \ 191&& PBXT_SRC_URI="http://www.primebase.org/download/${PBXT_P}.tar.gz mirror://sourceforge/pbxt/${PBXT_P}.tar.gz" \
163&& SRC_URI="${SRC_URI} pbxt? ( ${PBXT_SRC_URI} )" 192&& SRC_URI="${SRC_URI} pbxt? ( ${PBXT_SRC_URI} )" \
193&& IUSE="${IUSE} pbxt"
164 194
165# Get the percona tarball if XTRADB_VER and PERCONA_VER are both set 195# Get the percona tarball if XTRADB_VER and PERCONA_VER are both set
166mysql_version_is_at_least "5.1.26" \ 196mysql_version_is_at_least "5.1.26" \
167&& [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \ 197&& [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \
168&& XTRADB_P="percona-xtradb-${XTRADB_VER}" \ 198&& XTRADB_P="percona-xtradb-${XTRADB_VER}" \
199&& XTRADB_SRC_URI_COMMON="${PERCONA_VER}/source/${XTRADB_P}.tar.gz" \
200&& XTRADB_SRC_URI1="http://www.percona.com/percona-builds/xtradb/${XTRADB_SRC_URI_COMMON}" \
169&& XTRADB_SRC_URI="http://www.percona.com/${PN}/xtradb/${PERCONA_VER}/source/${XTRADB_P}.tar.gz" \ 201&& XTRADB_SRC_URI2="http://www.percona.com/${PN}/xtradb/${XTRADB_SRC_URI_COMMON}" \
170&& SRC_URI="${SRC_URI} xtradb? ( ${XTRADB_SRC_URI} )" 202&& SRC_URI="${SRC_URI} xtradb? ( ${XTRADB_SRC_URI1} ${XTRADB_SRC_URI2} )" \
171
172DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
173HOMEPAGE="http://www.mysql.com/"
174LICENSE="GPL-2"
175SLOT="0"
176IUSE="big-tables debug embedded minimal ${IUSE_DEFAULT_ON}perl selinux ssl static"
177
178mysql_version_is_at_least "4.1" \
179&& IUSE="${IUSE} latin1"
180
181mysql_version_is_at_least "4.1.3" \
182&& IUSE="${IUSE} cluster extraengine"
183
184mysql_version_is_at_least "5.0" \
185|| IUSE="${IUSE} raid"
186
187mysql_version_is_at_least "5.0.18" \
188&& IUSE="${IUSE} max-idx-128"
189
190mysql_version_is_at_least "5.1" \
191|| IUSE="${IUSE} berkdb"
192
193mysql_version_is_at_least "5.1.12" \
194&& [[ -n "${PBXT_VERSION}" ]] \
195&& IUSE="${IUSE} pbxt"
196
197mysql_version_is_at_least "5.1.26" \
198&& [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \
199&& IUSE="${IUSE} xtradb" 203&& IUSE="${IUSE} xtradb"
200
201[ "${MYSQL_COMMUNITY_FEATURES}" == "1" ] \
202&& IUSE="${IUSE} ${IUSE_DEFAULT_ON}community profiling"
203 204
204# 205#
205# HELPER FUNCTIONS: 206# HELPER FUNCTIONS:
206# 207#
207 208
215 ewarn "test '${rawtestname}' disabled: '${reason}'" 216 ewarn "test '${rawtestname}' disabled: '${reason}'"
216 217
217 testsuite="${rawtestname/.*}" 218 testsuite="${rawtestname/.*}"
218 testname="${rawtestname/*.}" 219 testname="${rawtestname/*.}"
219 mysql_disable_file="${S}/mysql-test/t/disabled.def" 220 mysql_disable_file="${S}/mysql-test/t/disabled.def"
220 einfo "rawtestname=${rawtestname} testname=${testname} testsuite=${testsuite}" 221 #einfo "rawtestname=${rawtestname} testname=${testname} testsuite=${testsuite}"
221 echo ${testname} : ${reason} >> "${mysql_disable_file}" 222 echo ${testname} : ${reason} >> "${mysql_disable_file}"
222 223
223 # ${S}/mysql-tests/t/disabled.def 224 # ${S}/mysql-tests/t/disabled.def
224 # 225 #
225 # ${S}/mysql-tests/suite/federated/disabled.def 226 # ${S}/mysql-tests/suite/federated/disabled.def
395 myconf="${myconf} $(use_with perl bench)" 396 myconf="${myconf} $(use_with perl bench)"
396 myconf="${myconf} --enable-assembler" 397 myconf="${myconf} --enable-assembler"
397 myconf="${myconf} --with-extra-tools" 398 myconf="${myconf} --with-extra-tools"
398 myconf="${myconf} --with-innodb" 399 myconf="${myconf} --with-innodb"
399 myconf="${myconf} --without-readline" 400 myconf="${myconf} --without-readline"
401 myconf="${myconf} $(use_with ssl openssl)"
400 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)" 402 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)"
401 403
402 # --with-vio is not needed anymore, it's on by default and 404 # --with-vio is not needed anymore, it's on by default and
403 # has been removed from configure 405 # has been removed from configure
406 # Apply to 4.x and 5.0.[0-3]
404 if use ssl ; then 407 if use ssl ; then
405 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio" 408 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio"
406 fi
407
408 if mysql_version_is_at_least "5.1.11" ; then
409 myconf="${myconf} $(use_with ssl)"
410 else
411 myconf="${myconf} $(use_with ssl openssl)"
412 fi 409 fi
413 410
414 if mysql_version_is_at_least "5.0.60" ; then 411 if mysql_version_is_at_least "5.0.60" ; then
415 if use berkdb ; then 412 if use berkdb ; then
416 elog "Berkeley DB support was disabled due to build failures" 413 elog "Berkeley DB support was disabled due to build failures"
473 470
474configure_51() { 471configure_51() {
475 # TODO: !!!! readd --without-readline 472 # TODO: !!!! readd --without-readline
476 # the failure depend upon config/ac-macros/readline.m4 checking into 473 # the failure depend upon config/ac-macros/readline.m4 checking into
477 # readline.h instead of history.h 474 # readline.h instead of history.h
478 myconf="${myconf} $(use_with ssl)" 475 myconf="${myconf} $(use_with ssl ssl /usr)"
479 myconf="${myconf} --enable-assembler" 476 myconf="${myconf} --enable-assembler"
480 myconf="${myconf} --with-geometry" 477 myconf="${myconf} --with-geometry"
481 myconf="${myconf} --with-readline" 478 myconf="${myconf} --with-readline"
482 myconf="${myconf} --with-row-based-replication"
483 myconf="${myconf} --with-zlib=/usr/$(get_libdir)" 479 myconf="${myconf} --with-zlib-dir=/usr/"
484 myconf="${myconf} --without-pstack" 480 myconf="${myconf} --without-pstack"
485 use max-idx-128 && myconf="${myconf} --with-max-indexes=128" 481 use max-idx-128 && myconf="${myconf} --with-max-indexes=128"
482 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
483 myconf="${myconf} $(use_enable community community-features)"
484 if use community; then
485 myconf="${myconf} $(use_enable profiling)"
486 else
487 myconf="${myconf} --disable-profiling"
488 fi
489 fi
486 490
487 # 5.1 introduces a new way to manage storage engines (plugins) 491 # 5.1 introduces a new way to manage storage engines (plugins)
488 # like configuration=none 492 # like configuration=none
489 local plugins="csv,myisam,myisammrg,heap" 493 local plugins="csv,myisam,myisammrg,heap"
490 if use extraengine ; then 494 if use extraengine ; then
491 # like configuration=max-no-ndb, archive and example removed in 5.1.11 495 # like configuration=max-no-ndb, archive and example removed in 5.1.11
496 # not added yet: ibmdb2i
497 # Not supporting as examples: example,daemon_example,ftexample
492 plugins="${plugins},archive,blackhole,example,federated,partition" 498 plugins="${plugins},archive,blackhole,federated,partition"
493 499
494 elog "Before using the Federated storage engine, please be sure to read" 500 elog "Before using the Federated storage engine, please be sure to read"
495 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html" 501 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
496 fi 502 fi
497 503
498 # Upstream specifically requests that InnoDB always be built. 504 # Upstream specifically requests that InnoDB always be built:
499 plugins="${plugins},innobase" 505 # - innobase, innodb_plugin
506 # Build falcon if available for 6.x series.
507 for i in innobase innodb_plugin falcon ; do
508 [ -e "${S}"/storage/${i} ] && plugins="${plugins},${i}"
509 done
500 510
501 # like configuration=max-no-ndb 511 # like configuration=max-no-ndb
502 if use cluster ; then 512 if use cluster ; then
503 plugins="${plugins},ndbcluster" 513 plugins="${plugins},ndbcluster"
504 myconf="${myconf} --with-ndb-binlog" 514 myconf="${myconf} --with-ndb-binlog"
505 fi 515 fi
506 516
507 if mysql_version_is_at_least "5.2" ; then
508 plugins="${plugins},falcon"
509 fi
510
511 myconf="${myconf} --with-plugins=${plugins}" 517 myconf="${myconf} --with-plugins=${plugins}"
518}
519
520xtradb_applicable() {
521 mysql_version_is_at_least "5.1.26" \
522 && [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \
523 && use xtradb
524 return $?
525}
526
527pbxt_applicable() {
528 mysql_version_is_at_least "5.1.12" \
529 && [[ -n "${PBXT_VERSION}" ]] \
530 && use pbxt
531 return $?
512} 532}
513 533
514pbxt_src_configure() { 534pbxt_src_configure() {
515 mysql_init_vars 535 mysql_init_vars
516 536
518 538
519 einfo "Reconfiguring dir '${PWD}'" 539 einfo "Reconfiguring dir '${PWD}'"
520 AT_GNUCONF_UPDATE="yes" eautoreconf 540 AT_GNUCONF_UPDATE="yes" eautoreconf
521 541
522 local myconf="" 542 local myconf=""
523 myconf="${myconf} --with-mysql=${S} --libdir=${D}/${MY_LIBDIR}" 543 myconf="${myconf} --with-mysql=${S} --libdir=${MY_LIBDIR}"
524 use debug && myconf="${myconf} --with-debug=full" 544 use debug && myconf="${myconf} --with-debug=full"
525 # TODO: is it safe/needed to use econf here ? 545 # TODO: is it safe/needed to use econf here ?
526 ./configure ${myconf} || die "Problem configuring PBXT storage engine" 546 ./configure ${myconf} || die "Problem configuring PBXT storage engine"
527} 547}
528 548
538 # TODO: modify test suite for PBXT 558 # TODO: modify test suite for PBXT
539} 559}
540 560
541pbxt_src_install() { 561pbxt_src_install() {
542 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null 562 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
543 make install || die "Failed to install PBXT" 563 emake install DESTDIR="${D}" || die "Failed to install PBXT"
544 popd 564 popd
545} 565}
546 566
547# 567#
548# EBUILD FUNCTIONS 568# EBUILD FUNCTIONS
597 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user" 617 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
598 618
599 mysql_check_version_range "4.0 to 5.0.99.99" \ 619 mysql_check_version_range "4.0 to 5.0.99.99" \
600 && use berkdb \ 620 && use berkdb \
601 && elog "Berkeley DB support is deprecated and will be removed in future versions!" 621 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
622
623 if [ "${PN}" != "mysql-cluster" ] && use cluster; then
624 ewarn "Upstream has noted that the NDB cluster support in the 5.0 and"
625 ewarn "5.1 series should NOT be put into production. In the near"
626 ewarn "future, it will be disabled from building."
627 ewarn ""
628 ewarn "If you need NDB support, you should instead move to the new"
629 ewarn "mysql-cluster package that represents that upstream NDB"
630 ewarn "development."
631 fi
602} 632}
603 633
604# @FUNCTION: mysql_src_unpack 634# @FUNCTION: mysql_src_unpack
605# @DESCRIPTION: 635# @DESCRIPTION:
606# Unpack the source code and call mysql_src_prepare for EAPI < 2. 636# Unpack the source code and call mysql_src_prepare for EAPI < 2.
635 # Now link in right patches 665 # Now link in right patches
636 mysql_mv_patches 666 mysql_mv_patches
637 # And apply 667 # And apply
638 epatch 668 epatch
639 669
670 # last -fPIC fixup, per bug #305873
671 i="${S}"/storage/innodb_plugin/plug.in
672 [ -f "${i}" ] && sed -i -e '/CFLAGS/s,-prefer-non-pic,,g' "${i}"
673
640 # Additional checks, remove bundled zlib 674 # Additional checks, remove bundled zlib
641 rm -f "${S}/zlib/"*.[ch] 675 rm -f "${S}/zlib/"*.[ch]
642 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in" 676 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
643 rm -f "scripts/mysqlbug" 677 rm -f "scripts/mysqlbug"
644 678
657 rm -f "scripts/mysqlbug" 691 rm -f "scripts/mysqlbug"
658 fi 692 fi
659 693
660 local rebuilddirlist d 694 local rebuilddirlist d
661 695
662 if mysql_version_is_at_least "5.1.26" && use xtradb ; then 696 if xtradb_applicable ; then
663 einfo "Replacing InnoDB with Percona XtraDB" 697 einfo "Replacing InnoDB with Percona XtraDB"
664 pushd "${S}"/storage 698 pushd "${S}"/storage
665 i="innobase" 699 i="innobase"
666 o="${WORKDIR}/storage-${i}.mysql-upstream" 700 o="${WORKDIR}/storage-${i}.mysql-upstream"
667 # Have we been here already? 701 # Have we been here already?
668 [ -h "${i}" ] && rm -f "${i}" 702 [ -d "${o}" ] && rm -f "${i}"
669 # Or maybe we haven't 703 # Or maybe we haven't
670 [ -d "${i}" -a ! -d "${o}" ] && mv "${i}" "${o}" 704 [ -d "${i}" -a ! -d "${o}" ] && mv "${i}" "${o}"
671 ln -s "${WORKDIR}/${XTRADB_P}" "${i}" 705 cp -ra "${WORKDIR}/${XTRADB_P}" "${i}"
672 popd 706 popd
673 fi 707 fi
674 708
675 if mysql_version_is_at_least "5.1.12" ; then 709 if mysql_version_is_at_least "5.1.12" ; then
676 einfo "Updating innobase cmake"
677 rebuilddirlist="." 710 rebuilddirlist="."
711 # This does not seem to be needed presently. robbat2 2010/02/23
712 #einfo "Updating innobase cmake"
678 # TODO: check this with a cmake expert 713 ## TODO: check this with a cmake expert
679 cmake \ 714 #cmake \
680 -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \ 715 # -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \
681 -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \ 716 # -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \
682 "storage/innobase" 717 # "storage/innobase"
683 else 718 else
684 rebuilddirlist=". innobase" 719 rebuilddirlist=". innobase"
685 fi 720 fi
686 721
687 for d in ${rebuilddirlist} ; do 722 for d in ${rebuilddirlist} ; do
771 find . -type f -name Makefile -print0 \ 806 find . -type f -name Makefile -print0 \
772 | xargs -0 -n100 sed -i \ 807 | xargs -0 -n100 sed -i \
773 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|' 808 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
774 809
775 if [[ $EAPI == 2 ]]; then 810 if [[ $EAPI == 2 ]]; then
776 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_configure 811 pbxt_applicable && pbxt_src_configure
777 fi 812 fi
778} 813}
779 814
780# @FUNCTION: mysql_src_compile 815# @FUNCTION: mysql_src_compile
781# @DESCRIPTION: 816# @DESCRIPTION:
787 0 | 1) mysql_src_configure ;; 822 0 | 1) mysql_src_configure ;;
788 esac 823 esac
789 824
790 emake || die "emake failed" 825 emake || die "emake failed"
791 826
792 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_compile 827 pbxt_applicable && pbxt_src_compile
793} 828}
794 829
795# @FUNCTION: mysql_src_install 830# @FUNCTION: mysql_src_install
796# @DESCRIPTION: 831# @DESCRIPTION:
797# Install mysql. 832# Install mysql.
798mysql_src_install() { 833mysql_src_install() {
799 # Make sure the vars are correctly initialized 834 # Make sure the vars are correctly initialized
800 mysql_init_vars 835 mysql_init_vars
801 836
802 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed" 837 emake install \
838 DESTDIR="${D}" \
839 benchdir_root="${MY_SHAREDSTATEDIR}" \
840 testroot="${MY_SHAREDSTATEDIR}" \
841 || die "emake install failed"
803 842
804 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_install 843 pbxt_applicable && pbxt_src_install
805 844
806 # Convenience links 845 # Convenience links
807 einfo "Making Convenience links for mysqlcheck multi-call binary" 846 einfo "Making Convenience links for mysqlcheck multi-call binary"
808 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze" 847 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
809 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair" 848 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
813 einfo "Removing duplicate /usr/share/mysql files" 852 einfo "Removing duplicate /usr/share/mysql files"
814 rm -Rf "${D}/usr/share/info" 853 rm -Rf "${D}/usr/share/info"
815 for removeme in "mysql-log-rotate" mysql.server* \ 854 for removeme in "mysql-log-rotate" mysql.server* \
816 binary-configure* my-*.cnf mi_test_all* 855 binary-configure* my-*.cnf mi_test_all*
817 do 856 do
818 rm -f "${D}"/usr/share/mysql/${removeme} 857 rm -f "${D}"/${MY_SHAREDSTATEDIR}/${removeme}
819 done 858 done
820 859
821 # Clean up stuff for a minimal build 860 # Clean up stuff for a minimal build
822 if use minimal ; then 861 if use minimal ; then
823 einfo "Remove all extra content for minimal build" 862 einfo "Remove all extra content for minimal build"
824 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench} 863 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
825 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} 864 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}
826 rm -f "${D}/usr/sbin/mysqld" 865 rm -f "${D}/usr/sbin/mysqld"
827 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a 866 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
867 fi
868
869 # Unless they explicitly specific USE=test, then do not install the
870 # testsuite. It DOES have a use to be installed, esp. when you want to do a
871 # validation of your database configuration after tuning it.
872 if use !test ; then
873 rm -rf "${D}"/${MY_SHAREDSTATEDIR}/mysql-test
828 fi 874 fi
829 875
830 # Configuration stuff 876 # Configuration stuff
831 if mysql_version_is_at_least "4.1" ; then 877 if mysql_version_is_at_least "4.1" ; then
832 mysql_mycnf_version="4.1" 878 mysql_mycnf_version="4.1"
863 done 909 done
864 fi 910 fi
865 911
866 # Docs 912 # Docs
867 einfo "Installing docs" 913 einfo "Installing docs"
868 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 914 dodoc README ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
869 doinfo "${S}"/Docs/mysql.info 915 doinfo "${S}"/Docs/mysql.info
870 916
871 # Minimal builds don't have the MySQL server 917 # Minimal builds don't have the MySQL server
872 if ! use minimal ; then 918 if ! use minimal ; then
873 einfo "Including support files and sample configurations" 919 einfo "Including support files and sample configurations"
875 for script in \ 921 for script in \
876 "${S}"/support-files/my-*.cnf \ 922 "${S}"/support-files/my-*.cnf \
877 "${S}"/support-files/magic \ 923 "${S}"/support-files/magic \
878 "${S}"/support-files/ndb-config-2-node.ini 924 "${S}"/support-files/ndb-config-2-node.ini
879 do 925 do
880 dodoc "${script}" 926 [[ -f "$script" ]] && dodoc "${script}"
881 done 927 done
882 928
883 docinto "scripts" 929 docinto "scripts"
884 for script in "${S}"/scripts/mysql* ; do 930 for script in "${S}"/scripts/mysql* ; do
885 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 931 [[ -f "$script" ]] && [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
886 done 932 done
887 933
888 fi 934 fi
889 935
890 mysql_lib_symlinks "${D}" 936 mysql_lib_symlinks "${D}"
939 elog "\"emerge --config =${CATEGORY}/${PF}\"" 985 elog "\"emerge --config =${CATEGORY}/${PF}\""
940 elog "if this is a new install." 986 elog "if this is a new install."
941 einfo 987 einfo
942 fi 988 fi
943 989
944 if mysql_version_is_at_least "5.1.12" && use pbxt ; then 990 if pbxt_applicable ; then
945 # TODO: explain it better 991 # TODO: explain it better
946 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';" 992 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';"
947 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;" 993 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;"
948 elog "if, after that, you cannot start the MySQL server," 994 elog "if, after that, you cannot start the MySQL server,"
949 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then" 995 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then"

Legend:
Removed from v.1.127  
changed lines
  Added in v.1.136

  ViewVC Help
Powered by ViewVC 1.1.20