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

Diff of /eclass/mysql.eclass

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

Revision 1.133 Revision 1.137
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.133 2010/02/21 00:18:16 robbat2 Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/Attic/mysql.eclass,v 1.137 2010/03/15 18:50:43 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>
51 ;; 51 ;;
52 *) 52 *)
53 die "Unsupported EAPI: ${EAPI}" ;; 53 die "Unsupported EAPI: ${EAPI}" ;;
54esac 54esac
55 55
56
57# @ECLASS-VARIABLE: MYSQL_PV_MAJOR
58# @DESCRIPTION:
59# Upstream MySQL considers the first two parts of the version number to be the
60# major version. Upgrades that change major version should always run
61# mysql_upgrade.
62MYSQL_PV_MAJOR="$(get_version_component_range 1-2 ${PV})"
63
56# @ECLASS-VARIABLE: MYSQL_VERSION_ID 64# @ECLASS-VARIABLE: MYSQL_VERSION_ID
57# @DESCRIPTION: 65# @DESCRIPTION:
58# MYSQL_VERSION_ID will be: 66# MYSQL_VERSION_ID will be:
59# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99] 67# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99]
60# This is an important part, because many of the choices the MySQL ebuild will do 68# This is an important part, because many of the choices the MySQL ebuild will do
77# @DESCRIPTION: 85# @DESCRIPTION:
78# Specifiy if community features are available. Possible values are 1 (yes) 86# Specifiy if community features are available. Possible values are 1 (yes)
79# and 0 (no). 87# and 0 (no).
80# Community features are available in mysql-community 88# Community features are available in mysql-community
81# AND in the re-merged mysql-5.0.82 and newer 89# AND in the re-merged mysql-5.0.82 and newer
82if [ "${PN}" == "mysql-community" ]; then 90if [ "${PN}" == "mysql-community" -o "${PN}" == "mariadb" ]; then
83 MYSQL_COMMUNITY_FEATURES=1 91 MYSQL_COMMUNITY_FEATURES=1
84elif [ "${PV#5.0}" != "${PV}" ] && mysql_version_is_at_least "5.0.82"; then 92elif [ "${PV#5.0}" != "${PV}" ] && mysql_version_is_at_least "5.0.82"; then
85 MYSQL_COMMUNITY_FEATURES=1 93 MYSQL_COMMUNITY_FEATURES=1
86elif [ "${PV#5.1}" != "${PV}" ] && mysql_version_is_at_least "5.1.28"; then 94elif [ "${PV#5.1}" != "${PV}" ] && mysql_version_is_at_least "5.1.28"; then
87 MYSQL_COMMUNITY_FEATURES=1 95 MYSQL_COMMUNITY_FEATURES=1
112 >=sys-apps/sed-4 120 >=sys-apps/sed-4
113 >=sys-apps/texinfo-4.7-r1 121 >=sys-apps/texinfo-4.7-r1
114 >=sys-libs/readline-4.1 122 >=sys-libs/readline-4.1
115 >=sys-libs/zlib-1.2.3" 123 >=sys-libs/zlib-1.2.3"
116 124
125[[ "${PN}" == "mariadb" ]] \
126&& DEPEND="${DEPEND} libevent? ( >=dev-libs/libevent-1.4 )"
127
117# Having different flavours at the same time is not a good idea 128# Having different flavours at the same time is not a good idea
118for i in "" "-community" ; do 129for i in "mysql" "mysql-community" "mariadb" ; do
119 [[ "${i}" == ${PN#mysql} ]] || 130 [[ "${i}" == ${PN} ]] ||
120 DEPEND="${DEPEND} !dev-db/mysql${i}" 131 DEPEND="${DEPEND} !dev-db/${i}"
121done 132done
122 133
123RDEPEND="${DEPEND} 134RDEPEND="${DEPEND}
124 !minimal? ( dev-db/mysql-init-scripts ) 135 !minimal? ( dev-db/mysql-init-scripts )
125 selinux? ( sec-policy/selinux-mysql )" 136 selinux? ( sec-policy/selinux-mysql )"
134 145
135# dev-perl/DBD-mysql is needed by some scripts installed by MySQL 146# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
136PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )" 147PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
137 148
138# For other stuff to bring us in 149# For other stuff to bring us in
139PDEPEND="${PDEPEND} =virtual/mysql-$(get_version_component_range 1-2 ${PV})" 150PDEPEND="${PDEPEND} =virtual/mysql-${MYSQL_PV_MAJOR}"
140 151
141# Work out the default SERVER_URI correctly 152# Work out the default SERVER_URI correctly
142if [ -z "${SERVER_URI}" ]; then 153if [ -z "${SERVER_URI}" ]; then
143 [ -z "${MY_PV}" ] && MY_PV="${PV//_/-}" 154 [ -z "${MY_PV}" ] && MY_PV="${PV//_/-}"
155 if [ "${PN}" == "mariadb" ]; then
156 MARIA_FULL_PV="$(replace_version_separator 3 '-' ${PV})"
157 SERVER_URI="http://launchpad.net/maria/${MYSQL_PV_MAJOR}/ongoing/+download/mariadb-${MARIA_FULL_PV}.tar.gz"
144 # The community build is on the mirrors 158 # The community build is on the mirrors
145 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then 159 elif [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
146 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${MY_PV}.tar.gz" 160 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${MY_PV}.tar.gz"
147 # The (old) enterprise source is on the primary site only 161 # The (old) enterprise source is on the primary site only
148 elif [ "${PN}" == "mysql" ]; then 162 elif [ "${PN}" == "mysql" ]; then
149 SERVER_URI="ftp://ftp.mysql.com/pub/mysql/src/mysql-${MY_PV}.tar.gz" 163 SERVER_URI="ftp://ftp.mysql.com/pub/mysql/src/mysql-${MY_PV}.tar.gz"
150 fi 164 fi
160 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 174 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
161 http://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2" 175 http://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
162 176
163DESCRIPTION="A fast, multi-threaded, multi-user SQL database server." 177DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
164HOMEPAGE="http://www.mysql.com/" 178HOMEPAGE="http://www.mysql.com/"
179if [[ "${PN}" == "mariadb" ]]; then
180 HOMEPAGE="http://askmonty.org/"
181 DESCRIPTION="MariaDB is a MySQL fork with 3rd-party patches and additional storage engines merged."
182fi
165LICENSE="GPL-2" 183LICENSE="GPL-2"
166SLOT="0" 184SLOT="0"
167IUSE="big-tables debug embedded minimal ${IUSE_DEFAULT_ON}perl selinux ssl static test" 185IUSE="big-tables debug embedded minimal ${IUSE_DEFAULT_ON}perl selinux ssl static test"
168 186
169mysql_version_is_at_least "4.1" \ 187mysql_version_is_at_least "4.1" \
182|| IUSE="${IUSE} berkdb" 200|| IUSE="${IUSE} berkdb"
183 201
184[ "${MYSQL_COMMUNITY_FEATURES}" == "1" ] \ 202[ "${MYSQL_COMMUNITY_FEATURES}" == "1" ] \
185&& IUSE="${IUSE} ${IUSE_DEFAULT_ON}community profiling" 203&& IUSE="${IUSE} ${IUSE_DEFAULT_ON}community profiling"
186 204
187# PBXT engine 205[[ "${PN}" == "mariadb" ]] \
206&& IUSE="${IUSE} libevent"
207
208# MariaDB has integrated PBXT
209# PBXT_VERSION means that we have a PBXT patch for this PV
210# PBXT was only introduced after 5.1.12
211pbxt_patch_available() {
212 [[ "${PN}" != "mariadb" ]] \
188mysql_version_is_at_least "5.1.12" \ 213 && mysql_version_is_at_least "5.1.12" \
189&& [[ -n "${PBXT_VERSION}" ]] \ 214 && [[ -n "${PBXT_VERSION}" ]]
215 return $?
216}
217
218pbxt_available() {
219 pbxt_patch_available || [[ "${PN}" == "mariadb" ]]
220 return $?
221}
222
223# Get the percona tarball if XTRADB_VER and PERCONA_VER are both set
224# MariaDB has integrated XtraDB
225# XTRADB_VERS means that we have a XTRADB patch for this PV
226# XTRADB was only introduced after 5.1.26
227xtradb_patch_available() {
228 [[ "${PN}" != "mariadb" ]] \
229 && mysql_version_is_at_least "5.1.26" \
230 && [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]]
231 return $?
232}
233
234pbxt_patch_available \
190&& PBXT_P="pbxt-${PBXT_VERSION}" \ 235&& PBXT_P="pbxt-${PBXT_VERSION}" \
191&& PBXT_SRC_URI="mirror://sourceforge/pbxt/${PBXT_P}.tar.gz" \ 236&& PBXT_SRC_URI="http://www.primebase.org/download/${PBXT_P}.tar.gz mirror://sourceforge/pbxt/${PBXT_P}.tar.gz" \
192&& SRC_URI="${SRC_URI} pbxt? ( ${PBXT_SRC_URI} )" \ 237&& SRC_URI="${SRC_URI} pbxt? ( ${PBXT_SRC_URI} )" \
238
239pbxt_available \
193&& IUSE="${IUSE} pbxt" 240&& IUSE="${IUSE} pbxt"
194 241
195# Get the percona tarball if XTRADB_VER and PERCONA_VER are both set 242xtradb_patch_available \
196mysql_version_is_at_least "5.1.26" \
197&& [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \
198&& XTRADB_P="percona-xtradb-${XTRADB_VER}" \ 243&& XTRADB_P="percona-xtradb-${XTRADB_VER}" \
244&& XTRADB_SRC_URI_COMMON="${PERCONA_VER}/source/${XTRADB_P}.tar.gz" \
245&& XTRADB_SRC_URI1="http://www.percona.com/percona-builds/xtradb/${XTRADB_SRC_URI_COMMON}" \
199&& XTRADB_SRC_URI="http://www.percona.com/${PN}/xtradb/${PERCONA_VER}/source/${XTRADB_P}.tar.gz" \ 246&& XTRADB_SRC_URI2="http://www.percona.com/${PN}/xtradb/${XTRADB_SRC_URI_COMMON}" \
200&& SRC_URI="${SRC_URI} xtradb? ( ${XTRADB_SRC_URI} )" \ 247&& SRC_URI="${SRC_URI} xtradb? ( ${XTRADB_SRC_URI1} ${XTRADB_SRC_URI2} )" \
201&& IUSE="${IUSE} xtradb" 248&& IUSE="${IUSE} xtradb"
202 249
203# 250#
204# HELPER FUNCTIONS: 251# HELPER FUNCTIONS:
205# 252#
394 myconf="${myconf} $(use_with perl bench)" 441 myconf="${myconf} $(use_with perl bench)"
395 myconf="${myconf} --enable-assembler" 442 myconf="${myconf} --enable-assembler"
396 myconf="${myconf} --with-extra-tools" 443 myconf="${myconf} --with-extra-tools"
397 myconf="${myconf} --with-innodb" 444 myconf="${myconf} --with-innodb"
398 myconf="${myconf} --without-readline" 445 myconf="${myconf} --without-readline"
446 myconf="${myconf} $(use_with ssl openssl)"
399 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)" 447 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)"
400 448
401 # --with-vio is not needed anymore, it's on by default and 449 # --with-vio is not needed anymore, it's on by default and
402 # has been removed from configure 450 # has been removed from configure
451 # Apply to 4.x and 5.0.[0-3]
403 if use ssl ; then 452 if use ssl ; then
404 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio" 453 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio"
405 fi
406
407 if mysql_version_is_at_least "5.1.11" ; then
408 myconf="${myconf} $(use_with ssl)"
409 else
410 myconf="${myconf} $(use_with ssl openssl)"
411 fi 454 fi
412 455
413 if mysql_version_is_at_least "5.0.60" ; then 456 if mysql_version_is_at_least "5.0.60" ; then
414 if use berkdb ; then 457 if use berkdb ; then
415 elog "Berkeley DB support was disabled due to build failures" 458 elog "Berkeley DB support was disabled due to build failures"
472 515
473configure_51() { 516configure_51() {
474 # TODO: !!!! readd --without-readline 517 # TODO: !!!! readd --without-readline
475 # the failure depend upon config/ac-macros/readline.m4 checking into 518 # the failure depend upon config/ac-macros/readline.m4 checking into
476 # readline.h instead of history.h 519 # readline.h instead of history.h
477 myconf="${myconf} $(use_with ssl)" 520 myconf="${myconf} $(use_with ssl ssl /usr)"
478 myconf="${myconf} --enable-assembler" 521 myconf="${myconf} --enable-assembler"
479 myconf="${myconf} --with-geometry" 522 myconf="${myconf} --with-geometry"
480 myconf="${myconf} --with-readline" 523 myconf="${myconf} --with-readline"
481 myconf="${myconf} --with-zlib-dir=/usr/" 524 myconf="${myconf} --with-zlib-dir=/usr/"
482 myconf="${myconf} --without-pstack" 525 myconf="${myconf} --without-pstack"
483 use max-idx-128 && myconf="${myconf} --with-max-indexes=128" 526 use max-idx-128 && myconf="${myconf} --with-max-indexes=128"
527 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
528 myconf="${myconf} $(use_enable community community-features)"
529 if use community; then
530 myconf="${myconf} $(use_enable profiling)"
531 else
532 myconf="${myconf} --disable-profiling"
533 fi
534 fi
484 535
485 # 5.1 introduces a new way to manage storage engines (plugins) 536 # 5.1 introduces a new way to manage storage engines (plugins)
486 # like configuration=none 537 # like configuration=none
487 local plugins="csv,myisam,myisammrg,heap" 538 local plugins="csv,myisam,myisammrg,heap"
488 if use extraengine ; then 539 if use extraengine ; then
489 # like configuration=max-no-ndb, archive and example removed in 5.1.11 540 # like configuration=max-no-ndb, archive and example removed in 5.1.11
490 # not added yet: ibmdb2i 541 # not added yet: ibmdb2i
491 # Not supporting as examples: example,daemon_example,ftexample 542 # Not supporting as examples: example,daemon_example,ftexample
492 plugins="${plugins},archive,blackhole,federated,partition" 543 plugins="${plugins},archive,blackhole,federated,partition"
493 544
545 if [[ "${PN}" != "mariadb" ]] ; then
494 elog "Before using the Federated storage engine, please be sure to read" 546 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" 547 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
548 else
549 elog "MariaDB includes the FederatedX engine. Be sure to read"
550 elog "http://askmonty.org/wiki/index.php/Manual:FederatedX_storage_engine"
551 fi
496 fi 552 fi
497 553
498 # Upstream specifically requests that InnoDB always be built: 554 # Upstream specifically requests that InnoDB always be built:
499 # - innobase, innodb_plugin 555 # - innobase, innodb_plugin
500 # Build falcon if available for 6.x series. 556 # Build falcon if available for 6.x series.
506 if use cluster ; then 562 if use cluster ; then
507 plugins="${plugins},ndbcluster" 563 plugins="${plugins},ndbcluster"
508 myconf="${myconf} --with-ndb-binlog" 564 myconf="${myconf} --with-ndb-binlog"
509 fi 565 fi
510 566
567 if [[ "${PN}" == "mariadb" ]] ; then
568 # In MariaDB, InnoDB is packaged in the xtradb directory, so it's not
569 # caught above.
570 plugins="${plugins},maria,innobase"
571 if use pbxt ; then
572 plugins="${plugins},pbxt"
573 else
574 myconf="${myconf} --without-plugin-pbxt"
575 fi
576 myconf="${myconf} $(use_with libevent)"
577 # This is not optional, without it several upstream testcases fail.
578 # Also strongly recommended by upstream.
579 myconf="${myconf} --with-maria-tmp-tables"
580 fi
581
511 myconf="${myconf} --with-plugins=${plugins}" 582 myconf="${myconf} --with-plugins=${plugins}"
512}
513
514xtradb_applicable() {
515 mysql_version_is_at_least "5.1.26" \
516 && [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \
517 && use xtradb
518 return $?
519}
520
521pbxt_applicable() {
522 mysql_version_is_at_least "5.1.12" \
523 && [[ -n "${PBXT_VERSION}" ]] \
524 && use pbxt
525 return $?
526} 583}
527 584
528pbxt_src_configure() { 585pbxt_src_configure() {
529 mysql_init_vars 586 mysql_init_vars
530 587
532 589
533 einfo "Reconfiguring dir '${PWD}'" 590 einfo "Reconfiguring dir '${PWD}'"
534 AT_GNUCONF_UPDATE="yes" eautoreconf 591 AT_GNUCONF_UPDATE="yes" eautoreconf
535 592
536 local myconf="" 593 local myconf=""
537 myconf="${myconf} --with-mysql=${S} --libdir=${D}/${MY_LIBDIR}" 594 myconf="${myconf} --with-mysql=${S} --libdir=${MY_LIBDIR}"
538 use debug && myconf="${myconf} --with-debug=full" 595 use debug && myconf="${myconf} --with-debug=full"
539 # TODO: is it safe/needed to use econf here ? 596 # TODO: is it safe/needed to use econf here ?
540 ./configure ${myconf} || die "Problem configuring PBXT storage engine" 597 ./configure ${myconf} || die "Problem configuring PBXT storage engine"
541} 598}
542 599
552 # TODO: modify test suite for PBXT 609 # TODO: modify test suite for PBXT
553} 610}
554 611
555pbxt_src_install() { 612pbxt_src_install() {
556 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null 613 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
557 make install || die "Failed to install PBXT" 614 emake install DESTDIR="${D}" || die "Failed to install PBXT"
558 popd 615 popd
559} 616}
560 617
561# 618#
562# EBUILD FUNCTIONS 619# EBUILD FUNCTIONS
685 rm -f "scripts/mysqlbug" 742 rm -f "scripts/mysqlbug"
686 fi 743 fi
687 744
688 local rebuilddirlist d 745 local rebuilddirlist d
689 746
690 if xtradb_applicable ; then 747 if xtradb_patch_available && use xtradb ; then
691 einfo "Replacing InnoDB with Percona XtraDB" 748 einfo "Replacing InnoDB with Percona XtraDB"
692 pushd "${S}"/storage 749 pushd "${S}"/storage
693 i="innobase" 750 i="innobase"
694 o="${WORKDIR}/storage-${i}.mysql-upstream" 751 o="${WORKDIR}/storage-${i}.mysql-upstream"
695 # Have we been here already? 752 # Have we been here already?
696 [ -h "${i}" ] && rm -f "${i}" 753 [ -d "${o}" ] && rm -f "${i}"
697 # Or maybe we haven't 754 # Or maybe we haven't
698 [ -d "${i}" -a ! -d "${o}" ] && mv "${i}" "${o}" 755 [ -d "${i}" -a ! -d "${o}" ] && mv "${i}" "${o}"
699 ln -s "${WORKDIR}/${XTRADB_P}" "${i}" 756 cp -ra "${WORKDIR}/${XTRADB_P}" "${i}"
700 popd 757 popd
701 fi 758 fi
702 759
703 if mysql_version_is_at_least "5.1.12" ; then 760 if mysql_version_is_at_least "5.1.12" ; then
704 einfo "Updating innobase cmake"
705 rebuilddirlist="." 761 rebuilddirlist="."
762 # This does not seem to be needed presently. robbat2 2010/02/23
763 #einfo "Updating innobase cmake"
706 # TODO: check this with a cmake expert 764 ## TODO: check this with a cmake expert
707 cmake \ 765 #cmake \
708 -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \ 766 # -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \
709 -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \ 767 # -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \
710 "storage/innobase" 768 # "storage/innobase"
711 else 769 else
712 rebuilddirlist=". innobase" 770 rebuilddirlist=". innobase"
713 fi 771 fi
714 772
715 for d in ${rebuilddirlist} ; do 773 for d in ${rebuilddirlist} ; do
799 find . -type f -name Makefile -print0 \ 857 find . -type f -name Makefile -print0 \
800 | xargs -0 -n100 sed -i \ 858 | xargs -0 -n100 sed -i \
801 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|' 859 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
802 860
803 if [[ $EAPI == 2 ]]; then 861 if [[ $EAPI == 2 ]]; then
804 pbxt_applicable && pbxt_src_configure 862 pbxt_patch_available && use pbxt && pbxt_src_configure
805 fi 863 fi
806} 864}
807 865
808# @FUNCTION: mysql_src_compile 866# @FUNCTION: mysql_src_compile
809# @DESCRIPTION: 867# @DESCRIPTION:
810# Compile the mysql code. 868# Compile the mysql code.
811mysql_src_compile() { 869mysql_src_compile() {
812 # Be backwards compatible for now 870 # Be backwards compatible for now
813 case ${EAPI:-0} in 871 case ${EAPI:-0} in
814 2) : ;; 872 2) : ;;
815 0 | 1) mysql_src_configure ;; 873 0 | 1) mysql_src_configure ;;
816 esac 874 esac
817 875
818 emake || die "emake failed" 876 emake || die "emake failed"
819 877
820 pbxt_applicable && pbxt_src_compile 878 pbxt_patch_available && use pbxt && pbxt_src_compile
821} 879}
822 880
823# @FUNCTION: mysql_src_install 881# @FUNCTION: mysql_src_install
824# @DESCRIPTION: 882# @DESCRIPTION:
825# Install mysql. 883# Install mysql.
831 DESTDIR="${D}" \ 889 DESTDIR="${D}" \
832 benchdir_root="${MY_SHAREDSTATEDIR}" \ 890 benchdir_root="${MY_SHAREDSTATEDIR}" \
833 testroot="${MY_SHAREDSTATEDIR}" \ 891 testroot="${MY_SHAREDSTATEDIR}" \
834 || die "emake install failed" 892 || die "emake install failed"
835 893
836 pbxt_applicable && pbxt_src_install 894 pbxt_patch_available && use pbxt && pbxt_src_install
837 895
838 # Convenience links 896 # Convenience links
839 einfo "Making Convenience links for mysqlcheck multi-call binary" 897 einfo "Making Convenience links for mysqlcheck multi-call binary"
840 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze" 898 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
841 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair" 899 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
914 for script in \ 972 for script in \
915 "${S}"/support-files/my-*.cnf \ 973 "${S}"/support-files/my-*.cnf \
916 "${S}"/support-files/magic \ 974 "${S}"/support-files/magic \
917 "${S}"/support-files/ndb-config-2-node.ini 975 "${S}"/support-files/ndb-config-2-node.ini
918 do 976 do
919 dodoc "${script}" 977 [[ -f "$script" ]] && dodoc "${script}"
920 done 978 done
921 979
922 docinto "scripts" 980 docinto "scripts"
923 for script in "${S}"/scripts/mysql* ; do 981 for script in "${S}"/scripts/mysql* ; do
924 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 982 [[ -f "$script" ]] && [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
925 done 983 done
926 984
927 fi 985 fi
928 986
929 mysql_lib_symlinks "${D}" 987 mysql_lib_symlinks "${D}"
963 for script in \ 1021 for script in \
964 support-files/my-*.cnf \ 1022 support-files/my-*.cnf \
965 support-files/magic \ 1023 support-files/magic \
966 support-files/ndb-config-2-node.ini 1024 support-files/ndb-config-2-node.ini
967 do 1025 do
1026 [[ -f "${script}" ]] \
968 dodoc "${script}" 1027 && dodoc "${script}"
969 done 1028 done
970 1029
971 docinto "scripts" 1030 docinto "scripts"
972 for script in scripts/mysql* ; do 1031 for script in scripts/mysql* ; do
1032 [[ -f "${script}" ]] \
973 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 1033 && [[ "${script%.sh}" == "${script}" ]] \
1034 && dodoc "${script}"
974 done 1035 done
975 1036
976 einfo 1037 einfo
977 elog "You might want to run:" 1038 elog "You might want to run:"
978 elog "\"emerge --config =${CATEGORY}/${PF}\"" 1039 elog "\"emerge --config =${CATEGORY}/${PF}\""
979 elog "if this is a new install." 1040 elog "if this is a new install."
980 einfo 1041 einfo
981 fi 1042 fi
982 1043
983 if pbxt_applicable ; then 1044 if pbxt_available && use pbxt ; then
984 # TODO: explain it better 1045 # TODO: explain it better
985 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';" 1046 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';"
986 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;" 1047 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;"
987 elog "if, after that, you cannot start the MySQL server," 1048 elog "if, after that, you cannot start the MySQL server,"
988 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then" 1049 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then"

Legend:
Removed from v.1.133  
changed lines
  Added in v.1.137

  ViewVC Help
Powered by ViewVC 1.1.20