diff options
author | Francesco Riosa <vivo@gentoo.org> | 2005-10-24 17:00:19 +0000 |
---|---|---|
committer | Francesco Riosa <vivo@gentoo.org> | 2005-10-24 17:00:19 +0000 |
commit | bcef1ff86906ff10bf5978cc329f7ae1188f0160 (patch) | |
tree | 30026897d7eda77c62123e6794416e2e6bc275b6 /dev-db/mysql | |
parent | Marked ppc stable, bug #109809 (diff) | |
download | historical-bcef1ff86906ff10bf5978cc329f7ae1188f0160.tar.gz historical-bcef1ff86906ff10bf5978cc329f7ae1188f0160.tar.bz2 historical-bcef1ff86906ff10bf5978cc329f7ae1188f0160.zip |
new 5.0.15; fixed typo in 4.1.15
Package-Manager: portage-2.0.52-r1
Diffstat (limited to 'dev-db/mysql')
-rw-r--r-- | dev-db/mysql/ChangeLog | 14 | ||||
-rw-r--r-- | dev-db/mysql/Manifest | 10 | ||||
-rw-r--r-- | dev-db/mysql/files/digest-mysql-5.0.15 | 2 | ||||
-rw-r--r-- | dev-db/mysql/mysql-4.1.14.ebuild | 7 | ||||
-rw-r--r-- | dev-db/mysql/mysql-4.1.15.ebuild | 53 | ||||
-rw-r--r-- | dev-db/mysql/mysql-5.0.13_rc.ebuild | 7 | ||||
-rw-r--r-- | dev-db/mysql/mysql-5.0.15.ebuild | 624 |
7 files changed, 682 insertions, 35 deletions
diff --git a/dev-db/mysql/ChangeLog b/dev-db/mysql/ChangeLog index 839890012520..06227060b18e 100644 --- a/dev-db/mysql/ChangeLog +++ b/dev-db/mysql/ChangeLog @@ -1,6 +1,18 @@ # ChangeLog for dev-db/mysql # Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/ChangeLog,v 1.254 2005/10/22 16:51:04 vivo Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/ChangeLog,v 1.255 2005/10/24 17:00:19 vivo Exp $ + +*mysql-5.0.15 (24 Oct 2005) + + 24 Oct 2005; Francesco Riosa <vivo@gentoo.org> +mysql-5.0.15.ebuild: + Version bump, 5.0.15 is the first version declared GA from upstream + + 24 Oct 2005; Francesco Riosa <vivo@gentoo.org> mysql-4.1.15.ebuild: + fixed typo, readded /var/log/mysql to binpkg + + 24 Oct 2005; Francesco Riosa <vivo@gentoo.org> mysql-4.1.14.ebuild, + mysql-4.1.15.ebuild, mysql-5.0.13_rc.ebuild: + Added revdep-rebuild --soname hint 22 Oct 2005; Francesco Riosa <vivo@gentoo.org> mysql-4.0.26.ebuild, -mysql-4.1.13-r1.ebuild, mysql-4.1.14.ebuild, mysql-4.1.15.ebuild, diff --git a/dev-db/mysql/Manifest b/dev-db/mysql/Manifest index 85c251a97b00..11208ccb8eca 100644 --- a/dev-db/mysql/Manifest +++ b/dev-db/mysql/Manifest @@ -1,9 +1,10 @@ -MD5 80b9cede400575cbfd3c0ba65794e72d mysql-4.1.14.ebuild 18744 +MD5 ca4439086bc967f265e38f7d46d8632a mysql-4.1.14.ebuild 18782 MD5 d419eb0723fa69b4e938806f4aaf705f mysql-4.0.26.ebuild 14895 -MD5 30e5e0002d9e0cf26a5e3107000fe0b1 mysql-5.0.13_rc.ebuild 18891 -MD5 03901a76f20ac2d071c4f6262b1fb840 mysql-4.1.15.ebuild 18862 +MD5 af5393351bb355e6ca2e187afcc3fd34 mysql-5.0.15.ebuild 19150 +MD5 c727796d2a8548e62c735d262a0b8ee7 mysql-5.0.13_rc.ebuild 18929 +MD5 d4af8acfa6042b6149b81e3646637e27 mysql-4.1.15.ebuild 19022 MD5 eb11a08abb447b7a69b192a6f9be3dbf mysql-3.23.58-r1.ebuild 7219 -MD5 5e0fdae97ccc7eca1aabf3cf813a2a16 ChangeLog 46581 +MD5 76d4cf1c79d7d844649d58b2d28fd4d2 ChangeLog 47025 MD5 a2a9fdc7d010a7c04c96cb3b7c05f06b metadata.xml 158 MD5 2318a7432107d2b7842f9e2fe87d8571 mysql-4.0.25-r2.ebuild 14266 MD5 625b4007f035e3da9a4f1eeee1db6b9c files/mysql-4.0.15.rc6 1187 @@ -11,6 +12,7 @@ MD5 c6fcd70c34bed04e59808ec71c5bedfb files/digest-mysql-3.23.58-r1 140 MD5 201c8b31cd9eb58eec712e37d6f0c328 files/digest-mysql-4.0.26 139 MD5 4e6e76e3945e29b6795ce6d1a66bc98f files/digest-mysql-4.1.14 139 MD5 b8eda6b8ec67faff78e5d01023e6eefb files/digest-mysql-4.1.15 139 +MD5 b9b44f65c775f650064022427ae52425 files/digest-mysql-5.0.15 139 MD5 73be6460f548f6f73c70246a4cfd13a0 files/mysql.init 886 MD5 713dc46b7ffa15edda542a15508ce07c files/digest-mysql-5.0.13_rc 142 MD5 d200345efa421d012cf858134d2c8884 files/logrotate.mysql 440 diff --git a/dev-db/mysql/files/digest-mysql-5.0.15 b/dev-db/mysql/files/digest-mysql-5.0.15 new file mode 100644 index 000000000000..9d25b38b16cd --- /dev/null +++ b/dev-db/mysql/files/digest-mysql-5.0.15 @@ -0,0 +1,2 @@ +MD5 b19e03de0ec348552b4bfac2e215f335 mysql-5.0.15.tar.gz 18813065 +MD5 5a936d382232f7b4b15fc7d025e9fa8e mysql-extras-20050920.tar.bz2 51007 diff --git a/dev-db/mysql/mysql-4.1.14.ebuild b/dev-db/mysql/mysql-4.1.14.ebuild index f97c05953cf5..aea2ae2396ad 100644 --- a/dev-db/mysql/mysql-4.1.14.ebuild +++ b/dev-db/mysql/mysql-4.1.14.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2005 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-4.1.14.ebuild,v 1.19 2005/10/22 16:51:04 vivo Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-4.1.14.ebuild,v 1.20 2005/10/24 17:00:19 vivo Exp $ inherit eutils gnuconfig flag-o-matic versionator @@ -60,8 +60,9 @@ mysql_upgrade_warning() { ewarn "If you're upgrading from MySQL-3.x to 4.0, or 4.0.x to 4.1.x, you" ewarn "must recompile the other packages on your system that link with" ewarn "libmysqlclient after the upgrade completes. To obtain such a list" - ewarn "of packages for your system, you may use 'revdep-rebuild' from" - ewarn "app-portage/gentoolkit." + ewarn "of packages for your system, you may use:" + ewarn "revdep-rebuild --soname=libmysqlclient.so.12" + ewarn "from app-portage/gentoolkit." ewarn "" ewarn "the value of \"innodb_log_file_size\" into /etc/mysql/my.cnf file " ewarn "has changed size from \"8M\" to \"5M\"." diff --git a/dev-db/mysql/mysql-4.1.15.ebuild b/dev-db/mysql/mysql-4.1.15.ebuild index e1389035bf86..67625cee1a5c 100644 --- a/dev-db/mysql/mysql-4.1.15.ebuild +++ b/dev-db/mysql/mysql-4.1.15.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2005 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-4.1.15.ebuild,v 1.2 2005/10/22 16:51:04 vivo Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-4.1.15.ebuild,v 1.3 2005/10/24 17:00:19 vivo Exp $ inherit eutils gnuconfig flag-o-matic versionator @@ -41,7 +41,7 @@ if version_is_at_least "4.1.3" ; then # 2005-09-29 # geometry has been removed due to repeated compile problems _without_ it. # From now on it will be *always* enabled - # if you need to compile *without it* take a look at + # if you need to compile *without it* take a look at # http://lists.mysql.com/internals/29559 IUSE="${IUSE} cluster utf8 extraengine" fi @@ -65,8 +65,9 @@ mysql_upgrade_warning() { ewarn "If you're upgrading from MySQL-3.x to 4.0, or 4.0.x to 4.1.x, you" ewarn "must recompile the other packages on your system that link with" ewarn "libmysqlclient after the upgrade completes. To obtain such a list" - ewarn "of packages for your system, you may use 'revdep-rebuild' from" - ewarn "app-portage/gentoolkit." + ewarn "of packages for your system, you may use:" + ewarn "revdep-rebuild --library=libmysqlclient.so.12" + ewarn "from app-portage/gentoolkit." ewarn "" ewarn "the value of \"innodb_log_file_size\" into /etc/mysql/my.cnf file " ewarn "has changed size from \"8M\" to \"5M\"." @@ -110,7 +111,7 @@ pkg_setup() { if [[ -z $MYSQL_STRAIGHT_UPGRADE ]] ; then mysql_get_datadir - local local curversion="dev-db/${PN}-${PV%.*}" + local curversion="dev-db/${PN}-${PV%.*}" local oldversion="$(best_version dev-db/mysql)" oldversion=${oldversion%.*} @@ -161,6 +162,7 @@ src_unpack() { epatch ${MY_PATCH_SOURCE}/010_all_my-print-defaults-r0.patch || die epatch ${MY_PATCH_SOURCE}/030_all_thrssl-r1.patch || die + epatch ${MY_PATCH_SOURCE}/035_x86_asm-pic-fixes-r7.patch || die epatch ${MY_PATCH_SOURCE}/040_all_tcpd-vars-fix.patch || die for d in ${S} ${S}/innobase; do @@ -257,6 +259,7 @@ src_compile() { for i in ${minimal_exclude_list}; do myconf="${myconf} --with-${i}" done + if useq static ; then myconf="${myconf} --without-raid" ewarn "disabling raid support, has problem with static" @@ -290,7 +293,7 @@ src_compile() { fi if version_is_at_least "4.1.3" ; then - myconf="${myconf} -with-geometry" + myconf="${myconf} --with-geometry" #myconf="${myconf} $(use_with geometry)" myconf="${myconf} $(use_with cluster ndbcluster)" fi @@ -446,12 +449,13 @@ src_install() { chown -R mysql:mysql "${D}/${DATADIR}" fi - #diropts "-m0755" - #dodir "/var/log/mysql" + diropts "-m0755" + dodir "/var/log/mysql" + # the following files fails with FEATURES="collision-protect" #touch ${D}/var/log/mysql/mysql.{log,err} #chmod 0660 ${D}/var/log/mysql/mysql.{log,err} - #keepdir "/var/log/mysql" - #chown -R mysql:mysql "${D}/var/log/mysql" + keepdir "/var/log/mysql" + chown -R mysql:mysql "${D}/var/log/mysql" diropts "-m0755" dodir "/var/run/mysqld" @@ -498,6 +502,21 @@ pkg_postinst() { einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream." } +pkg_postinst() { + # mind at FEATURES=collision-protect before to remove this + #empty dirs... + [ -d "${ROOT}/var/log/mysql" ] \ + || install -d -m0755 -o mysql -g mysql ${ROOT}/var/log/mysql + + #secure the logfiles... does this bother anybody? + touch ${ROOT}/var/log/mysql/mysql.{log,err} + chown mysql:mysql ${ROOT}/var/log/mysql/mysql* + chmod 0660 ${ROOT}/var/log/mysql/mysql* + # secure some directories + chmod 0750 ${ROOT}/var/log/mysql +} + + pkg_config() { mysql_get_datadir @@ -598,17 +617,3 @@ pkg_config() { einfo "done" } -pkg_postinst() { - # mind at FEATURES=collision-protect before to remove this - #empty dirs... - [ -d "${ROOT}/var/log/mysql" ] \ - || install -d -m0755 -o mysql -g mysql ${ROOT}/var/log/mysql - - #secure the logfiles... does this bother anybody? - touch ${ROOT}/var/log/mysql/mysql.{log,err} - chown mysql:mysql ${ROOT}/var/log/mysql/mysql* - chmod 0660 ${ROOT}/var/log/mysql/mysql* - # secure some directories - chmod 0750 ${ROOT}/var/log/mysql -} - diff --git a/dev-db/mysql/mysql-5.0.13_rc.ebuild b/dev-db/mysql/mysql-5.0.13_rc.ebuild index a58b002a1151..b15e8940656d 100644 --- a/dev-db/mysql/mysql-5.0.13_rc.ebuild +++ b/dev-db/mysql/mysql-5.0.13_rc.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2005 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-5.0.13_rc.ebuild,v 1.7 2005/10/22 16:51:04 vivo Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-5.0.13_rc.ebuild,v 1.8 2005/10/24 17:00:19 vivo Exp $ inherit eutils flag-o-matic versionator @@ -62,8 +62,9 @@ mysql_upgrade_warning() { ewarn "If you're upgrading from MySQL-3.x to 4.0, or 4.0.x to 4.1.x, you" ewarn "must recompile the other packages on your system that link with" ewarn "libmysqlclient after the upgrade completes. To obtain such a list" - ewarn "of packages for your system, you may use 'revdep-rebuild' from" - ewarn "app-portage/gentoolkit." + ewarn "of packages for your system, you may use:" + ewarn "revdep-rebuild --soname=libmysqlclient.so.14" + ewarn "from app-portage/gentoolkit." ewarn "" ewarn "the value of \"innodb_log_file_size\" into /etc/mysql/my.cnf file " ewarn "has changed size from \"8M\" to \"5M\"." diff --git a/dev-db/mysql/mysql-5.0.15.ebuild b/dev-db/mysql/mysql-5.0.15.ebuild new file mode 100644 index 000000000000..60afb78139de --- /dev/null +++ b/dev-db/mysql/mysql-5.0.15.ebuild @@ -0,0 +1,624 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-5.0.15.ebuild,v 1.1 2005/10/24 17:00:19 vivo Exp $ + +inherit eutils flag-o-matic versionator + +SVER=${PV%.*} +NEWP="${PN}-${PV}" +NEWP="${NEWP/_beta/-beta}" +NEWP="${NEWP/_rc/-rc}" + + +# shorten the path because the socket path length must be shorter than 107 chars +# and we will run a mysql server during test phase +S="${WORKDIR}/${PN}" + +DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" +HOMEPAGE="http://www.mysql.com/" +SRC_URI="mirror://mysql/Downloads/MySQL-${SVER}/${NEWP}.tar.gz + mirror://gentoo/mysql-extras-20050920.tar.bz2" + +LICENSE="GPL-2" +SLOT="0" +#KEYWORDS="~x86 ~amd64 ~sparc ~ia64 ~ppc ~ppc64" +KEYWORDS="~amd64 ~ppc ~x86" +IUSE="big-tables berkdb debug doc minimal perl readline selinux ssl static" +RESTRICT="primaryuri" + +DEPEND="readline? ( >=sys-libs/readline-4.1 ) + bdb? ( sys-apps/ed ) + ssl? ( >=dev-libs/openssl-0.9.6d ) + perl? ( dev-lang/perl ) + userland_GNU? ( sys-process/procps ) + >=sys-libs/zlib-1.2.3 + >=sys-apps/texinfo-4.7-r1 + >=sys-apps/sed-4" +RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )" +# dev-perl/DBD-mysql is needed by some scripts installed by MySQL +PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )" + +if version_is_at_least "4.1.3" ; then + # 2005-09-29 + # geometry has been removed due to repeated compile problems _without_ it. + # From now on it will be always enabled + IUSE="${IUSE} cluster utf8 extraengine" +fi + +mysql_upgrade_error() { + ewarn "Sorry, plain up/downgrade between different version of MySQL is (still)" + ewarn "un-supported." + ewarn "Some gentoo documentation on how to do it:" + ewarn "http://www.gentoo.org/doc/en/mysql-upgrading.xml" + ewarn "Also on the MySQL website:" + ewarn "http://dev.mysql.com/doc/refman/5.0/en/upgrading-from-4-1.html" + ewarn "" + ewarn "You can also choose to preview some new MySQL 4.1 behaviour" + ewarn "adding a section \"[mysqld-4.0]\" followed by the word \"new\"" + ewarn "into /etc/mysql/my.cnf (you need a recent MySQL version)" +} + +mysql_upgrade_warning() { + ewarn "If you're upgrading from MySQL-3.x to 4.0, or 4.0.x to 4.1.x, you" + ewarn "must recompile the other packages on your system that link with" + ewarn "libmysqlclient after the upgrade completes. To obtain such a list" + ewarn "of packages for your system, you may use:" + ewarn "revdep-rebuild --library=libmysqlclient.so.14" + ewarn "from app-portage/gentoolkit." + ewarn "" + ewarn "the value of \"innodb_log_file_size\" into /etc/mysql/my.cnf file " + ewarn "has changed size from \"8M\" to \"5M\"." + ewarn "To start mysql either revert the value back to \"8M\" or backup and" + ewarn "remove the old ib_logfile* from the datadir" +} + +mysql_get_datadir() { + DATADIR="" + if [ -f '/etc/mysql/my.cnf' ] ; then + #DATADIR=`/usr/sbin/mysqld --help |grep '^datadir' | awk '{print $2}'` + #DATADIR=`my_print_defaults mysqld | grep -- '^--datadir' | tail -n1 | sed -e 's|^--datadir=||'` + DATADIR=`my_print_defaults mysqld 2>/dev/null | sed -ne '/datadir/s|^--datadir=||p' | tail -n1` + if [ -z "${DATADIR}" ]; then + DATADIR=`grep ^datadir /etc/mysql/my.cnf | sed -e 's/.*= //'` + einfo "Using default DATADIR" + fi + fi + if [ -z "${DATADIR}" ]; then + DATADIR="/var/lib/mysql/" + einfo "Using default DATADIR" + fi + einfo "MySQL DATADIR is ${DATADIR}" + + if [ -z "${PREVIOUS_DATADIR}" ] ; then + if [ -a "${DATADIR}" ] ; then + ewarn "Previous datadir found, it's YOUR job to change" + ewarn "ownership and have care of it" + PREVIOUS_DATADIR="yes" + export PREVIOUS_DATADIR + else + PREVIOUS_DATADIR="no" + export PREVIOUS_DATADIR + fi + fi + + export DATADIR +} + +pkg_setup() { + + if [[ -z $MYSQL_STRAIGHT_UPGRADE ]] ; then + mysql_get_datadir + local curversion="dev-db/${PN}-${PV%.*}" + local oldversion="$(best_version dev-db/mysql)" + oldversion=${oldversion%.*} + + # permit upgrade from old version if it's safe + useq minimal && oldversion="" + built_with_use dev-db/mysql minimal && oldversion="" + [[ -d "${DATADIR}/mysql" ]] || oldversion="" + + if [[ -n "${oldversion}" ]] && [[ "${oldversion}" != "${curversion}" ]] + then + mysql_upgrade_error + eerror "MySQL-${oldversion} found, up/downgrade to \"${curversion}\" is unsupported" + eerror "export MYSQL_STRAIGHT_UPGRADE=1 to force" + die + fi + fi + + mysql_upgrade_warning + + enewgroup mysql 60 || die "problem adding group mysql" + enewuser mysql 60 -1 /dev/null mysql \ + || die "problem adding user mysql" + +} + +src_unpack() { + if useq static && useq ssl; then + local msg="MySQL does not support building statically with SSL support" + eerror "${msg}" + die "${msg}" + fi + + if version_is_at_least "4.1.3" \ + && useq cluster \ + || useq extraengine \ + && useq minimal ; then + die "USEs cluster, extraengine conflicts with \"minimal\"" + fi + + unpack ${A} || die + + mv "${WORKDIR}/${NEWP}" "${S}" + cd "${S}" + rm -rf "${S}/zlib/"*.[ch] + sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in" + + local MY_PATCH_SOURCE="${WORKDIR}/mysql-extras" + + epatch "${MY_PATCH_SOURCE}/010_all_my-print-defaults-r2.patch" || die + epatch "${MY_PATCH_SOURCE}/035_x86_asm-pic-fixes-r7.patch" || die + epatch "${MY_PATCH_SOURCE}/703_all_test-rpl_rotate_logs.patch" || die + #epatch "${MY_PATCH_SOURCE}/705_all_view_geometry.patch" || die + + find . -name Makefile -o -name Makefile.in -o -name configure -exec rm {} \; + aclocal && autoheader \ + || die "failed reconfigure step 01" + libtoolize --automake --force \ + || die "failed reconfigure step 02" + automake --force --add-missing && autoconf \ + || die "failed reconfigure step 03" + + if version_is_at_least "5.1_alpha" ; then + pushd storage/innobase || die "failed chdir" + else + pushd innobase || die "failed chroot" + fi + aclocal && autoheader && autoconf && automake + popd + + pushd bdb/dist && sh s_all \ + || die "failed bdb reconfigure" + popd + + # Temporary workaround for bug in test suite, a correct solution + # should work inside the include files to enable/disable the tests + # for the current configuration + + if ! useq extraengine ; then + einfo "disabling unneded extraengine tests" + local disable_test="archive bdb blackhole federated view csv" + for i in $disable_test ; do + mv "${S}/mysql-test/t/${i}.test" "${S}/mysql-test/t/${i}.disabled" \ + &> /dev/null + done + fi + + + if ! useq berkdb ; then + einfo "disabling unneded berkdb tests" + local disable_test="auto_increment bdb-alter-table-1 bdb-alter-table-2 bdb-crash bdb-deadlock bdb bdb_cache binlog ctype_sjis ctype_utf8 heap_auto_increment index_merge_bdb multi_update mysqldump ps_1general ps_6bdb rowid_order_bdb" + for i in $disable_test ; do + mv "${S}/mysql-test/t/${i}.test" "${S}/mysql-test/t/${i}.disabled" \ + &> /dev/null + done + fi + +} + +src_compile() { + local myconf + + # readline pair reads backwards on purpose, DONT change it around, Ok? + # this is because it refers to the building of a bundled readline + # versus the system copy + useq readline && myconf="${myconf} --without-readline" + useq readline || myconf="${myconf} --with-readline" + + if useq static ; then + myconf="${myconf} --with-mysqld-ldflags=-all-static" + myconf="${myconf} --with-client-ldflags=-all-static" + myconf="${myconf} --disable-shared" + else + myconf="${myconf} --enable-shared --enable-static" + fi + + #myconf="${myconf} `use_with tcpd libwrap`" + myconf="${myconf} --without-libwrap" + + if useq ssl ; then + # --with-vio is not needed anymore, it's on by default and + # has been removed from configure + version_is_at_least "5.0.4_beta" || myconf="${myconf} --with-vio" + if version_is_at_least "5.0.6_beta" ; then + # yassl-0.96 is young break with gcc-4.0 || amd64 + #myconf="${myconf} --with-yassl" + myconf="${myconf} --with-openssl" + else + myconf="${myconf} --with-openssl" + fi + else + myconf="${myconf} --without-openssl" + fi + + if useq debug; then + myconf="${myconf} --with-debug=full" + else + myconf="${myconf} --without-debug" + version_is_at_least "4.1.3" && useq cluster && myconf="${myconf} --without-ndb-debug" + fi + + # benchmarking stuff needs perl + # and shouldn't be bothered with on minimal builds + if useq perl && ! useq minimal; then + myconf="${myconf} --with-bench" + else + myconf="${myconf} --without-bench" + fi + + # these are things we exclude from a minimal build + # note that the server actually does get built and installed + # but we then delete it before packaging. + local minimal_exclude_list="server embedded-server extra-tools innodb" + if ! useq minimal; then + for i in ${minimal_exclude_list}; do + myconf="${myconf} --with-${i}" + done + if useq static ; then + myconf="${myconf} --without-raid" + ewarn "disabling raid support, has problem with static" + else + myconf="${myconf} --with-raid" + fi + + if ! version_is_at_least "5.0_alpha" ; then + if version_is_at_least "4.1_alpha" && useq utf8; then + myconf="${myconf} --with-charset=utf8" + myconf="${myconf} --with-collation=utf8_general_ci" + else + myconf="${myconf} --with-charset=latin1" + myconf="${myconf} --with-collation=latin1_swedish_ci" + fi + fi + + # lots of chars + myconf="${myconf} --with-extra-charsets=all" + + #The following fix is due to a bug with bdb on sparc's. See: + #http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8 + # it comes down to non-64-bit safety problems + if useq sparc || useq alpha || useq hppa || useq mips || useq amd64 + then + myconf="${myconf} --without-berkeley-db" + else + useq berkdb \ + && myconf="${myconf} --with-berkeley-db=./bdb" \ + || myconf="${myconf} --without-berkeley-db" + fi + + if version_is_at_least "4.1.3" ; then + #myconf="${myconf} $(use_with geometry)" + myconf="${myconf} --with-geometry" + myconf="${myconf} $(use_with cluster ndbcluster)" + fi + + version_is_at_least "4.1.11_alpha20050403" && myconf="${myconf} --with-big-tables" + else + for i in ${minimal_exclude_list}; do + myconf="${myconf} --without-${i}" + done + myconf="${myconf} --without-berkeley-db" + myconf="${myconf} --with-extra-charsets=none" + fi + + # documentation + myconf="${myconf} `use_with doc docs`" + + if version_is_at_least "4.1.3" && useq extraengine; then + # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html + myconf="${myconf} --with-archive-storage-engine" + # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html + version_is_at_least "4.1.4" \ + && myconf="${myconf} --with-csv-storage-engine" + # http://dev.mysql.com/doc/mysql/en/federated-description.html + # http://dev.mysql.com/doc/mysql/en/federated-limitations.html + if version_is_at_least "5.0.3" ; then + einfo "before to use federated engine be sure to read" + einfo "http://dev.mysql.com/doc/mysql/en/federated-limitations.html" + myconf="${myconf} --with-federated-storage-engine" + fi + version_is_at_least "4.1.11_alpha20050403" \ + && myconf="${myconf} --with-blackhole-storage-engine" + fi + + myconf="${myconf} `use_with big-tables`" + + #glibc-2.3.2_pre fix; bug #16496 + append-flags "-DHAVE_ERRNO_AS_DEFINE=1" + + #the compiler flags are as per their "official" spec ;) + #CFLAGS="${CFLAGS/-O?/} -O3" \ + export CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" + version_is_at_least "5.0_alpha" \ + && export CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" + + econf \ + --libexecdir=/usr/sbin \ + --sysconfdir=/etc/mysql \ + --localstatedir=/var/lib/mysql \ + --with-low-memory \ + --enable-assembler \ + --enable-local-infile \ + --with-mysqld-user=mysql \ + --with-client-ldflags=-lstdc++ \ + --enable-thread-safe-client \ + --with-comment="Gentoo Linux ${PF}" \ + --with-unix-socket-path=/var/run/mysqld/mysqld.sock \ + --with-zlib-dir=/usr \ + --with-lib-ccflags="-fPIC" \ + ${myconf} || die "bad ./configure" + + emake || die "compile problem" +} + +src_test() { + cd ${S} + einfo ">>> Test phase [check]: ${CATEGORY}/${PF}" + make check || die "make check failed" + if ! useq minimal; then + einfo ">>> Test phase [test]: ${CATEGORY}/${PF}" + local retstatus + addpredict /this-dir-does-not-exist/t9.MYI + + version_is_at_least "5.0.15" \ + && make test-force-pl \ + || make test-pl + retstatus=$? + + # to be sure ;) + pkill -9 -f "${S}/ndb" 2>/dev/null + pkill -9 -f "${S}/sql" 2>/dev/null + [[ $retstatus -eq 0 ]] || die "make test failed" + else + einfo "Skipping server tests due to minimal build." + fi +} + +src_install() { + mysql_get_datadir + make install DESTDIR="${D}" benchdir_root="/usr/share/mysql" || die + + # move client libs, install a couple of missing headers + local lib=$(get_libdir) + mv ${D}/usr/${lib}/mysql/libmysqlclient*.so* ${D}/usr/${lib} + dosym ../libmysqlclient.so /usr/${lib}/mysql/libmysqlclient.so + dosym ../libmysqlclient_r.so /usr/${lib}/mysql/libmysqlclient_r.so + insinto /usr/include/mysql ; doins include/{my_config.h,my_dir.h} + + # convenience links + dosym /usr/bin/mysqlcheck /usr/bin/mysqlanalyze + dosym /usr/bin/mysqlcheck /usr/bin/mysqlrepair + dosym /usr/bin/mysqlcheck /usr/bin/mysqloptimize + + # various junk + rm -f ${D}/usr/bin/make*distribution + rm -f ${D}/usr/share/mysql/make_*_distribution + rm -f ${D}/usr/share/mysql/mysql.server + rm -f ${D}/usr/share/mysql/binary-configure + rm -f ${D}/usr/share/mysql/mysql-log-rotate + rm -f ${D}/usr/share/mysql/{post,pre}install + rm -f ${D}/usr/share/mysql/mi_test* + rm -f ${D}/usr/share/mysql/*.spec # Redhat gunk + rm -f ${D}/usr/share/mysql/*.plist # Apple gunk + rm -f ${D}/usr/share/mysql/my-*.cnf # Put them elsewhere + + # All of these (ab)use Perl. + if ! useq perl; then + rm -f ${D}/usr/bin/{mysqlhotcopy,mysql_find_rows,mysql_convert_table_format,mysqld_multi,mysqlaccess,mysql_fix_extensions,mysqldumpslow,mysql_zap,mysql_explain_log,mysql_tableinfo,mysql_setpermission} + rm -f ${D}/usr/bin/mysqlhotcopy + rm -rf ${D}/usr/share/mysql/sql-bench + fi + + # clean up stuff for a minimal build + # this is anything server-specific + if useq minimal; then + rm -rf ${D}/usr/share/mysql/{mysql-test,sql-bench} + rm -f ${D}/usr/bin/{mysql_install_db,mysqlmanager*,mysql_secure_installation,mysql_fix_privilege_tables,mysqlhotcopy,mysql_convert_table_format,mysqld_multi,mysql_fix_extensions,mysql_zap,mysql_explain_log,mysql_tableinfo,mysqld_safe,myisam*,isam*,mysql_install,mysql_waitpid,mysqlbinlog,mysqltest,pack_isam} + rm -f ${D}/usr/sbin/mysqld + rm -f ${D}/usr/lib/mysql/lib{heap,merge,nisam,mysys,mystrings,mysqld,myisammrg,vio,dbug,myisam}.a + fi + + # config stuff + insinto /etc/mysql + doins scripts/mysqlaccess.conf + + newins "${FILESDIR}/my.cnf-4.1" my.cnf + + if version_is_at_least "4.1.3" && ! useq utf8; then + sed --in-place -e "s/utf8/latin1/" \ + ${D}/etc/mysql/my.cnf + fi + + # minimal builds don't have the server + if ! useq minimal; then + exeinto /etc/init.d + newexe "${FILESDIR}/mysql-4.0.24-r2.rc6" mysql + insinto /etc/logrotate.d + newins "${FILESDIR}/logrotate.mysql" mysql + + #empty dirs... + diropts "-m0750" + if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then + dodir "${DATADIR}" + keepdir "${DATADIR}" + chown -R mysql:mysql "${D}/${DATADIR}" + fi + + diropts "-m0755" + dodir "/var/log/mysql" + # the following files fails with FEATURES="collision-protect" + #touch ${D}/var/log/mysql/mysql.{log,err} + #chmod 0660 ${D}/var/log/mysql/mysql.{log,err} + keepdir "/var/log/mysql" + chown -R mysql:mysql "${D}/var/log/mysql" + + diropts "-m0755" + dodir "/var/run/mysqld" + + keepdir "/var/run/mysqld" + chown -R mysql:mysql \ + "${D}/var/run/mysqld" + fi + + # docs + dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE + # minimal builds don't have the server + if useq doc && ! useq minimal; then + dohtml Docs/*.html + dodoc Docs/manual.{txt,ps} + docinto conf-samples + dodoc support-files/my-*.cnf + fi +} + +pkg_preinst() { + enewgroup mysql 60 || die "problem adding group mysql" + enewuser mysql 60 -1 /dev/null mysql \ + || die "problem adding user mysql" +} + +pkg_postinst() { + mysql_get_datadir + + if ! useq minimal; then + # your friendly public service announcement... + einfo + einfo "You might want to run:" + einfo "\"emerge --config =${PF}\"" + einfo "if this is a new install." + einfo + if [[ "${PREVIOUS_DATADIR}" == "yes" ]] ; then + ewarn "Previous datadir found, it's YOUR job to change" + ewarn "ownership and have care of it" + fi + fi + + mysql_upgrade_warning + einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream." +} + +pkg_postinst() { + # mind at FEATURES=collision-protect before to remove this + #empty dirs... + [ -d "${ROOT}/var/log/mysql" ] \ + || install -d -m0755 -o mysql -g mysql ${ROOT}/var/log/mysql + + #secure the logfiles... does this bother anybody? + touch ${ROOT}/var/log/mysql/mysql.{log,err} + chown mysql:mysql ${ROOT}/var/log/mysql/mysql* + chmod 0660 ${ROOT}/var/log/mysql/mysql* + # secure some directories + chmod 0750 ${ROOT}/var/log/mysql +} + +pkg_config() { + mysql_get_datadir + + if built_with_use dev-db/mysql minimal; then + die "Minimal builds do NOT include the MySQL server" + fi + + if [[ "$(pgrep mysqld)" != "" ]] ; then + die "Oops you already have a mysql daemon running!" + fi + + local pwd1="a" + local pwd2="b" + local maxtry=5 + + if [[ -d "${DATADIR}/mysql" ]] ; then + ewarn "You have already a MySQL database in place." + ewarn "Please rename it or delete it if you wish to replace it." + die "MySQL database already exists!" + fi + + einfo "Creating the mysql database and setting proper" + einfo "permissions on it..." + + einfo "Insert a password for the mysql 'root' user" + ewarn "Avoid [\"'\\_%] characters in the password" + + read -rsp " >" pwd1 ; echo + einfo "Check the password" + read -rsp " >" pwd2 ; echo + + if [[ "x$pwd1" != "x$pwd2" ]] ; then + die "Passwords are not the same" + fi + + ${ROOT}/usr/bin/mysql_install_db || die "MySQL databases not installed" + + # MySQL 5.0 don't need this + chown -R mysql:mysql ${DATADIR} + chmod 0750 ${ROOT}/${DATADIR} + + local options="" + local sqltmp="$(emktemp)" + local help_tables="${ROOT}/usr/share/mysql/fill_help_tables.sql" + + if version_is_at_least "4.1.3" ; then + options="--skip-ndbcluster" + + # Filling timezones, see + # http://dev.mysql.com/doc/mysql/en/time-zone-support.html + ${ROOT}/usr/bin/mysql_tzinfo_to_sql ${ROOT}/usr/share/zoneinfo \ + > "${sqltmp}" + + if [[ -r "${help_tables}" ]] ; then + cat "${help_tables}" >> "${sqltmp}" + fi + fi + + local socket=${ROOT}/var/run/mysqld/mysqld.sock + local mysqld="${ROOT}/usr/sbin/mysqld \ + ${options} \ + --skip-grant-tables \ + --basedir=${ROOT}/usr \ + --datadir=${ROOT}/var/lib/mysql \ + --skip-innodb \ + --skip-bdb \ + --max_allowed_packet=8M \ + --net_buffer_length=16K \ + --socket=${socket} \ + --pid-file=${ROOT}/var/run/mysqld/mysqld.pid" + + $mysqld & + while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] + do + maxtry=$(($maxtry-1)) + echo -n "." + sleep 1 + done + + # do this from memory we don't want clear text password in temp files + local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'" + ${ROOT}/usr/bin/mysql \ + --socket=${ROOT}/var/run/mysqld/mysqld.sock \ + -hlocalhost \ + -e "${sql}" + + einfo "Loading \"zoneinfo\" this step may require few seconds" + + ${ROOT}/usr/bin/mysql \ + --socket=${socket} \ + -hlocalhost \ + -uroot \ + -p"${pwd1}" \ + mysql < "${sqltmp}" + + kill $( cat ${ROOT}/var/run/mysqld/mysqld.pid ) + rm "${sqltmp}" + einfo "done" +} + |