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

Diff of /eclass/mysql.eclass

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

Revision 1.109 Revision 1.135
1# Copyright 1999-2007 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/mysql.eclass,v 1.109 2009/02/28 10:51:57 robbat2 Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.135 2010/03/03 23:57:13 robbat2 Exp $
4 4
5# @ECLASS: mysql.eclass
6# @MAINTAINER:
5# Author: Francesco Riosa (Retired) <vivo@gentoo.org> 7# Author: Francesco Riosa (Retired) <vivo@gentoo.org>
6# Maintainer: MySQL Team <mysql-bugs@gentoo.org> 8# Maintainers: MySQL Team <mysql-bugs@gentoo.org>
7# - Luca Longinotti <chtekk@gentoo.org> 9# - Luca Longinotti <chtekk@gentoo.org>
8# - Robin H. Johnson <robbat2@gentoo.org> 10# - Robin H. Johnson <robbat2@gentoo.org>
11# @BLURB: This eclass provides most of the functions for mysql ebuilds
12# @DESCRIPTION:
13# The mysql.eclass provides almost all the code to build the mysql ebuilds
14# including the src_unpack, src_prepare, src_configure, src_compile,
15# scr_install, pkg_preinst, pkg_postinst, pkg_config and pkg_postrm
16# phase hooks.
9 17
10WANT_AUTOCONF="latest" 18WANT_AUTOCONF="latest"
11WANT_AUTOMAKE="latest" 19WANT_AUTOMAKE="latest"
12 20
13inherit eutils flag-o-matic gnuconfig autotools mysql_fx versionator 21inherit eutils flag-o-matic gnuconfig autotools mysql_fx versionator toolchain-funcs
14 22
15# Shorten the path because the socket path length must be shorter than 107 chars 23# Shorten the path because the socket path length must be shorter than 107 chars
16# and we will run a mysql server during test phase 24# and we will run a mysql server during test phase
17S="${WORKDIR}/mysql" 25S="${WORKDIR}/mysql"
18 26
21 EGIT_PROJECT=mysql-extras 29 EGIT_PROJECT=mysql-extras
22 EGIT_REPO_URI="git://git.overlays.gentoo.org/proj/mysql-extras.git" 30 EGIT_REPO_URI="git://git.overlays.gentoo.org/proj/mysql-extras.git"
23 inherit git 31 inherit git
24fi 32fi
25 33
34case "${EAPI:-0}" in
35 2)
36 EXPORT_FUNCTIONS pkg_setup \
37 src_unpack src_prepare \
38 src_configure src_compile \
39 src_install \
40 pkg_preinst pkg_postinst \
41 pkg_config pkg_postrm
42 IUSE_DEFAULT_ON='+'
43 ;;
44 0 | 1)
45 EXPORT_FUNCTIONS pkg_setup \
46 src_unpack \
47 src_compile \
48 src_install \
49 pkg_preinst pkg_postinst \
50 pkg_config pkg_postrm
51 ;;
52 *)
53 die "Unsupported EAPI: ${EAPI}" ;;
54esac
55
56# @ECLASS-VARIABLE: MYSQL_VERSION_ID
57# @DESCRIPTION:
26# MYSQL_VERSION_ID will be: 58# MYSQL_VERSION_ID will be:
27# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99] 59# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99]
28# This is an important part, because many of the choices the MySQL ebuild will do 60# This is an important part, because many of the choices the MySQL ebuild will do
29# depend on this variable. 61# depend on this variable.
30# In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803" 62# In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803"
39 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}" 71 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}"
40done 72done
41# strip leading "0" (otherwise it's considered an octal number by BASH) 73# strip leading "0" (otherwise it's considered an octal number by BASH)
42MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"} 74MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"}
43 75
76# @ECLASS-VARIABLE: MYSQL_COMMUNITY_FEATURES
77# @DESCRIPTION:
78# Specifiy if community features are available. Possible values are 1 (yes)
79# and 0 (no).
80# Community features are available in mysql-community
81# AND in the re-merged mysql-5.0.82 and newer
82if [ "${PN}" == "mysql-community" ]; then
83 MYSQL_COMMUNITY_FEATURES=1
84elif [ "${PV#5.0}" != "${PV}" ] && mysql_version_is_at_least "5.0.82"; then
85 MYSQL_COMMUNITY_FEATURES=1
86elif [ "${PV#5.1}" != "${PV}" ] && mysql_version_is_at_least "5.1.28"; then
87 MYSQL_COMMUNITY_FEATURES=1
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
93 MYSQL_COMMUNITY_FEATURES=1
94else
95 MYSQL_COMMUNITY_FEATURES=0
96fi
97
98# @ECLASS-VARIABLE: XTRADB_VER
99# @DESCRIPTION:
100# Version of the XTRADB storage engine
101XTRADB_VER="${XTRADB_VER}"
102
103# @ECLASS-VARIABLE: PERCONA_VER
104# @DESCRIPTION:
105# Designation by PERCONA for a MySQL version to apply an XTRADB release
106PERCONA_VER="${PERCONA_VER}"
107
44# Be warned, *DEPEND are version-dependant 108# Be warned, *DEPEND are version-dependant
45# These are used for both runtime and compiletime 109# These are used for both runtime and compiletime
46DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d ) 110DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d )
47 userland_GNU? ( sys-process/procps ) 111 userland_GNU? ( sys-process/procps )
48 >=sys-apps/sed-4 112 >=sys-apps/sed-4
74# For other stuff to bring us in 138# For other stuff to bring us in
75PDEPEND="${PDEPEND} =virtual/mysql-$(get_version_component_range 1-2 ${PV})" 139PDEPEND="${PDEPEND} =virtual/mysql-$(get_version_component_range 1-2 ${PV})"
76 140
77# Work out the default SERVER_URI correctly 141# Work out the default SERVER_URI correctly
78if [ -z "${SERVER_URI}" ]; then 142if [ -z "${SERVER_URI}" ]; then
143 [ -z "${MY_PV}" ] && MY_PV="${PV//_/-}"
79 # The community build is on the mirrors 144 # The community build is on the mirrors
80 if [ "${PN}" == "mysql-community" ]; then 145 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
81 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${PV//_/-}.tar.gz" 146 SERVER_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/mysql-${MY_PV}.tar.gz"
82 # The enterprise source is on the primary site only 147 # The (old) enterprise source is on the primary site only
83 elif [ "${PN}" == "mysql" ]; then 148 elif [ "${PN}" == "mysql" ]; then
84 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"
85 fi 150 fi
86fi 151fi
87 152
88# Define correct SRC_URIs 153# Define correct SRC_URIs
89SRC_URI="${SERVER_URI}" 154SRC_URI="${SERVER_URI}"
90 155
91[[ ${MY_EXTRAS_VER} != live ]] && SRC_URI="${SRC_URI} 156# Gentoo patches to MySQL
157[[ ${MY_EXTRAS_VER} != live ]] \
158&& SRC_URI="${SRC_URI}
92 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2 159 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
93 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2" 160 http://g3nt8.org/patches/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
94mysql_version_is_at_least "5.1.12" \ 161 http://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
95&& [[ -n "${PBXT_VERSION}" ]] \
96&& SRC_URI="${SRC_URI} pbxt? ( mirror://sourceforge/pbxt/pbxt-${PBXT_VERSION}.tar.gz )"
97 162
98DESCRIPTION="A fast, multi-threaded, multi-user SQL database server." 163DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
99HOMEPAGE="http://www.mysql.com/" 164HOMEPAGE="http://www.mysql.com/"
100LICENSE="GPL-2" 165LICENSE="GPL-2"
101SLOT="0" 166SLOT="0"
102IUSE="big-tables debug embedded minimal perl selinux ssl static" 167IUSE="big-tables debug embedded minimal ${IUSE_DEFAULT_ON}perl selinux ssl static test"
103 168
104mysql_version_is_at_least "4.1" \ 169mysql_version_is_at_least "4.1" \
105&& IUSE="${IUSE} latin1" 170&& IUSE="${IUSE} latin1"
106 171
107mysql_version_is_at_least "4.1.3" \ 172mysql_version_is_at_least "4.1.3" \
114&& IUSE="${IUSE} max-idx-128" 179&& IUSE="${IUSE} max-idx-128"
115 180
116mysql_version_is_at_least "5.1" \ 181mysql_version_is_at_least "5.1" \
117|| IUSE="${IUSE} berkdb" 182|| IUSE="${IUSE} berkdb"
118 183
184[ "${MYSQL_COMMUNITY_FEATURES}" == "1" ] \
185&& IUSE="${IUSE} ${IUSE_DEFAULT_ON}community profiling"
186
187# PBXT engine
119mysql_version_is_at_least "5.1.12" \ 188mysql_version_is_at_least "5.1.12" \
189&& [[ -n "${PBXT_VERSION}" ]] \
190&& PBXT_P="pbxt-${PBXT_VERSION}" \
191&& 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} )" \
120&& IUSE="${IUSE} pbxt" 193&& IUSE="${IUSE} pbxt"
121 194
122EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \ 195# Get the percona tarball if XTRADB_VER and PERCONA_VER are both set
123 pkg_postinst pkg_config pkg_postrm 196mysql_version_is_at_least "5.1.26" \
197&& [[ -n "${XTRADB_VER}" && -n "${PERCONA_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}" \
201&& XTRADB_SRC_URI2="http://www.percona.com/${PN}/xtradb/${XTRADB_SRC_URI_COMMON}" \
202&& SRC_URI="${SRC_URI} xtradb? ( ${XTRADB_SRC_URI1} ${XTRADB_SRC_URI2} )" \
203&& IUSE="${IUSE} xtradb"
124 204
125# 205#
126# HELPER FUNCTIONS: 206# HELPER FUNCTIONS:
127# 207#
128 208
209# @FUNCTION: mysql_disable_test
210# @DESCRIPTION:
211# Helper function to disable specific tests.
129mysql_disable_test() { 212mysql_disable_test() {
213 local rawtestname testname testsuite reason mysql_disable_file
130 local testname="${1}" ; shift 214 rawtestname="${1}" ; shift
131 local reason="${@}" 215 reason="${@}"
216 ewarn "test '${rawtestname}' disabled: '${reason}'"
217
218 testsuite="${rawtestname/.*}"
219 testname="${rawtestname/*.}"
132 local mysql_disable_file="${S}/mysql-test/t/disabled.def" 220 mysql_disable_file="${S}/mysql-test/t/disabled.def"
221 #einfo "rawtestname=${rawtestname} testname=${testname} testsuite=${testsuite}"
133 echo ${testname} : ${reason} >> "${mysql_disable_file}" 222 echo ${testname} : ${reason} >> "${mysql_disable_file}"
134 ewarn "test '${testname}' disabled: '${reason}'"
135}
136 223
224 # ${S}/mysql-tests/t/disabled.def
225 #
226 # ${S}/mysql-tests/suite/federated/disabled.def
227 #
228 # ${S}/mysql-tests/suite/jp/t/disabled.def
229 # ${S}/mysql-tests/suite/ndb/t/disabled.def
230 # ${S}/mysql-tests/suite/rpl/t/disabled.def
231 # ${S}/mysql-tests/suite/parts/t/disabled.def
232 # ${S}/mysql-tests/suite/rpl_ndb/t/disabled.def
233 # ${S}/mysql-tests/suite/ndb_team/t/disabled.def
234 # ${S}/mysql-tests/suite/binlog/t/disabled.def
235 # ${S}/mysql-tests/suite/innodb/t/disabled.def
236 if [ -n "${testsuite}" ]; then
237 for mysql_disable_file in \
238 ${S}/mysql-test/suite/${testsuite}/disabled.def \
239 ${S}/mysql-test/suite/${testsuite}/t/disabled.def \
240 FAILED ; do
241 [ -f "${mysql_disable_file}" ] && break
242 done
243 if [ "${mysql_disabled_file}" != "FAILED" ]; then
244 echo "${testname} : ${reason}" >> "${mysql_disable_file}"
245 else
246 ewarn "Could not find testsuite disabled.def location for ${rawtestname}"
247 fi
248 fi
249}
250
251# @FUNCTION: mysql_init_vars
252# @DESCRIPTION:
137# void mysql_init_vars() 253# void mysql_init_vars()
138#
139# Initialize global variables 254# Initialize global variables
140# 2005-11-19 <vivo@gentoo.org> 255# 2005-11-19 <vivo@gentoo.org>
141
142mysql_init_vars() { 256mysql_init_vars() {
143 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"} 257 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"}
144 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"} 258 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"}
145 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"} 259 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"}
146 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"} 260 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"}
173 PREVIOUS_DATADIR="yes" 287 PREVIOUS_DATADIR="yes"
174 else 288 else
175 PREVIOUS_DATADIR="no" 289 PREVIOUS_DATADIR="no"
176 fi 290 fi
177 export PREVIOUS_DATADIR 291 export PREVIOUS_DATADIR
292 fi
293 else
294 if [[ ${EBUILD_PHASE} == "config" ]]; then
295 local new_MY_DATADIR
296 new_MY_DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
297 | sed -ne '/datadir/s|^--datadir=||p' \
298 | tail -n1`
299
300 if [[ ( -n "${new_MY_DATADIR}" ) && ( "${new_MY_DATADIR}" != "${MY_DATADIR}" ) ]]; then
301 ewarn "MySQL MY_DATADIR has changed"
302 ewarn "from ${MY_DATADIR}"
303 ewarn "to ${new_MY_DATADIR}"
304 MY_DATADIR="${new_MY_DATADIR}"
305 fi
178 fi 306 fi
179 fi 307 fi
180 308
181 MY_SOURCEDIR=${SERVER_URI##*/} 309 MY_SOURCEDIR=${SERVER_URI##*/}
182 MY_SOURCEDIR=${MY_SOURCEDIR%.tar*} 310 MY_SOURCEDIR=${MY_SOURCEDIR%.tar*}
277 if use ssl ; then 405 if use ssl ; then
278 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio" 406 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio"
279 fi 407 fi
280 408
281 if mysql_version_is_at_least "5.1.11" ; then 409 if mysql_version_is_at_least "5.1.11" ; then
282 myconf="${myconf} $(use_with ssl)" 410 myconf="${myconf} $(use_with ssl /usr)"
283 else 411 else
284 myconf="${myconf} $(use_with ssl openssl)" 412 myconf="${myconf} $(use_with ssl openssl)"
285 fi 413 fi
286 414
287 if mysql_version_is_at_least "5.0.60" ; then 415 if mysql_version_is_at_least "5.0.60" ; then
328 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html" 456 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
329 myconf="${myconf} --with-federated-storage-engine" 457 myconf="${myconf} --with-federated-storage-engine"
330 fi 458 fi
331 fi 459 fi
332 460
333 if [ "${PN}" == "mysql-community" ]; then 461 if [ "${MYSQL_COMMUNITY_FEATURES}" == "1" ]; then
334 myconf="${myconf} --enable-community-features" 462 myconf="${myconf} `use_enable community community-features`"
463 if use community; then
464 myconf="${myconf} `use_enable profiling`"
465 else
466 myconf="${myconf} --disable-profiling"
467 fi
335 fi 468 fi
336 469
337 mysql_version_is_at_least "5.0.18" \ 470 mysql_version_is_at_least "5.0.18" \
338 && use max-idx-128 \ 471 && use max-idx-128 \
339 && myconf="${myconf} --with-max-indexes=128" 472 && myconf="${myconf} --with-max-indexes=128"
345 # readline.h instead of history.h 478 # readline.h instead of history.h
346 myconf="${myconf} $(use_with ssl)" 479 myconf="${myconf} $(use_with ssl)"
347 myconf="${myconf} --enable-assembler" 480 myconf="${myconf} --enable-assembler"
348 myconf="${myconf} --with-geometry" 481 myconf="${myconf} --with-geometry"
349 myconf="${myconf} --with-readline" 482 myconf="${myconf} --with-readline"
350 myconf="${myconf} --with-row-based-replication"
351 myconf="${myconf} --with-zlib=/usr/$(get_libdir)" 483 myconf="${myconf} --with-zlib-dir=/usr/"
352 myconf="${myconf} --without-pstack" 484 myconf="${myconf} --without-pstack"
353 use max-idx-128 && myconf="${myconf} --with-max-indexes=128" 485 use max-idx-128 && myconf="${myconf} --with-max-indexes=128"
354 486
355 # 5.1 introduces a new way to manage storage engines (plugins) 487 # 5.1 introduces a new way to manage storage engines (plugins)
356 # like configuration=none 488 # like configuration=none
357 local plugins="csv,myisam,myisammrg,heap" 489 local plugins="csv,myisam,myisammrg,heap"
358 if use extraengine ; then 490 if use extraengine ; then
359 # like configuration=max-no-ndb, archive and example removed in 5.1.11 491 # like configuration=max-no-ndb, archive and example removed in 5.1.11
492 # not added yet: ibmdb2i
493 # Not supporting as examples: example,daemon_example,ftexample
360 plugins="${plugins},archive,blackhole,example,federated,partition" 494 plugins="${plugins},archive,blackhole,federated,partition"
361 495
362 elog "Before using the Federated storage engine, please be sure to read" 496 elog "Before using the Federated storage engine, please be sure to read"
363 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html" 497 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
364 fi 498 fi
365 499
366 # Upstream specifically requests that InnoDB always be built. 500 # Upstream specifically requests that InnoDB always be built:
367 plugins="${plugins},innobase" 501 # - innobase, innodb_plugin
502 # Build falcon if available for 6.x series.
503 for i in innobase innodb_plugin falcon ; do
504 [ -e "${S}"/storage/${i} ] && plugins="${plugins},${i}"
505 done
368 506
369 # like configuration=max-no-ndb 507 # like configuration=max-no-ndb
370 if use cluster ; then 508 if use cluster ; then
371 plugins="${plugins},ndbcluster" 509 plugins="${plugins},ndbcluster"
372 myconf="${myconf} --with-ndb-binlog" 510 myconf="${myconf} --with-ndb-binlog"
373 fi 511 fi
374 512
375 if mysql_version_is_at_least "5.2" ; then
376 plugins="${plugins},falcon"
377 fi
378
379 myconf="${myconf} --with-plugins=${plugins}" 513 myconf="${myconf} --with-plugins=${plugins}"
380} 514}
381 515
516xtradb_applicable() {
517 mysql_version_is_at_least "5.1.26" \
518 && [[ -n "${XTRADB_VER}" && -n "${PERCONA_VER}" ]] \
519 && use xtradb
520 return $?
521}
522
523pbxt_applicable() {
524 mysql_version_is_at_least "5.1.12" \
525 && [[ -n "${PBXT_VERSION}" ]] \
526 && use pbxt
527 return $?
528}
529
382pbxt_src_compile() { 530pbxt_src_configure() {
383 mysql_init_vars 531 mysql_init_vars
384 532
385 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null 533 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
386 534
387 einfo "Reconfiguring dir '${PWD}'" 535 einfo "Reconfiguring dir '${PWD}'"
388 AT_GNUCONF_UPDATE="yes" eautoreconf 536 AT_GNUCONF_UPDATE="yes" eautoreconf
389 537
390 local myconf="" 538 local myconf=""
391 myconf="${myconf} --with-mysql=${S} --libdir=${D}/${MY_LIBDIR}" 539 myconf="${myconf} --with-mysql=${S} --libdir=${MY_LIBDIR}"
392 use debug && myconf="${myconf} --with-debug=full" 540 use debug && myconf="${myconf} --with-debug=full"
393 # TODO: is it safe/needed to use econf here ? 541 # TODO: is it safe/needed to use econf here ?
394 ./configure ${myconf} || die "Problem configuring PBXT storage engine" 542 ./configure ${myconf} || die "Problem configuring PBXT storage engine"
543}
544
545pbxt_src_compile() {
546 # Be backwards compatible for now
547 if [[ $EAPI != 2 ]]; then
548 pbxt_src_configure
549 fi
395 # TODO: is it safe/needed to use emake here ? 550 # TODO: is it safe/needed to use emake here ?
396 make || die "Problem making PBXT storage engine (${myconf})" 551 make || die "Problem making PBXT storage engine (${myconf})"
397 552
398 popd 553 popd
399 # TODO: modify test suite for PBXT 554 # TODO: modify test suite for PBXT
400} 555}
401 556
402pbxt_src_install() { 557pbxt_src_install() {
403 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null 558 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
404 make install || die "Failed to install PBXT" 559 emake install DESTDIR="${D}" || die "Failed to install PBXT"
405 popd 560 popd
406} 561}
407 562
408# 563#
409# EBUILD FUNCTIONS 564# EBUILD FUNCTIONS
410# 565#
566# @FUNCTION: mysql_pkg_setup
567# @DESCRIPTION:
568# Perform some basic tests and tasks during pkg_setup phase:
569# die if FEATURES="test", USE="-minimal" and not using FEATURES="userpriv"
570# check for conflicting use flags
571# create new user and group for mysql
572# warn about deprecated features
411mysql_pkg_setup() { 573mysql_pkg_setup() {
412 if hasq test ${FEATURES} ; then 574 if hasq test ${FEATURES} ; then
413 if ! use minimal ; then 575 if ! use minimal ; then
414 if [[ $UID -eq 0 ]]; then 576 if [[ $UID -eq 0 ]]; then
415 eerror "Testing with FEATURES=-userpriv is no longer supported by upstream. Tests MUST be run as non-root." 577 eerror "Testing with FEATURES=-userpriv is no longer supported by upstream. Tests MUST be run as non-root."
436 && use minimal ; then 598 && use minimal ; then
437 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!" 599 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
438 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!" 600 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
439 fi 601 fi
440 602
603 # Bug #290570 fun. Upstream made us need a fairly new GCC4.
604 if mysql_version_is_at_least "5.0.83" ; then
605 GCC_VER=$(gcc-version)
606 case ${GCC_VER} in
607 2*|3*|4.0|4.1|4.2) die "Active GCC too old! Must have at least GCC4.3" ;;
608 esac
609 fi
610
441 # This should come after all of the die statements 611 # This should come after all of the die statements
442 enewgroup mysql 60 || die "problem adding 'mysql' group" 612 enewgroup mysql 60 || die "problem adding 'mysql' group"
443 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user" 613 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
444 614
445 mysql_check_version_range "4.0 to 5.0.99.99" \ 615 mysql_check_version_range "4.0 to 5.0.99.99" \
446 && use berkdb \ 616 && use berkdb \
447 && elog "Berkeley DB support is deprecated and will be removed in future versions!" 617 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
448}
449 618
619 if [ "${PN}" != "mysql-cluster" ] && use cluster; then
620 ewarn "Upstream has noted that the NDB cluster support in the 5.0 and"
621 ewarn "5.1 series should NOT be put into production. In the near"
622 ewarn "future, it will be disabled from building."
623 ewarn ""
624 ewarn "If you need NDB support, you should instead move to the new"
625 ewarn "mysql-cluster package that represents that upstream NDB"
626 ewarn "development."
627 fi
628}
629
630# @FUNCTION: mysql_src_unpack
631# @DESCRIPTION:
632# Unpack the source code and call mysql_src_prepare for EAPI < 2.
450mysql_src_unpack() { 633mysql_src_unpack() {
451 # Initialize the proper variables first 634 # Initialize the proper variables first
452 mysql_init_vars 635 mysql_init_vars
453 636
454 unpack ${A} 637 unpack ${A}
455 # Grab the patches 638 # Grab the patches
456 [[ "${MY_EXTRAS_VER}" == "live" ]] && S="${WORKDIR}/mysql-extras" git_src_unpack 639 [[ "${MY_EXTRAS_VER}" == "live" ]] && S="${WORKDIR}/mysql-extras" git_src_unpack
457 640
458 mv -f "${WORKDIR}/${MY_SOURCEDIR}" "${S}" 641 mv -f "${WORKDIR}/${MY_SOURCEDIR}" "${S}"
642
643 # Be backwards compatible for now
644 case ${EAPI:-0} in
645 2) : ;;
646 0 | 1) mysql_src_prepare ;;
647 esac
648}
649
650# @FUNCTION: mysql_src_prepare
651# @DESCRIPTION:
652# Apply patches to the source code and remove unneeded bundled libs.
653mysql_src_prepare() {
459 cd "${S}" 654 cd "${S}"
460 655
461 # Apply the patches for this MySQL version 656 # Apply the patches for this MySQL version
462 EPATCH_SUFFIX="patch" 657 EPATCH_SUFFIX="patch"
463 mkdir -p "${EPATCH_SOURCE}" || die "Unable to create epatch directory" 658 mkdir -p "${EPATCH_SOURCE}" || die "Unable to create epatch directory"
466 # Now link in right patches 661 # Now link in right patches
467 mysql_mv_patches 662 mysql_mv_patches
468 # And apply 663 # And apply
469 epatch 664 epatch
470 665
666 # last -fPIC fixup, per bug #305873
667 i="${S}"/storage/innodb_plugin/plug.in
668 [ -f "${i}" ] && sed -i -e '/CFLAGS/s,-prefer-non-pic,,g' "${i}"
669
471 # Additional checks, remove bundled zlib 670 # Additional checks, remove bundled zlib
472 rm -f "${S}/zlib/"*.[ch] 671 rm -f "${S}/zlib/"*.[ch]
473 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in" 672 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
474 rm -f "scripts/mysqlbug" 673 rm -f "scripts/mysqlbug"
475 674
477 find . -name 'Makefile.am' \ 676 find . -name 'Makefile.am' \
478 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \; 677 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
479 678
480 if mysql_version_is_at_least "4.1" ; then 679 if mysql_version_is_at_least "4.1" ; then
481 # Remove what needs to be recreated, so we're sure it's actually done 680 # Remove what needs to be recreated, so we're sure it's actually done
681 einfo "Cleaning up old buildscript files"
482 find . -name Makefile \ 682 find . -name Makefile \
483 -o -name Makefile.in \ 683 -o -name Makefile.in \
484 -o -name configure \ 684 -o -name configure \
485 -exec rm -f {} \; 685 -exec rm -f {} \;
486 rm -f "ltmain.sh" 686 rm -f "ltmain.sh"
487 rm -f "scripts/mysqlbug" 687 rm -f "scripts/mysqlbug"
488 fi 688 fi
489 689
490 local rebuilddirlist d 690 local rebuilddirlist d
491 691
692 if xtradb_applicable ; then
693 einfo "Replacing InnoDB with Percona XtraDB"
694 pushd "${S}"/storage
695 i="innobase"
696 o="${WORKDIR}/storage-${i}.mysql-upstream"
697 # Have we been here already?
698 [ -d "${o}" ] && rm -f "${i}"
699 # Or maybe we haven't
700 [ -d "${i}" -a ! -d "${o}" ] && mv "${i}" "${o}"
701 cp -ra "${WORKDIR}/${XTRADB_P}" "${i}"
702 popd
703 fi
704
492 if mysql_version_is_at_least "5.1.12" ; then 705 if mysql_version_is_at_least "5.1.12" ; then
493 rebuilddirlist="." 706 rebuilddirlist="."
707 # This does not seem to be needed presently. robbat2 2010/02/23
708 #einfo "Updating innobase cmake"
494 # TODO: check this with a cmake expert 709 ## TODO: check this with a cmake expert
495 cmake \ 710 #cmake \
496 -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \ 711 # -DCMAKE_C_COMPILER=$(type -P $(tc-getCC)) \
497 -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \ 712 # -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX)) \
498 "storage/innobase" 713 # "storage/innobase"
499 else 714 else
500 rebuilddirlist=". innobase" 715 rebuilddirlist=". innobase"
501 fi 716 fi
502 717
503 for d in ${rebuilddirlist} ; do 718 for d in ${rebuilddirlist} ; do
507 popd &>/dev/null 722 popd &>/dev/null
508 done 723 done
509 724
510 if mysql_check_version_range "4.1 to 5.0.99.99" \ 725 if mysql_check_version_range "4.1 to 5.0.99.99" \
511 && use berkdb ; then 726 && use berkdb ; then
727 einfo "Fixing up berkdb buildsystem"
512 [[ -w "bdb/dist/ltmain.sh" ]] && cp -f "ltmain.sh" "bdb/dist/ltmain.sh" 728 [[ -w "bdb/dist/ltmain.sh" ]] && cp -f "ltmain.sh" "bdb/dist/ltmain.sh"
513 cp -f "/usr/share/aclocal/libtool.m4" "bdb/dist/aclocal/libtool.ac" \ 729 cp -f "/usr/share/aclocal/libtool.m4" "bdb/dist/aclocal/libtool.ac" \
514 || die "Could not copy libtool.m4 to bdb/dist/" 730 || die "Could not copy libtool.m4 to bdb/dist/"
515 #These files exist only with libtool-2*, and need to be included. 731 #These files exist only with libtool-2*, and need to be included.
516 if [ -f '/usr/share/aclocal/ltsugar.m4' ]; then 732 if [ -f '/usr/share/aclocal/ltsugar.m4' ]; then
524 || die "Failed bdb reconfigure" 740 || die "Failed bdb reconfigure"
525 popd &>/dev/null 741 popd &>/dev/null
526 fi 742 fi
527} 743}
528 744
745# @FUNCTION: mysql_src_configure
746# @DESCRIPTION:
747# Configure mysql to build the code for Gentoo respecting the use flags.
529mysql_src_compile() { 748mysql_src_configure() {
530 # Make sure the vars are correctly initialized 749 # Make sure the vars are correctly initialized
531 mysql_init_vars 750 mysql_init_vars
532 751
533 # $myconf is modified by the configure_* functions 752 # $myconf is modified by the configure_* functions
534 local myconf="" 753 local myconf=""
559 CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-strict-aliasing" 778 CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-strict-aliasing"
560 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti" 779 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
561 mysql_version_is_at_least "5.0" \ 780 mysql_version_is_at_least "5.0" \
562 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 781 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
563 export CXXFLAGS 782 export CXXFLAGS
783
784 # bug #283926, with GCC4.4, this is required to get correct behavior.
785 append-flags -fno-strict-aliasing
564 786
565 econf \ 787 econf \
566 --libexecdir="/usr/sbin" \ 788 --libexecdir="/usr/sbin" \
567 --sysconfdir="${MY_SYSCONFDIR}" \ 789 --sysconfdir="${MY_SYSCONFDIR}" \
568 --localstatedir="${MY_LOCALSTATEDIR}" \ 790 --localstatedir="${MY_LOCALSTATEDIR}" \
579 # TODO: Move this before autoreconf !!! 801 # TODO: Move this before autoreconf !!!
580 find . -type f -name Makefile -print0 \ 802 find . -type f -name Makefile -print0 \
581 | xargs -0 -n100 sed -i \ 803 | xargs -0 -n100 sed -i \
582 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|' 804 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
583 805
806 if [[ $EAPI == 2 ]]; then
807 pbxt_applicable && pbxt_src_configure
808 fi
809}
810
811# @FUNCTION: mysql_src_compile
812# @DESCRIPTION:
813# Compile the mysql code.
814mysql_src_compile() {
815 # Be backwards compatible for now
816 case ${EAPI:-0} in
817 2) : ;;
818 0 | 1) mysql_src_configure ;;
819 esac
820
584 emake || die "emake failed" 821 emake || die "emake failed"
585 822
586 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_compile 823 pbxt_applicable && pbxt_src_compile
587} 824}
588 825
826# @FUNCTION: mysql_src_install
827# @DESCRIPTION:
828# Install mysql.
589mysql_src_install() { 829mysql_src_install() {
590 # Make sure the vars are correctly initialized 830 # Make sure the vars are correctly initialized
591 mysql_init_vars 831 mysql_init_vars
592 832
593 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed" 833 emake install \
834 DESTDIR="${D}" \
835 benchdir_root="${MY_SHAREDSTATEDIR}" \
836 testroot="${MY_SHAREDSTATEDIR}" \
837 || die "emake install failed"
594 838
595 mysql_version_is_at_least "5.1.12" && use pbxt && pbxt_src_install 839 pbxt_applicable && pbxt_src_install
596 840
597 # Convenience links 841 # Convenience links
598 einfo "Making Convenience links for mysqlcheck multi-call binary" 842 einfo "Making Convenience links for mysqlcheck multi-call binary"
599 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze" 843 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
600 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair" 844 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
604 einfo "Removing duplicate /usr/share/mysql files" 848 einfo "Removing duplicate /usr/share/mysql files"
605 rm -Rf "${D}/usr/share/info" 849 rm -Rf "${D}/usr/share/info"
606 for removeme in "mysql-log-rotate" mysql.server* \ 850 for removeme in "mysql-log-rotate" mysql.server* \
607 binary-configure* my-*.cnf mi_test_all* 851 binary-configure* my-*.cnf mi_test_all*
608 do 852 do
609 rm -f "${D}"/usr/share/mysql/${removeme} 853 rm -f "${D}"/${MY_SHAREDSTATEDIR}/${removeme}
610 done 854 done
611 855
612 # Clean up stuff for a minimal build 856 # Clean up stuff for a minimal build
613 if use minimal ; then 857 if use minimal ; then
614 einfo "Remove all extra content for minimal build" 858 einfo "Remove all extra content for minimal build"
615 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench} 859 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
616 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} 860 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}
617 rm -f "${D}/usr/sbin/mysqld" 861 rm -f "${D}/usr/sbin/mysqld"
618 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a 862 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
863 fi
864
865 # Unless they explicitly specific USE=test, then do not install the
866 # testsuite. It DOES have a use to be installed, esp. when you want to do a
867 # validation of your database configuration after tuning it.
868 if use !test ; then
869 rm -rf "${D}"/${MY_SHAREDSTATEDIR}/mysql-test
619 fi 870 fi
620 871
621 # Configuration stuff 872 # Configuration stuff
622 if mysql_version_is_at_least "4.1" ; then 873 if mysql_version_is_at_least "4.1" ; then
623 mysql_mycnf_version="4.1" 874 mysql_mycnf_version="4.1"
654 done 905 done
655 fi 906 fi
656 907
657 # Docs 908 # Docs
658 einfo "Installing docs" 909 einfo "Installing docs"
659 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 910 dodoc README ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
660 doinfo "${S}"/Docs/mysql.info 911 doinfo "${S}"/Docs/mysql.info
661 912
662 # Minimal builds don't have the MySQL server 913 # Minimal builds don't have the MySQL server
663 if ! use minimal ; then 914 if ! use minimal ; then
664 einfo "Including support files and sample configurations" 915 einfo "Including support files and sample configurations"
666 for script in \ 917 for script in \
667 "${S}"/support-files/my-*.cnf \ 918 "${S}"/support-files/my-*.cnf \
668 "${S}"/support-files/magic \ 919 "${S}"/support-files/magic \
669 "${S}"/support-files/ndb-config-2-node.ini 920 "${S}"/support-files/ndb-config-2-node.ini
670 do 921 do
671 dodoc "${script}" 922 [[ -f "$script" ]] && dodoc "${script}"
672 done 923 done
673 924
674 docinto "scripts" 925 docinto "scripts"
675 for script in "${S}"/scripts/mysql* ; do 926 for script in "${S}"/scripts/mysql* ; do
676 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 927 [[ -f "$script" ]] && [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
677 done 928 done
678 929
679 fi 930 fi
680 931
681 mysql_lib_symlinks "${D}" 932 mysql_lib_symlinks "${D}"
682} 933}
683 934
935# @FUNCTION: mysql_pkg_preinst
936# @DESCRIPTION:
937# Create the user and groups for mysql - die if that fails.
684mysql_pkg_preinst() { 938mysql_pkg_preinst() {
685 enewgroup mysql 60 || die "problem adding 'mysql' group" 939 enewgroup mysql 60 || die "problem adding 'mysql' group"
686 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user" 940 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
687} 941}
688 942
943# @FUNCTION: mysql_pkg_postinst
944# @DESCRIPTION:
945# Run post-installation tasks:
946# create the dir for logfiles if non-existant
947# touch the logfiles and secure them
948# install scripts
949# issue required steps for optional features
950# issue deprecation warnings
689mysql_pkg_postinst() { 951mysql_pkg_postinst() {
690 # Make sure the vars are correctly initialized 952 # Make sure the vars are correctly initialized
691 mysql_init_vars 953 mysql_init_vars
692 954
693 # Check FEATURES="collision-protect" before removing this 955 # Check FEATURES="collision-protect" before removing this
719 elog "\"emerge --config =${CATEGORY}/${PF}\"" 981 elog "\"emerge --config =${CATEGORY}/${PF}\""
720 elog "if this is a new install." 982 elog "if this is a new install."
721 einfo 983 einfo
722 fi 984 fi
723 985
724 if mysql_version_is_at_least "5.1.12" && use pbxt ; then 986 if pbxt_applicable ; then
725 # TODO: explain it better 987 # TODO: explain it better
726 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';" 988 elog " mysql> INSTALL PLUGIN pbxt SONAME 'libpbxt.so';"
727 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;" 989 elog " mysql> CREATE TABLE t1 (c1 int, c2 text) ENGINE=pbxt;"
728 elog "if, after that, you cannot start the MySQL server," 990 elog "if, after that, you cannot start the MySQL server,"
729 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then" 991 elog "remove the ${MY_DATADIR}/mysql/plugin.* files, then"
739 mysql_check_version_range "4.0 to 5.0.99.99" \ 1001 mysql_check_version_range "4.0 to 5.0.99.99" \
740 && use berkdb \ 1002 && use berkdb \
741 && elog "Berkeley DB support is deprecated and will be removed in future versions!" 1003 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
742} 1004}
743 1005
1006# @FUNCTION: mysql_pkg_config
1007# @DESCRIPTION:
1008# Configure mysql environment.
744mysql_pkg_config() { 1009mysql_pkg_config() {
1010 local old_MY_DATADIR="${MY_DATADIR}"
1011
745 # Make sure the vars are correctly initialized 1012 # Make sure the vars are correctly initialized
746 mysql_init_vars 1013 mysql_init_vars
747 1014
748 [[ -z "${MY_DATADIR}" ]] && die "Sorry, unable to find MY_DATADIR" 1015 [[ -z "${MY_DATADIR}" ]] && die "Sorry, unable to find MY_DATADIR"
749 1016
750 if built_with_use ${CATEGORY}/${PN} minimal ; then 1017 if built_with_use ${CATEGORY}/${PN} minimal ; then
751 die "Minimal builds do NOT include the MySQL server" 1018 die "Minimal builds do NOT include the MySQL server"
1019 fi
1020
1021 if [[ ( -n "${MY_DATADIR}" ) && ( "${MY_DATADIR}" != "${old_MY_DATADIR}" ) ]]; then
1022 local MY_DATADIR_s="$(strip_duplicate_slashes ${ROOT}/${MY_DATADIR})"
1023 local old_MY_DATADIR_s="$(strip_duplicate_slashes ${ROOT}/${old_MY_DATADIR})"
1024
1025 if [[ -d "${old_MY_DATADIR_s}" ]]; then
1026 if [[ -d "${MY_DATADIR_s}" ]]; then
1027 ewarn "Both ${old_MY_DATADIR_s} and ${MY_DATADIR_s} exist"
1028 ewarn "Attempting to use ${MY_DATADIR_s} and preserving ${old_MY_DATADIR_s}"
1029 else
1030 elog "Moving MY_DATADIR from ${old_MY_DATADIR_s} to ${MY_DATADIR_s}"
1031 mv --strip-trailing-slashes -T "${old_MY_DATADIR_s}" "${MY_DATADIR_s}" \
1032 || die "Moving MY_DATADIR failed"
1033 fi
1034 else
1035 ewarn "Previous MY_DATADIR (${old_MY_DATADIR_s}) does not exist"
1036 if [[ -d "${MY_DATADIR_s}" ]]; then
1037 ewarn "Attempting to use ${MY_DATADIR_s}"
1038 else
1039 eerror "New MY_DATADIR (${MY_DATADIR_s}) does not exist"
1040 die "Configuration Failed! Please reinstall ${CATEGORY}/${PN}"
1041 fi
1042 fi
752 fi 1043 fi
753 1044
754 local pwd1="a" 1045 local pwd1="a"
755 local pwd2="b" 1046 local pwd2="b"
756 local maxtry=5 1047 local maxtry=5
857 einfo "Stopping the server ..." 1148 einfo "Stopping the server ..."
858 wait %1 1149 wait %1
859 einfo "Done" 1150 einfo "Done"
860} 1151}
861 1152
1153# @FUNCTION: mysql_pkg_postrm
1154# @DESCRIPTION:
1155# Remove mysql symlinks.
862mysql_pkg_postrm() { 1156mysql_pkg_postrm() {
863 : # mysql_lib_symlinks "${D}" 1157 : # mysql_lib_symlinks "${D}"
864} 1158}

Legend:
Removed from v.1.109  
changed lines
  Added in v.1.135

  ViewVC Help
Powered by ViewVC 1.1.20