summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFrancesco Riosa <vivo@gentoo.org>2006-04-13 12:55:40 +0000
committerFrancesco Riosa <vivo@gentoo.org>2006-04-13 12:55:40 +0000
commit0a56f85d9b504f6522f1cdc79b28db0544e8a378 (patch)
tree36c0c237f01c691d6b26cd81a6be49165b256a69 /dev-db/mysql
parentreadding mysql-4.1.14 (diff)
downloadgentoo-2-0a56f85d9b504f6522f1cdc79b28db0544e8a378.tar.gz
gentoo-2-0a56f85d9b504f6522f1cdc79b28db0544e8a378.tar.bz2
gentoo-2-0a56f85d9b504f6522f1cdc79b28db0544e8a378.zip
readding mysql-4.1.14
(Portage version: 2.0.54)
Diffstat (limited to 'dev-db/mysql')
-rw-r--r--dev-db/mysql/Manifest74
-rw-r--r--dev-db/mysql/files/digest-mysql-4.1.142
-rw-r--r--dev-db/mysql/mysql-4.1.14.ebuild612
3 files changed, 616 insertions, 72 deletions
diff --git a/dev-db/mysql/Manifest b/dev-db/mysql/Manifest
index a74cb091bd30..d5958e1ff17a 100644
--- a/dev-db/mysql/Manifest
+++ b/dev-db/mysql/Manifest
@@ -1,103 +1,33 @@
------BEGIN PGP SIGNED MESSAGE-----
-Hash: SHA1
-
MD5 031cbb3d5c108373f1206b0ffd30d714 ChangeLog 65837
-RMD160 e2edcee998c817d0a0fa3405b4bd32ee0351b282 ChangeLog 65837
-SHA256 a03d24e6827d2e020a62d65bedcb4423b60c75df95ccf05209de851153f3e836 ChangeLog 65837
MD5 7ff18823ff47cc6f2a8a97562393e509 files/digest-mysql-3.23.58-r1 332
-RMD160 e75ea6d541e5965418aae1cc981daf9cac675568 files/digest-mysql-3.23.58-r1 332
-SHA256 3188cb980032a8904aff4bd3e3a2692b188ecba144c055b2832980f225ca1536 files/digest-mysql-3.23.58-r1 332
MD5 f46e4cce1614b8836c7db841ffa3156f files/digest-mysql-4.0.25-r2 331
-RMD160 9f8335c5838a34dcf5c29dc555f533b5bf03b6cc files/digest-mysql-4.0.25-r2 331
-SHA256 73e7594c9077f91f96b89e2528e2aed4f31c8d28bf4bb0acdffbfc7c5df81f7c files/digest-mysql-4.0.25-r2 331
MD5 1c7b9fbd650a5aa48bdff4ac53285ff2 files/digest-mysql-4.0.26 331
-RMD160 46f2f9d5a4cac98484c52be45a6f29bbc9440c6a files/digest-mysql-4.0.26 331
-SHA256 ed1d917cb6618a539759cb9ad74afe07cf10d3b8e2a76975ce2a473a8becf67d files/digest-mysql-4.0.26 331
+MD5 4e6e76e3945e29b6795ce6d1a66bc98f files/digest-mysql-4.1.14 139
MD5 952476d6f938513831408e00c4e11a25 files/digest-mysql-4.1.14-r1 331
-RMD160 3cb6e15c4ec0735a07acad9a717d05193dc28108 files/digest-mysql-4.1.14-r1 331
-SHA256 3da2d689a001c4fd4fc4a3fb137cb9baa042a6a793a119c5d810064e62f6045a files/digest-mysql-4.1.14-r1 331
MD5 c5d06b52808e93245bf66777e3774059 files/digest-mysql-4.1.18-r61 509
-RMD160 bbfedc0da467cf81cc71bc62fc69649394f15949 files/digest-mysql-4.1.18-r61 509
-SHA256 9129853d9bfee626dafa39981b6f8798ddd3874e57fb37c8f87534eea3edfc5e files/digest-mysql-4.1.18-r61 509
MD5 c254d0ff45e50dd27871b015cab39b2d files/digest-mysql-5.0.19-r1 509
-RMD160 a0ced5cf6cc8dc623c8d882f52330fdcc4eb02bd files/digest-mysql-5.0.19-r1 509
-SHA256 4d06587767c5a1cf1d6119514f3d10336d069790884b2ab3a044919cda23f539 files/digest-mysql-5.0.19-r1 509
MD5 1960fc44fdd8eaaa78c5785f6a3df741 files/digest-mysql-5.1.7_beta 332
-RMD160 436ba2df164ff2d5d1218057eebe7b6f03ed3968 files/digest-mysql-5.1.7_beta 332
-SHA256 5dc04639527e9f7c078f25f8190188d7c8f36df0d01c7e1e9e8ffce9f182dd14 files/digest-mysql-5.1.7_beta 332
MD5 631d741e2c56442abacaa4c1ca5db499 files/logrotate-slot.mysql 502
-RMD160 733fca29244c8e86503c9e4e4f7f2fc7df97be69 files/logrotate-slot.mysql 502
-SHA256 a83b0adc3cde04c4ee2f430d732d094bb2f35ff74d65ca173714768455249879 files/logrotate-slot.mysql 502
MD5 d200345efa421d012cf858134d2c8884 files/logrotate.mysql 440
-RMD160 60fafc24863f848f2ecff6cf225455707ca20941 files/logrotate.mysql 440
-SHA256 21697d841ea5e35409a40c4e38180ffa9891bcb932d13aa475bf61d1702a68d2 files/logrotate.mysql 440
MD5 f1fc8bfe540d6f1268b53b7cad275080 files/my.cnf 1231
-RMD160 21aad0c2aa4aecc5963043e5127c0648b4e4fa5c files/my.cnf 1231
-SHA256 303d5a4344c40246974e849a18c66508234961e7ba325cbc0f75777463283776 files/my.cnf 1231
MD5 a8f89d11a0913332c5f8c1da5a21cc3f files/my.cnf-4.0.14-r1 2816
-RMD160 5ac744b54b81fc47b5cdce9a86fed5e3fb729623 files/my.cnf-4.0.14-r1 2816
-SHA256 0e45f72f03ba45aa611065280802a12e5931f2a805fe82f8ae3d5b8caeca5f05 files/my.cnf-4.0.14-r1 2816
MD5 9946a8f7163970ec4f6a713c97eadbe0 files/my.cnf-4.0.24-r1 4271
-RMD160 97fa49f4eaa157931137a29c5c438533451c3c4d files/my.cnf-4.0.24-r1 4271
-SHA256 aafe65eb29b759c0cf19d81f3e26d95981a67662d3804454847cc4854839a34b files/my.cnf-4.0.24-r1 4271
MD5 277705080f05b5b98b815487e080e562 files/my.cnf-4.1 4068
-RMD160 28f61031229c1066e4b3122a624ea3ce050f8c39 files/my.cnf-4.1 4068
-SHA256 6d5ce7c495a09182fa57f2d148f0d76ecbaed8dfefe1804cd387713a4f7ac054 files/my.cnf-4.1 4068
MD5 ae9ccd995f24a6a958be80cc1abdf758 files/my.cnf-4.1-r1 4165
-RMD160 177710c3af04503c6dc77bb36935350bb631c763 files/my.cnf-4.1-r1 4165
-SHA256 5d2580be1a40683ce1e3217cd1101c9e25857117b90b7627b72997d1d1fdea7a files/my.cnf-4.1-r1 4165
MD5 625b4007f035e3da9a4f1eeee1db6b9c files/mysql-4.0.15.rc6 1187
-RMD160 f0ef64b31bcf919f4e63ba3eab679a4db9074f80 files/mysql-4.0.15.rc6 1187
-SHA256 62ed0c50ad425b856ef627f2e825841081c829fc33d57d4d34313635b7c03998 files/mysql-4.0.15.rc6 1187
MD5 d0fbdf4e41f2b52210eef6cb3a53e128 files/mysql-4.0.24-r1.rc6 1662
-RMD160 44285f44b40fc143c77b34c6b4adc7df0cf1502c files/mysql-4.0.24-r1.rc6 1662
-SHA256 df9d9e80bdf69023e1692691a4e7f32d605b635fee8b1d6fbed58117f199a6d5 files/mysql-4.0.24-r1.rc6 1662
MD5 356c1b4211a0b3d229bcb09c7c8742a7 files/mysql-4.0.24-r2.rc6 2151
-RMD160 135141528b176b9210c35c0b3b49101f7d16c872 files/mysql-4.0.24-r2.rc6 2151
-SHA256 15c87eeac5ecabb1ba18ad6671e006f5a89c4bf69cfb016e71385658e02c8753 files/mysql-4.0.24-r2.rc6 2151
MD5 048977e1cd12b4d57554468962c0b996 files/mysql.conf.d-r1 3154
-RMD160 3955e1ba119a23e4b8f67f1aca956f0f72c53149 files/mysql.conf.d-r1 3154
-SHA256 6269c09a01c1b210a07c520d32b74bc70e371b5a14691de535997c36a4ef50b5 files/mysql.conf.d-r1 3154
MD5 73be6460f548f6f73c70246a4cfd13a0 files/mysql.init 886
-RMD160 26b8aa45af3f930db01f0db731865b9293626fb1 files/mysql.init 886
-SHA256 2d7faf6d88fd13e5c10368a20074fdb59554635f8b1fd17e088d82208e611c12 files/mysql.init 886
MD5 b5c8391aa5e4452a95ff2ae393489b7e files/mysql.rc6-r3 10482
-RMD160 96bc9325229168627e6f4a194ee02e2ceb299f3a files/mysql.rc6-r3 10482
-SHA256 cf5201af1ce6046c517bc3e783683c3ac8dde861918b2043a3bed4496de86115 files/mysql.rc6-r3 10482
MD5 9ff84042930f67b14f418a9dcf78d860 files/mysqlmanager.conf.d 1021
-RMD160 3868b32a4ac59a89ae870299d8ecf684ba2d320e files/mysqlmanager.conf.d 1021
-SHA256 5b36b46e0a5ec1afbf8ae659ad7f901289421ecf1b100924c5fe4db11bbd1475 files/mysqlmanager.conf.d 1021
MD5 0b2151ed331b57b7bc3aa91d2c3d1627 files/mysqlmanager.rc6 6620
-RMD160 572df2aa4c49f10be1f186d0ba27ef5252a5849d files/mysqlmanager.rc6 6620
-SHA256 6d64bd796a55663dd76f8dd863c52ec3bc9cab5f7042d98899d1776d7baabdcc files/mysqlmanager.rc6 6620
MD5 8f52aa6b66453e37faae0d669e55ca9a metadata.xml 301
-RMD160 406132008e652ab8f5a273d1f5cefc6e2b50c358 metadata.xml 301
-SHA256 94c8a5dc776f0da424cb99dc9531cc27746c7bb5b2ed06490667e382b0f024a7 metadata.xml 301
MD5 0a98ffc228fea2a1a073880b2120dc68 mysql-3.23.58-r1.ebuild 7232
-RMD160 8dccb272ad58c1338c219aeb0327ad45522b05bf mysql-3.23.58-r1.ebuild 7232
-SHA256 6d461c9d360a41d4c9c7dafbc5744a3222a00a417fe439da4aebee276c956b38 mysql-3.23.58-r1.ebuild 7232
MD5 f94b563ca70600760eef7d7c49ead7d1 mysql-4.0.25-r2.ebuild 14244
-RMD160 993403a93bd268664b271473e21e9bd313119ddf mysql-4.0.25-r2.ebuild 14244
-SHA256 33d0c47739273e00026fbeca8ae9826bfeca8bc54a08eff9f6031368bcbb334f mysql-4.0.25-r2.ebuild 14244
MD5 fe9c5e4f733064d52715afcb21b51a72 mysql-4.0.26.ebuild 14873
-RMD160 fe7cc5754a39fc1eee543723d16e3a502ce94bc8 mysql-4.0.26.ebuild 14873
-SHA256 0c83c9795d5db2fceed61fc63f56b154082b898396af59b23e7c9cf739d51388 mysql-4.0.26.ebuild 14873
MD5 1bfb13b5fb87a3958bc0c49a5c04af99 mysql-4.1.14-r1.ebuild 925
-RMD160 40edd18cd52131d7f1d81e857f2c1dc0ed0d42c8 mysql-4.1.14-r1.ebuild 925
-SHA256 3a4e8e7a76180eb139c0394d4646ac850063e268a43e6d6f20b6147213a5c490 mysql-4.1.14-r1.ebuild 925
+MD5 57c460cdf0befdaecc7a5fd02b21d4db mysql-4.1.14.ebuild 18837
MD5 2c1a54e4e02d82534b7ac7a08b875d21 mysql-4.1.18-r61.ebuild 937
-RMD160 51df48055b46925c75f463f4285feb249a6084d5 mysql-4.1.18-r61.ebuild 937
-SHA256 4c4fad74e1242fc991886074185e41ae075039976a9b69ef9d5cb6d55317a515 mysql-4.1.18-r61.ebuild 937
MD5 62ff2058887c638dabab29aea6b39e14 mysql-5.0.19-r1.ebuild 936
-RMD160 21c94129119896dba3a1c2c5a984e5f1e17fd52d mysql-5.0.19-r1.ebuild 936
-SHA256 713075defac03f75f9972161ae018c85b6f8c5cf7feb4474f9aec4a1957c67f4 mysql-5.0.19-r1.ebuild 936
MD5 3bf1353ca70930e5e062eca3f3c7c91e mysql-5.1.7_beta.ebuild 883
-RMD160 c1888885e9b838a4b766b233f9629938c61c950d mysql-5.1.7_beta.ebuild 883
-SHA256 94ad2ab575a7fcd33cab94941a2e8dd65da612bea67a852358b7c8f301343566 mysql-5.1.7_beta.ebuild 883
------BEGIN PGP SIGNATURE-----
-Version: GnuPG v1.4.2.2 (GNU/Linux)
-
-iD8DBQFEPKK4OpjtAl+gMRURAkCnAJ4rDONT4tleXyHFRKXR+0UTc9iOoACeI29y
-ap9J3obEVvcL+FTvfWLhPjQ=
-=SoA1
------END PGP SIGNATURE-----
diff --git a/dev-db/mysql/files/digest-mysql-4.1.14 b/dev-db/mysql/files/digest-mysql-4.1.14
new file mode 100644
index 000000000000..530f960597fe
--- /dev/null
+++ b/dev-db/mysql/files/digest-mysql-4.1.14
@@ -0,0 +1,2 @@
+MD5 98ba9caea24b0a48ee06bb242ff2e37f mysql-4.1.14.tar.gz 17074439
+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
new file mode 100644
index 000000000000..d5f6136087d5
--- /dev/null
+++ b/dev-db/mysql/mysql-4.1.14.ebuild
@@ -0,0 +1,612 @@
+# Copyright 1999-2006 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.36 2006/04/13 12:55:40 vivo Exp $
+
+inherit eutils gnuconfig flag-o-matic versionator
+
+SVER=${PV%.*}
+NEWP="${PN}-${PV}"
+#NEWP="${NEWP/_beta/-beta}"
+
+
+# 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="alpha amd64 arm hppa ia64 ppc ppc64 s390 sh sparc x86"
+IUSE="big-tables berkdb debug doc minimal perl readline selinux ssl static tcpd"
+RESTRICT="primaryuri"
+
+DEPEND="readline? ( >=sys-libs/readline-4.1 )
+ berkdb? ( sys-apps/ed )
+ tcpd? ( >=sys-apps/tcp-wrappers-7.6-r6 )
+ 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
+ IUSE="${IUSE} cluster utf8 geometry 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/4.1/en/upgrading-from-4-0.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)"
+ ewarn ""
+
+}
+
+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.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\"."
+ 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 geometry \
+ || useq extraengine \
+ && useq minimal ; then
+ die "USEs cluster, geometry, 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-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
+ cd ${d}
+ # WARNING, plain autoconf breaks it!
+ #autoconf
+ # must use this instead
+ WANT_AUTOCONF="2.59" autoreconf --force
+ # Fix the evil "libtool.m4 and ltmain.sh have a version mismatch!"
+ libtoolize --copy --force
+ # Saving this for a rainy day, in case we need it again
+ #WANT_AUTOMAKE=1.7 automake
+ gnuconfig_update
+ done
+
+ # 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`"
+
+ 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} $(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-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
+
+ # Temporary removed, 4.1.14 use mysql-test-run.pl instead
+ # of mysql-test-run, thus failing on test that should be
+ # skipped.
+ #version_is_at_least "5.0.6_beta" \
+ #&& make test-force \
+ #|| make test
+
+ # <replace me whenever possible>
+ cd mysql-test; ./mysql-test-run && ./mysql-test-run --ps-protocol
+ retstatus=$?
+ cd ..
+ # </replace me whenever possible>
+
+ # 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"
+ #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
+
+ # 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
+
+ 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
+ fi
+
+ mysql_upgrade_warning
+ einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream."
+}
+
+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 "${ROOT}/${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 ${ROOT}/${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}/${DATADIR} \
+ --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"
+}