Gentoo Archives: gentoo-commits

From: Brian Evans <grknight@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] proj/mysql:master commit in: dev-db/mysql/
Date: Wed, 31 Jul 2019 13:57:16
Message-Id: 1564580260.b9182e17ea734829f956c24015804dba4099c248.grknight@gentoo
1 commit: b9182e17ea734829f956c24015804dba4099c248
2 Author: Brian Evans <grknight <AT> gentoo <DOT> org>
3 AuthorDate: Wed Jul 31 13:37:40 2019 +0000
4 Commit: Brian Evans <grknight <AT> gentoo <DOT> org>
5 CommitDate: Wed Jul 31 13:37:40 2019 +0000
6 URL: https://gitweb.gentoo.org/proj/mysql.git/commit/?id=b9182e17
7
8 dev-db/mysql: Add final 5.5 version - 5.5.62
9
10 Signed-off-by: Brian Evans <grknight <AT> gentoo.org>
11
12 dev-db/mysql/Manifest | 24 +-
13 dev-db/mysql/mysql-5.5.62.ebuild | 797 +++++++++++++++++++++++++++++++++++++++
14 2 files changed, 799 insertions(+), 22 deletions(-)
15
16 diff --git a/dev-db/mysql/Manifest b/dev-db/mysql/Manifest
17 index 888caa3..d5672e5 100644
18 --- a/dev-db/mysql/Manifest
19 +++ b/dev-db/mysql/Manifest
20 @@ -1,11 +1,9 @@
21 ------BEGIN PGP SIGNED MESSAGE-----
22 -Hash: SHA256
23 -
24 DIST mysql-4.0.27.tar.gz 11152643 SHA256 c79f83bed7c1ea98e018b8829375b55c1de838d21a526d7f679becc75de00d0f SHA512 188283133e99e1c0b52ac8650aff325d7c9762fbad526c2c67b26dd614f2a86afb247a3f55ff071be1d44cd13060b9d7cca08ba1d758a04d2369381fa104454e WHIRLPOOL d3964468635eae0caf7fc8fb7b3576da12d49264bd9b797bb2191da8c6b91ca46321fb090e994df2b93b43f50686dcc4f735bdff03b49a3176fa746d5c4a60ab
25 DIST mysql-4.1.22.tar.gz 17761101 SHA256 6bd2436fd0f233bb1518e15975cb4e9fa4434acb53c3c3cd7d4648219abf58e9 SHA512 9de1c2b27cf428a10f67a6217fc2783b638beb6345e2127a4163ceb286073886d223de861c40be0ab36ea78ec5f33ccd5ee457d1e35e67b081d629118b68d390 WHIRLPOOL b40ca2e0d07fc0bd504e57b7eb005d36cf842bb668e93722c723bcc5a797dc9b456ee8971ea99bfc2b9119a2e19ee599f8441eb4601709eb4238196a27319257
26 DIST mysql-5.0.96.tar.gz 22686667 SHA256 43853814775158aa1650f483530a7dde153957579e3349e3ec780b89d741fc84 SHA512 2e3b4ac221c1c1c11618dc79067a7feff680380fcea435813287b02cb0dff45fb5a32a4393c53cf13165f6efc99dbf347a9388ad364cfdf2e392760a310aa5a9 WHIRLPOOL 3e167e4ff4c56095fbdee55b7e619c9b7ad2120eb72c9a58fe77a023ab6e7498c74e2053876e61687d7812f9ff7022303728ddda49732e7569035684263d2517
27 DIST mysql-5.1.73.tar.gz 24023347 SHA256 05ebe21305408b24407d14b77607a3e5ffa3c300e03f1359d3066f301989dcb5 SHA512 2e3651ebc1370dad7e01158cdd99133ed3f90c985114766b6282d58b743ae7bce16db797e82819fa5bbc2fa53d89811fd76b278c7459338288e7957634a8c3ff WHIRLPOOL f47c3fe1cd98b8ca2163646c760bd9763c65eab0591b31fe30a8c55c72c8b10d7b549b394493695cf98f50999364409ef8158661141277e6d99b011835aef942
28 DIST mysql-5.5.60.tar.gz 21025041 SHA256 a34112e1748823f6dfd0d129fe29a629cf35b8702f9dfaf1f24caf89ab523d1c SHA512 734395f3ce2c12e7703fe48d5bb2ce85ff8d7f04ae51cbe2d04a46b72b9689f804e5b498ae0b4722b0c098e2eed43d4f93b622964059525e6d9d14a47d55f775 WHIRLPOOL cf00fad25570cc991c4f4666667cb35a7fdec3831e233f2647c99761c1bcec665fc9a425608b40111095ffe8fddd37bf2a184880c7e698337999c5022e746abf
29 +DIST mysql-5.5.62.tar.gz 21111902 SHA256 b1e7853bc1f04aabf6771e0ad947f35ac8d237f4b35d0706d1095c9526ff99d7 SHA512 1080a3989c20bbbfe98739f99dacd183f2087ceee5147845852144240386808568af4c908ecdbccdcb6114000ab760ed7257492834d50018eff9520260fd91ce WHIRLPOOL f55b30e0839025180945d9d8244613b46f0b635bb75d4a409a82bdda0262374f2df1e9124f3abdad58e0a603fc8c3b2b34e235037f6613923385a903bfb9945b
30 DIST mysql-5.6.30.tar.gz 32223818 SHA256 48464df00aad9b9dfc26c903529ddad944a7562aa28e66e98e4f3f0c35179deb SHA512 b9f5b22a0557fbdd765fd3c379395584dd35bbec2d7504eb132f734129c0d95d24dc538c9b64524870bbecb92fa2f1e95b49ccfe22531ed17ec1e754f08d491b WHIRLPOOL f56d4e9d2ac801605bb941d1a8ba4b876d838a5e3bdac2e644477e87f2e5d439594c28d0e1c1d0c45ebb38fbf4183c429dc8c53bd7aa76aeea95acd1774ca71e
31 DIST mysql-5.6.40.tar.gz 32083035 SHA256 1048a7abedba851efa62868e4d28d0be8828162b53903cd68e4f29546418d92d SHA512 c8e458b4cd34cae87f1b088ed2188bd00de8cdc42709d5964e82fa2e4aaecfc12a75ae006c54ffa0d3d286fbdef9704d0cbb83436437d5705fb8921d960e758c WHIRLPOOL a962d9223fbd66f47d7859458b82793c6a74e81c0dce69b222a274b92823245eb121302af10f9a476e88bc88edfdccddaa681efd3357b23f4880da05e3fbfb98
32 DIST mysql-boost-5.7.17.tar.gz 61480982 SHA256 b75bba87199ef6a6ccc5dfbcaf70949009dc12089eafad8c5254afc9002aa903 SHA512 a1512abeba307fd21687677d2ee4bf20ced373312824de034e9b340d97e67eb4fcc5caa4ad7d9f58d6c0ddf57f6f6c0b0978e7b01c46f397ac661da843e3dfa6 WHIRLPOOL c9c078afdb1f8eb4405593611c179552493265c50b1eb1bac8cecadbac07103a11a05daf8c26d3d751526d5a69f14a8b6fce40b1aaaac7b9b4680679bf61bc4f
33 @@ -17,24 +15,6 @@ DIST mysql-extras-20140514-0124Z.tar.bz2 1493742 SHA256 0cdda9f8587532375274510a
34 DIST mysql-extras-20160212-0233Z.tar.bz2 297332 SHA256 01a52587ef1335b2795197d2e547c0b3a1e4b705db09f96cdfb45d2152b6536b SHA512 956dbdcb987556c0625944848f97a36d096cd1f1712a2e051dd027f2856d3c6e94a18d23faca71882260c4b12ee329e3a5f569443b877a3c3e5e88146bfac916 WHIRLPOOL e3837d329ddd137be60fe9d0b37f35ed2e0e7fe1383f38ee45617be288ae318a444e6befdfbaf64b07d4a88ec47fec5cd88d733ecd5bb32ce40f3ba8d09573cd
35 DIST mysql-extras-20180312-2011Z.tar.bz2 319047 SHA256 5d83747593b2276ecaf253b193814df2bfe170de57ceb7565e3d9f215df92254 SHA512 b0aa9fc8fbc050451ef147cee99b00cf10d34a71641837821e78655241f7d79a94fe2efb4cef9a23fe9741e08ada2fc0b58ef3b3663752bc567babfbcaa547c8 WHIRLPOOL 29085d38c285e62fa5925e70e01fda98ce5582e660b84fa09992049b5c222d1c14e73b94c63cb754bd94df00ce154b24ea5d4ee472de1766b6941cb05503c493
36 DIST mysql-extras-20180628-0201Z.tar.bz2 322141 SHA256 8317028fa98cc4abd819d11191fb82026eb9c4d23490b7c1d42590731fbc834d SHA512 71a3800ec091b41e41d25536199149eb714c0bbfc0f6fc478e8e4dcaf4cf87a7e4d49c513da3c9badc0de810d7d78c05ad91dd898e45005b42136346237de42a WHIRLPOOL 71a5d8d09ede40a2d7adad6d57e1b546fabb34610c92ede6e0b472c0d84ad016e39ec7fcb038c708723535542dfd9caace22f2b8dd822951ba8c0ee2778c462b
37 +DIST mysql-extras-20180804-2323Z.tar.bz2 322215 SHA256 fa962215d2dba8f781f25351a1f8f70c79d4ab92eef438ec14824aadf12a9b34 SHA512 efd9d416f394cc61b977ab76f05ab3acc5803ff8bdee8e1dbc65cc5b3f07e4f9742140d9586c028908b10fcc44f21c98ebffdebcc5c3578acbe05b07526bcb3d WHIRLPOOL 175407174870609128c502a9843d2c3f3f40acdd24d3263bbe98b30d6b0586821f642ba57c0519ae5e795a883bf7eb736a4da6de5a6590407a3db560105d5140
38 DIST pbxt-1.0.11-6-pre-ga.tar.gz 3156307 SHA256 71ff3d86e9e5691f3efe541bf31f55a7ec2a88af27df6ad853b65902e00e6d12 SHA512 fa238303f06e0a9adfb10bd5a2e1d2e4850d2c17a350af3874cbff099d6e47b7c555d750c584d06a3ca87c1eb1e9301a9619d8d9a4cffb7fd0169b2b3a63c80c WHIRLPOOL 05cdd39f6f5dafff2def0062a00a24eff6cf6d8754f622b133365cef47cd6b828df5500ac407359d0793a75dd239ec1e49a13d2400a01ddf8b4cef7466e86962
39 DIST percona-xtradb-1.0.6-10.tar.gz 1676716 SHA256 e3aa818f13cf669412e59ad194eae8eada7a857bf7a4260e4bb41cab4d7ae39c SHA512 72e4b656b22a0420e6f5935dc28060e5c50fbeb48c6d1ae430579d9ccef8042fdd4dde128cc977b903de6221f7021e8c87ea29fe6a8a8c74edb84bf54ab889f3 WHIRLPOOL a916879be315498da27c60992efa4d19e91305b81242925e161547f3fb97a820256e1d07863e9e007ef843af54cd087ce5ac47d5ed1b70862da6cd5a9d81eccf
40 ------BEGIN PGP SIGNATURE-----
41 -Version: GnuPG v2
42 -
43 -iQKTBAEBCAB9FiEEZsLkTtkOMnWOfVXA0feB7/n0o7YFAls1B4VfFIAAAAAALgAo
44 -aXNzdWVyLWZwckBub3RhdGlvbnMub3BlbnBncC5maWZ0aGhvcnNlbWFuLm5ldDY2
45 -QzJFNDRFRDkwRTMyNzU4RTdENTVDMEQxRjc4MUVGRjlGNEEzQjYACgkQ0feB7/n0
46 -o7bBRxAAxFns0rydGSZklsHtzCTL2OQjXpI9NWAEkYGuEHWGH8wCJjYpuJ6td5sP
47 -HRRnMZ3J3e8vafS0mFNLRBtHtkud2J9Y0XGTlJPm/Vg/tVJQbVJ5mKJ42c2rg1vM
48 -HGGoOxNNLuKRRmKaZSXqeBkVeGE2jU0Vp7yLxIPwbLVMKpvNbwgFfXmRWP/jX6jx
49 -IKUgkuWAS9mMyYW/DIBxxA2h9QFpF+B3AFANY94Dyn8rPLqh9mXfD6mAOsbZ67Zu
50 -GKaiiRFwVbAd+L1CpzEaIARk+lL+lYa5gIUiFvVoP/06PDu1v4TxZm+2hSJbTLDw
51 -Fn9gVoW/cbeLjB3UoVM8LtkPabSMhl/Vi72sQp8XuaH7Xp60jZ4bJtUoUuwHM1fe
52 -AzwhYeOzOXFa8rnAGF/Isq9lMYiVRgLDyqKrxpkq7YkJyRxpTSSVP6uSkwejTvs7
53 -XEH3UBDFBXxbVm14owHRP36jZl2jbFUQp03TLhHqrZ3g8luSb56goOkMe+pOwybr
54 -N5z0acTr6NVkcxAjQqpfHztBYxv/s/MAPXZRIajKjoNEgwbid8o+sE3Wqr5/nys7
55 -+igUKAZPrVCF72L+8Hnjl8Jj/soO0r1IP/o1VuOCKq+4FEJ1FDcLFjlcTwohTQig
56 -5ZsgIdo98euNytaGvGM0xO/ja7x5kkoCld+QReTiHsJbjBVpNBk=
57 -=wFYx
58 ------END PGP SIGNATURE-----
59
60 diff --git a/dev-db/mysql/mysql-5.5.62.ebuild b/dev-db/mysql/mysql-5.5.62.ebuild
61 new file mode 100644
62 index 0000000..cb22969
63 --- /dev/null
64 +++ b/dev-db/mysql/mysql-5.5.62.ebuild
65 @@ -0,0 +1,797 @@
66 +# Copyright 1999-2018 Gentoo Authors
67 +# Distributed under the terms of the GNU General Public License v2
68 +
69 +EAPI="6"
70 +MY_EXTRAS_VER="20180804-2323Z"
71 +SUBSLOT="18"
72 +
73 +# Keeping eutils in EAPI=6 for emktemp in pkg_config
74 +
75 +inherit eutils flag-o-matic prefix toolchain-funcs user cmake-utils multilib-build
76 +
77 +SRC_URI="https://cdn.mysql.com/Downloads/MySQL-5.5/${P}.tar.gz
78 + https://downloads.mysql.com/archives/MySQL-5.5/${P}.tar.gz"
79 +# Gentoo patches to MySQL
80 +if [[ "${MY_EXTRAS_VER}" != "live" && "${MY_EXTRAS_VER}" != "none" ]]; then
81 + SRC_URI="${SRC_URI}
82 + mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
83 + https://gitweb.gentoo.org/proj/mysql-extras.git/snapshot/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
84 + https://dev.gentoo.org/~grknight/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
85 + https://dev.gentoo.org/~robbat2/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2
86 + https://dev.gentoo.org/~jmbsvicetto/distfiles/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
87 +fi
88 +
89 +HOMEPAGE="https://mysql.com/"
90 +DESCRIPTION="An enhanced, drop-in replacement for MySQL"
91 +LICENSE="GPL-2"
92 +SLOT="0/${SUBSLOT:-0}"
93 +IUSE="bindist client-libs debug extraengine jemalloc latin1 libressl
94 + +perl profiling selinux +server static static-libs systemtap tcmalloc
95 + test yassl"
96 +
97 +# Tests always fail when libressl is enabled due to hard-coded ciphers in the tests
98 +RESTRICT="!bindist? ( bindist ) libressl? ( test )"
99 +
100 +REQUIRED_USE="?? ( tcmalloc jemalloc )
101 + static? ( yassl )"
102 +
103 +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~x64-solaris ~x86-solaris"
104 +
105 +# Shorten the path because the socket path length must be shorter than 107 chars
106 +# and we will run a mysql server during test phase
107 +S="${WORKDIR}/mysql"
108 +
109 +if [[ "${MY_EXTRAS_VER}" == "live" ]] ; then
110 + MY_PATCH_DIR="${WORKDIR%/}/mysql-extras"
111 + inherit git-r3
112 + EGIT_REPO_URI="git://anongit.gentoo.org/proj/mysql-extras.git"
113 + EGIT_CHECKOUT_DIR="${WORKDIR%/}/mysql-extras"
114 + EGIT_CLONE_TYPE=shallow
115 +else
116 + MY_PATCH_DIR="${WORKDIR%/}/mysql-extras-${MY_EXTRAS_VER}"
117 +fi
118 +
119 +PATCHES=(
120 + "${MY_PATCH_DIR}/01050_all_mysql_config_cleanup-5.5.patch"
121 + "${MY_PATCH_DIR}/02040_all_embedded-library-shared-5.5.10.patch"
122 + "${MY_PATCH_DIR}/20001_all_fix-minimal-build-cmake-mysql-5.5.41.patch"
123 + "${MY_PATCH_DIR}/20002_all_mysql-va-list.patch"
124 + "${MY_PATCH_DIR}/20006_all_cmake_elib-mysql-5.5.53.patch"
125 + "${MY_PATCH_DIR}/20007_all_cmake-debug-werror-5.6.22.patch"
126 + "${MY_PATCH_DIR}/20008_all_mysql-tzinfo-symlink-5.6.37.patch"
127 + "${MY_PATCH_DIR}/20009_all_mysql_myodbc_symbol_fix-5.5.38.patch"
128 + "${MY_PATCH_DIR}/20018_all_mysql-5.5.60-without-clientlibs-tools.patch"
129 + "${MY_PATCH_DIR}/20027_all_mysql-5.5-perl5.26-includes.patch"
130 +)
131 +
132 +# Be warned, *DEPEND are version-dependant
133 +# These are used for both runtime and compiletime
134 +COMMON_DEPEND="
135 + kernel_linux? (
136 + sys-process/procps:0=
137 + dev-libs/libaio:0=
138 + )
139 + >=sys-apps/sed-4
140 + >=sys-apps/texinfo-4.7-r1
141 + jemalloc? ( dev-libs/jemalloc:0= )
142 + tcmalloc? ( dev-util/google-perftools:0= )
143 + systemtap? ( >=dev-util/systemtap-1.3:0= )
144 + !yassl? (
145 + !libressl? ( dev-libs/openssl:0= !>=dev-libs/openssl-1.1 )
146 + libressl? ( dev-libs/libressl:0= )
147 + )
148 + >=sys-libs/zlib-1.2.3:0=
149 + sys-libs/ncurses:0=
150 + !bindist? (
151 + >=sys-libs/readline-4.1:0=
152 + )
153 + !client-libs? ( dev-db/mysql-connector-c[${MULTILIB_USEDEP},static-libs?] )
154 +"
155 +DEPEND="virtual/yacc
156 + static? ( sys-libs/ncurses[static-libs] )
157 + || ( >=sys-devel/gcc-3.4.6 >=sys-devel/gcc-apple-4.0 )
158 + ${COMMON_DEPEND}"
159 +RDEPEND="selinux? ( sec-policy/selinux-mysql )
160 + client-libs? ( !dev-db/mariadb-connector-c[mysqlcompat] !dev-db/mysql-connector-c )
161 + !dev-db/mariadb !dev-db/mariadb-galera !dev-db/percona-server !dev-db/mysql-cluster
162 + server? ( !prefix? ( dev-db/mysql-init-scripts ) )
163 + ${COMMON_DEPEND}
164 + perl? ( !dev-db/mytop
165 + virtual/perl-Getopt-Long
166 + dev-perl/TermReadKey
167 + virtual/perl-Term-ANSIColor
168 + virtual/perl-Time-HiRes )
169 +"
170 +# For other stuff to bring us in
171 +# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
172 +PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
173 +
174 +pkg_setup() {
175 + if [[ ${MERGE_TYPE} != binary ]] ; then
176 + local GCC_MAJOR_SET=$(gcc-major-version)
177 + local GCC_MINOR_SET=$(gcc-minor-version)
178 + # Bug 565584. InnoDB now requires atomic functions introduced with gcc-4.7 on
179 + # non x86{,_64} arches
180 + if ! use amd64 && ! use x86 && [[ ${GCC_MAJOR_SET} -lt 4 || \
181 + ${GCC_MAJOR_SET} -eq 4 && ${GCC_MINOR_SET} -lt 7 ]] ; then
182 + eerror "${PN} needs to be built with gcc-4.7 or later."
183 + eerror "Please use gcc-config to switch to gcc-4.7 or later version."
184 + die
185 + fi
186 + fi
187 + if has test ${FEATURES} && \
188 + use server && ! has userpriv ${FEATURES} ; then
189 + eerror "Testing with FEATURES=-userpriv is no longer supported by upstream. Tests MUST be run as non-root."
190 + fi
191 +
192 + # This should come after all of the die statements
193 + enewgroup mysql 60 || die "problem adding 'mysql' group"
194 + enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
195 +}
196 +
197 +pkg_postinst() {
198 + # Make sure the vars are correctly initialized
199 + mysql_init_vars
200 +
201 + # Create log directory securely if it does not exist
202 + [[ -d "${ROOT}${MY_LOGDIR}" ]] || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
203 +
204 + if use server ; then
205 + if [[ -z "${REPLACING_VERSIONS}" ]] ; then
206 + einfo
207 + elog "You might want to run:"
208 + elog "\"emerge --config =${CATEGORY}/${PF}\""
209 + elog "if this is a new install."
210 + elog
211 + elog "If you are switching server implentations, you should run the"
212 + elog "mysql_upgrade tool."
213 + einfo
214 + else
215 + einfo
216 + elog "If you are upgrading major versions, you should run the"
217 + elog "mysql_upgrade tool."
218 + einfo
219 + fi
220 +
221 + einfo
222 + elog "Be sure to edit the my.cnf file to activate your cluster settings."
223 + elog "This should be done after running \"emerge --config =${CATEGORY}/${PF}\""
224 + elog "The first time the cluster is activated, you should add"
225 + elog "--wsrep-new-cluster to the options in /etc/conf.d/mysql for one node."
226 + elog "This option should then be removed for subsequent starts."
227 + einfo
228 + fi
229 +}
230 +
231 +src_unpack() {
232 + unpack ${A}
233 + # Grab the patches
234 + [[ "${MY_EXTRAS_VER}" == "live" ]] && S="${WORKDIR%/}/mysql-extras" git-r3_src_unpack
235 +
236 + mv -f "${WORKDIR%/}/${P}" "${S}" || die
237 +}
238 +
239 +src_prepare() {
240 + _disable_engine() {
241 + echo > "${S%/}/storage/${1}/CMakeLists.txt" || die
242 + }
243 +
244 + _disable_plugin() {
245 + echo > "${S%/}/plugin/${1}/CMakeLists.txt" || die
246 + }
247 +
248 + if use tcmalloc; then
249 + echo "TARGET_LINK_LIBRARIES(mysqld tcmalloc)" >> "${S%/}/sql/CMakeLists.txt" || die
250 + fi
251 +
252 + if use jemalloc; then
253 + echo "TARGET_LINK_LIBRARIES(mysqld jemalloc)" >> "${S%/}/sql/CMakeLists.txt" || die
254 + fi
255 +
256 + # Remove the centos and rhel selinux policies to support mysqld_safe under SELinux
257 + if [[ -d "${S}/support-files/SELinux" ]] ; then
258 + echo > "${S}/support-files/SELinux/CMakeLists.txt" || die
259 + fi
260 +
261 + if use libressl ; then
262 + sed -i 's/OPENSSL_MAJOR_VERSION STREQUAL "1"/OPENSSL_MAJOR_VERSION STREQUAL "2"/' \
263 + "${S}/cmake/ssl.cmake" || die
264 + fi
265 +
266 + local plugin
267 + local server_plugins=( semisync )
268 + local test_plugins=( audit_null daemon_example fulltext )
269 + if ! use server; then # These plugins are for the server
270 + for plugin in "${server_plugins[@]}" ; do
271 + _disable_plugin "${plugin}"
272 + done
273 + fi
274 +
275 + if ! use test; then # These plugins are only used during testing
276 + for plugin in "${test_plugins[@]}" ; do
277 + _disable_plugin "${plugin}"
278 + done
279 + fi
280 +
281 + # Don't build example
282 + _disable_engine example
283 + _disable_engine ndb
284 +
285 + cmake-utils_src_prepare
286 +}
287 +
288 +src_configure(){
289 + # Bug #114895, bug #110149
290 + filter-flags "-O" "-O[01]"
291 +
292 + append-cxxflags -felide-constructors
293 +
294 + # bug #283926, with GCC4.4, this is required to get correct behavior.
295 + append-flags -fno-strict-aliasing
296 +
297 + CMAKE_BUILD_TYPE="RelWithDebInfo"
298 +
299 + # debug hack wrt #497532
300 + mycmakeargs=(
301 + -DCMAKE_C_FLAGS_RELWITHDEBINFO="$(usex debug '' '-DNDEBUG')"
302 + -DCMAKE_CXX_FLAGS_RELWITHDEBINFO="$(usex debug '' '-DNDEBUG')"
303 + -DCMAKE_INSTALL_PREFIX="${EPREFIX%/}/usr"
304 + -DDEFAULT_SYSCONFDIR="${EPREFIX%/}/etc/mysql"
305 + -DINSTALL_BINDIR=bin
306 + -DINSTALL_DOCDIR=share/doc/${PF}
307 + -DINSTALL_DOCREADMEDIR=share/doc/${PF}
308 + -DINSTALL_INCLUDEDIR=include/mysql
309 + -DINSTALL_INFODIR=share/info
310 + -DINSTALL_LIBDIR=$(get_libdir)
311 + -DINSTALL_MANDIR=share/man
312 + -DINSTALL_MYSQLSHAREDIR=share/mysql
313 + -DINSTALL_PLUGINDIR=$(get_libdir)/mysql/plugin
314 + -DINSTALL_SCRIPTDIR=share/mysql/scripts
315 + -DINSTALL_MYSQLDATADIR="${EPREFIX%/}/var/lib/mysql"
316 + -DINSTALL_SBINDIR=sbin
317 + -DINSTALL_SUPPORTFILESDIR="${EPREFIX%/}/usr/share/mysql"
318 + -DCOMPILATION_COMMENT="Gentoo Linux ${PF}"
319 + -DWITH_UNIT_TESTS=$(usex test ON OFF)
320 + -DWITH_ZLIB=system
321 + -DENABLED_LOCAL_INFILE=1
322 + -DMYSQL_UNIX_ADDR="${EPREFIX%/}/var/run/mysqld/mysqld.sock"
323 + # The build forces this to be defined when cross-compiling. We pass it
324 + # all the time for simplicity and to make sure it is actually correct.
325 + -DSTACK_DIRECTION=$(tc-stack-grows-down && echo -1 || echo 1)
326 + -DWITHOUT_CLIENTLIBS=YES
327 + -DWITH_READLINE=$(usex bindist 1 0)
328 + -DENABLE_DTRACE=$(usex systemtap)
329 + )
330 + if use test ; then
331 + mycmakeargs+=( -DINSTALL_MYSQLTESTDIR=share/mysql/mysql-test )
332 + else
333 + mycmakeargs+=( -DINSTALL_MYSQLTESTDIR='' )
334 + fi
335 +
336 + if ! use yassl ; then
337 + mycmakeargs+=( -DWITH_SSL=system )
338 + else
339 + mycmakeargs+=( -DWITH_SSL=bundled )
340 + fi
341 +
342 + if use server ; then
343 +
344 + # Federated{,X} must be treated special otherwise they will not be built as plugins
345 + if ! use extraengine ; then
346 + mycmakeargs+=(
347 + -DWITHOUT_FEDERATED_STORAGE_ENGINE=1
348 + -DWITHOUT_FEDERATEDX_STORAGE_ENGINE=1 )
349 + fi
350 +
351 + if [[ ( -n ${MYSQL_DEFAULT_CHARSET} ) && ( -n ${MYSQL_DEFAULT_COLLATION} ) ]]; then
352 + ewarn "You are using a custom charset of ${MYSQL_DEFAULT_CHARSET}"
353 + ewarn "and a collation of ${MYSQL_DEFAULT_COLLATION}."
354 + ewarn "You MUST file bugs without these variables set."
355 +
356 + mycmakeargs+=(
357 + -DDEFAULT_CHARSET=${MYSQL_DEFAULT_CHARSET}
358 + -DDEFAULT_COLLATION=${MYSQL_DEFAULT_COLLATION}
359 + )
360 +
361 + elif ! use latin1 ; then
362 + mycmakeargs+=(
363 + -DDEFAULT_CHARSET=utf8
364 + -DDEFAULT_COLLATION=utf8_general_ci
365 + )
366 + else
367 + mycmakeargs+=(
368 + -DDEFAULT_CHARSET=latin1
369 + -DDEFAULT_COLLATION=latin1_swedish_ci
370 + )
371 + fi
372 + mycmakeargs+=(
373 + -DINSTALL_SQLBENCHDIR=share/mysql
374 + -DEXTRA_CHARSETS=all
375 + -DDISABLE_SHARED=$(usex static YES NO)
376 + -DWITH_EMBEDDED_SERVER=OFF
377 + )
378 +
379 + if use profiling ; then
380 + # Setting to OFF doesn't work: Once set, profiling options will be added
381 + # to `mysqld --help` output via sql/sys_vars.cc causing
382 + # "main.mysqld--help-notwin" test to fail
383 + mycmakeargs+=( -DENABLED_PROFILING=ON )
384 + fi
385 +
386 + if use static; then
387 + mycmakeargs+=( -DWITH_PIC=1 )
388 + fi
389 +
390 + # Storage engines
391 + mycmakeargs+=(
392 + -DWITH_ARCHIVE_STORAGE_ENGINE=1
393 + -DWITH_BLACKHOLE_STORAGE_ENGINE=1
394 + -DWITH_CSV_STORAGE_ENGINE=1
395 + -DWITH_HEAP_STORAGE_ENGINE=1
396 + -DWITH_INNOBASE_STORAGE_ENGINE=1
397 + -DWITH_MYISAMMRG_STORAGE_ENGINE=1
398 + -DWITH_MYISAM_STORAGE_ENGINE=1
399 + -DWITH_PARTITION_STORAGE_ENGINE=1
400 + )
401 +
402 + else
403 + mycmakeargs+=(
404 + -DWITHOUT_SERVER=1
405 + -DEXTRA_CHARSETS=none
406 + -DINSTALL_SQLBENCHDIR=
407 + )
408 + fi
409 +
410 + cmake-utils_src_configure
411 +}
412 +
413 +src_compile() {
414 + cmake-utils_src_compile
415 +}
416 +
417 +src_install() {
418 + cmake-utils_src_install
419 +
420 + # Remove an unnecessary, private config header which will never match between ABIs and is not meant to be used
421 + if [[ -f "${ED%/}/usr/include/mysql/server/private/config.h" ]] ; then
422 + rm "${ED%/}/usr/include/mysql/server/private/config.h" || die
423 + fi
424 +
425 + # Make sure the vars are correctly initialized
426 + mysql_init_vars
427 +
428 + # Convenience links
429 + einfo "Making Convenience links for mysqlcheck multi-call binary"
430 + dosym "mysqlcheck" "/usr/bin/mysqlanalyze"
431 + dosym "mysqlcheck" "/usr/bin/mysqlrepair"
432 + dosym "mysqlcheck" "/usr/bin/mysqloptimize"
433 +
434 + # INSTALL_LAYOUT=STANDALONE causes cmake to create a /usr/data dir
435 + if [[ -d "${ED%/}/usr/data" ]] ; then
436 + rm -Rf "${ED%/}/usr/data" || die
437 + fi
438 +
439 + # Unless they explicitly specific USE=test, then do not install the
440 + # testsuite. It DOES have a use to be installed, esp. when you want to do a
441 + # validation of your database configuration after tuning it.
442 + if ! use test ; then
443 + rm -rf "${D%/}/${MY_SHAREDSTATEDIR}/mysql-test"
444 + fi
445 +
446 + # Configuration stuff
447 + einfo "Building default configuration ..."
448 + insinto "${MY_SYSCONFDIR#${EPREFIX}}"
449 + [[ -f "${S%/}/scripts/mysqlaccess.conf" ]] && doins "${S%/}"/scripts/mysqlaccess.conf
450 + local mycnf_src="my.cnf-5.5"
451 + sed -e "s!@DATADIR@!${MY_DATADIR}!g" \
452 + "${FILESDIR%/}/${mycnf_src}" \
453 + > "${TMPDIR%/}/my.cnf.ok" || die
454 + use prefix && sed -i -r -e '/^user[[:space:]]*=[[:space:]]*mysql$/d' "${TMPDIR%/}/my.cnf.ok"
455 + if use latin1 ; then
456 + sed -i \
457 + -e "/character-set/s|utf8|latin1|g" \
458 + "${TMPDIR%/}/my.cnf.ok" || die
459 + fi
460 + eprefixify "${TMPDIR%/}/my.cnf.ok"
461 + newins "${TMPDIR}/my.cnf.ok" my.cnf
462 +
463 + if use server ; then
464 + einfo "Including support files and sample configurations"
465 + docinto "support-files"
466 + local script
467 + for script in \
468 + "${S%/}"/support-files/magic
469 + do
470 + [[ -f "$script" ]] && dodoc "${script}"
471 + done
472 +
473 + docinto "scripts"
474 + for script in "${S%/}"/scripts/mysql* ; do
475 + [[ ( -f "$script" ) && ( "${script%.sh}" == "${script}" ) ]] && dodoc "${script}"
476 + done
477 + fi
478 +
479 + #Remove mytop if perl is not selected
480 + [[ -e "${ED%/}/usr/bin/mytop" ]] && ! use perl && rm -f "${ED%/}/usr/bin/mytop"
481 +}
482 +
483 +# Official test instructions:
484 +# USE='extraengine perl server' \
485 +# FEATURES='test userpriv -usersandbox' \
486 +# ebuild mysql-X.X.XX.ebuild \
487 +# digest clean package
488 +src_test() {
489 +
490 + _disable_test() {
491 + local rawtestname reason
492 + rawtestname="${1}" ; shift
493 + reason="${@}"
494 + ewarn "test '${rawtestname}' disabled: '${reason}'"
495 + echo ${rawtestname} : ${reason} >> "${T}/disabled.def"
496 + }
497 +
498 + local TESTDIR="${BUILD_DIR}/mysql-test"
499 + local retstatus_unit
500 + local retstatus_tests
501 +
502 + if ! use server ; then
503 + einfo "Skipping server tests due to minimal build."
504 + return 0
505 + fi
506 +
507 + # Bug #213475 - MySQL _will_ object strenously if your machine is named
508 + # localhost. Also causes weird failures.
509 + [[ "${HOSTNAME}" == "localhost" ]] && die "Your machine must NOT be named localhost"
510 +
511 + if [[ $UID -eq 0 ]]; then
512 + die "Testing with FEATURES=-userpriv is no longer supported by upstream. Tests MUST be run as non-root."
513 + fi
514 + has usersandbox $FEATURES && ewarn "Some tests may fail with FEATURES=usersandbox"
515 +
516 + einfo ">>> Test phase [test]: ${CATEGORY}/${PF}"
517 +
518 + # Run CTest (test-units)
519 + cmake-utils_src_test
520 + retstatus_unit=$?
521 +
522 + # Ensure that parallel runs don't die
523 + export MTR_BUILD_THREAD="$((${RANDOM} % 100))"
524 + # Enable parallel testing, auto will try to detect number of cores
525 + # You may set this by hand.
526 + # The default maximum is 8 unless MTR_MAX_PARALLEL is increased
527 + export MTR_PARALLEL="${MTR_PARALLEL:-auto}"
528 +
529 + # create directories because mysqladmin might run out of order
530 + mkdir -p "${T}"/var-tests{,/log} || die
531 +
532 + # Run mysql tests
533 + pushd "${TESTDIR}" > /dev/null || die
534 +
535 + touch "${T}/disabled.def"
536 + # These are failing in MySQL 5.5 for now and are believed to be
537 + # false positives:
538 + #
539 + # main.mysql_client_test, main.mysql_client_test_nonblock
540 + # main.mysql_client_test_comp:
541 + # segfaults at random under Portage only, suspect resource limits.
542 +
543 + local t
544 + for t in federated.federated_plugin \
545 + main.mysql_client_test main.mysql_client_test_nonblock \
546 + main.mysql_client_test_comp rpl.rpl_extra_col_master_myisam \
547 + main.mysqlhotcopy_archive main.mysqlhotcopy_myisam main.openssl_1 \
548 + rpl.rpl_semi_sync_uninstall_plugin ; do
549 + _disable_test "$t" "False positives in Gentoo"
550 + done
551 +
552 + if ! use client-libs ; then
553 + _disable_test main.plugin_auth "Needs client libraries built"
554 + fi
555 +
556 + # run mysql-test tests
557 + perl mysql-test-run.pl --force --vardir="${T}/var-tests" --reorder --skip-test=tokudb --skip-test-list="${T}/disabled.def"
558 + retstatus_tests=$?
559 +
560 + popd > /dev/null || die
561 +
562 + # Cleanup is important for these testcases.
563 + pkill -9 -f "${S}/ndb" 2>/dev/null
564 + pkill -9 -f "${S}/sql" 2>/dev/null
565 +
566 + local failures=""
567 + [[ $retstatus_unit -eq 0 ]] || failures="${failures} test-unit"
568 + [[ $retstatus_tests -eq 0 ]] || failures="${failures} tests"
569 +
570 + [[ -z "$failures" ]] || die "Test failures: $failures"
571 + einfo "Tests successfully completed"
572 +}
573 +
574 +mysql_init_vars() {
575 + MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="${EPREFIX}/usr/share/mysql"}
576 + MY_SYSCONFDIR=${MY_SYSCONFDIR="${EPREFIX}/etc/mysql"}
577 + MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="${EPREFIX}/var/lib/mysql"}
578 + MY_LOGDIR=${MY_LOGDIR="${EPREFIX}/var/log/mysql"}
579 +
580 + if [[ -z "${MY_DATADIR}" ]] ; then
581 + MY_DATADIR=""
582 + if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then
583 + MY_DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
584 + | sed -ne '/datadir/s|^--datadir=||p' \
585 + | tail -n1`
586 + if [[ -z "${MY_DATADIR}" ]] ; then
587 + MY_DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \
588 + | sed -e 's/.*=\s*//' \
589 + | tail -n1`
590 + fi
591 + fi
592 + if [[ -z "${MY_DATADIR}" ]] ; then
593 + MY_DATADIR="${MY_LOCALSTATEDIR}"
594 + einfo "Using default MY_DATADIR"
595 + fi
596 + elog "MySQL MY_DATADIR is ${MY_DATADIR}"
597 +
598 + if [[ -z "${PREVIOUS_DATADIR}" ]] ; then
599 + if [[ -e "${MY_DATADIR}" ]] ; then
600 + # If you get this and you're wondering about it, see bug #207636
601 + elog "MySQL datadir found in ${MY_DATADIR}"
602 + elog "A new one will not be created."
603 + PREVIOUS_DATADIR="yes"
604 + else
605 + PREVIOUS_DATADIR="no"
606 + fi
607 + export PREVIOUS_DATADIR
608 + fi
609 + else
610 + if [[ ${EBUILD_PHASE} == "config" ]]; then
611 + local new_MY_DATADIR
612 + new_MY_DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
613 + | sed -ne '/datadir/s|^--datadir=||p' \
614 + | tail -n1`
615 +
616 + if [[ ( -n "${new_MY_DATADIR}" ) && ( "${new_MY_DATADIR}" != "${MY_DATADIR}" ) ]]; then
617 + ewarn "MySQL MY_DATADIR has changed"
618 + ewarn "from ${MY_DATADIR}"
619 + ewarn "to ${new_MY_DATADIR}"
620 + MY_DATADIR="${new_MY_DATADIR}"
621 + fi
622 + fi
623 + fi
624 +
625 + export MY_SHAREDSTATEDIR MY_SYSCONFDIR
626 + export MY_LOCALSTATEDIR MY_LOGDIR
627 + export MY_DATADIR
628 +}
629 +
630 +pkg_config() {
631 + _getoptval() {
632 + local mypd="${EROOT}"/usr/bin/my_print_defaults
633 + local section="$1"
634 + local flag="--${2}="
635 + local extra_options="${3}"
636 + "${mypd}" $extra_options $section | sed -n "/^${flag}/s,${flag},,gp"
637 + }
638 + local old_MY_DATADIR="${MY_DATADIR}"
639 + local old_HOME="${HOME}"
640 + # my_print_defaults needs to read stuff in $HOME/.my.cnf
641 + export HOME=${EPREFIX}/root
642 +
643 + # Make sure the vars are correctly initialized
644 + mysql_init_vars
645 +
646 + [[ -z "${MY_DATADIR}" ]] && die "Sorry, unable to find MY_DATADIR"
647 + if [[ ! -x "${EROOT}/usr/sbin/mysqld" ]] ; then
648 + die "Minimal builds do NOT include the MySQL server"
649 + fi
650 +
651 + if [[ ( -n "${MY_DATADIR}" ) && ( "${MY_DATADIR}" != "${old_MY_DATADIR}" ) ]]; then
652 + local MY_DATADIR_s="${ROOT}/${MY_DATADIR}"
653 + MY_DATADIR_s="${MY_DATADIR_s%%/}"
654 + local old_MY_DATADIR_s="${ROOT}/${old_MY_DATADIR}"
655 + old_MY_DATADIR_s="${old_MY_DATADIR_s%%/}"
656 +
657 + if [[ ( -d "${old_MY_DATADIR_s}" ) && ( "${old_MY_DATADIR_s}" != / ) ]]; then
658 + if [[ -d "${MY_DATADIR_s}" ]]; then
659 + ewarn "Both ${old_MY_DATADIR_s} and ${MY_DATADIR_s} exist"
660 + ewarn "Attempting to use ${MY_DATADIR_s} and preserving ${old_MY_DATADIR_s}"
661 + else
662 + elog "Moving MY_DATADIR from ${old_MY_DATADIR_s} to ${MY_DATADIR_s}"
663 + mv --strip-trailing-slashes -T "${old_MY_DATADIR_s}" "${MY_DATADIR_s}" \
664 + || die "Moving MY_DATADIR failed"
665 + fi
666 + else
667 + ewarn "Previous MY_DATADIR (${old_MY_DATADIR_s}) does not exist"
668 + if [[ -d "${MY_DATADIR_s}" ]]; then
669 + ewarn "Attempting to use ${MY_DATADIR_s}"
670 + else
671 + eerror "New MY_DATADIR (${MY_DATADIR_s}) does not exist"
672 + die "Configuration Failed! Please reinstall ${CATEGORY}/${PN}"
673 + fi
674 + fi
675 + fi
676 +
677 + local pwd1="a"
678 + local pwd2="b"
679 + local maxtry=15
680 +
681 + if [ -z "${MYSQL_ROOT_PASSWORD}" ]; then
682 + local tmp_mysqld_password_source=
683 +
684 + for tmp_mysqld_password_source in mysql client; do
685 + einfo "Trying to get password for mysql 'root' user from '${tmp_mysqld_password_source}' section ..."
686 + MYSQL_ROOT_PASSWORD="$(_getoptval "${tmp_mysqld_password_source}" password)"
687 + if [[ -n "${MYSQL_ROOT_PASSWORD}" ]]; then
688 + if [[ ${MYSQL_ROOT_PASSWORD} == *$'\n'* ]]; then
689 + ewarn "Ignoring password from '${tmp_mysqld_password_source}' section due to newline character (do you have multiple password options set?)!"
690 + MYSQL_ROOT_PASSWORD=
691 + continue
692 + fi
693 +
694 + einfo "Found password in '${tmp_mysqld_password_source}' section!"
695 + break
696 + fi
697 + done
698 +
699 + # Sometimes --show is required to display passwords in some implementations of my_print_defaults
700 + if [[ "${MYSQL_ROOT_PASSWORD}" == '*****' ]]; then
701 + MYSQL_ROOT_PASSWORD="$(_getoptval "${tmp_mysqld_password_source}" password --show)"
702 + fi
703 +
704 + unset tmp_mysqld_password_source
705 + fi
706 + MYSQL_TMPDIR="$(_getoptval mysqld tmpdir)"
707 + # These are dir+prefix
708 + MYSQL_RELAY_LOG="$(_getoptval mysqld relay-log)"
709 + MYSQL_RELAY_LOG=${MYSQL_RELAY_LOG%/*}
710 + MYSQL_LOG_BIN="$(_getoptval mysqld log-bin)"
711 + MYSQL_LOG_BIN=${MYSQL_LOG_BIN%/*}
712 +
713 + if [[ ! -d "${ROOT}/$MYSQL_TMPDIR" ]]; then
714 + einfo "Creating MySQL tmpdir $MYSQL_TMPDIR"
715 + install -d -m 770 -o mysql -g mysql "${EROOT}/$MYSQL_TMPDIR"
716 + fi
717 + if [[ ! -d "${ROOT}/$MYSQL_LOG_BIN" ]]; then
718 + einfo "Creating MySQL log-bin directory $MYSQL_LOG_BIN"
719 + install -d -m 770 -o mysql -g mysql "${EROOT}/$MYSQL_LOG_BIN"
720 + fi
721 + if [[ ! -d "${EROOT}/$MYSQL_RELAY_LOG" ]]; then
722 + einfo "Creating MySQL relay-log directory $MYSQL_RELAY_LOG"
723 + install -d -m 770 -o mysql -g mysql "${EROOT}/$MYSQL_RELAY_LOG"
724 + fi
725 +
726 + if [[ -d "${ROOT}/${MY_DATADIR}/mysql" ]] ; then
727 + ewarn "You have already a MySQL database in place."
728 + ewarn "(${ROOT}/${MY_DATADIR}/*)"
729 + ewarn "Please rename or delete it if you wish to replace it."
730 + die "MySQL database already exists!"
731 + fi
732 +
733 + # Bug #213475 - MySQL _will_ object strenously if your machine is named
734 + # localhost. Also causes weird failures.
735 + [[ "${HOSTNAME}" == "localhost" ]] && die "Your machine must NOT be named localhost"
736 +
737 + if [ -z "${MYSQL_ROOT_PASSWORD}" ]; then
738 +
739 + einfo "Please provide a password for the mysql 'root' user now"
740 + einfo "or through the ${HOME}/.my.cnf file."
741 + ewarn "Avoid [\"'\\_%] characters in the password"
742 + read -rsp " >" pwd1 ; echo
743 +
744 + einfo "Retype the password"
745 + read -rsp " >" pwd2 ; echo
746 +
747 + if [[ "x$pwd1" != "x$pwd2" ]] ; then
748 + die "Passwords are not the same"
749 + fi
750 + MYSQL_ROOT_PASSWORD="${pwd1}"
751 + unset pwd1 pwd2
752 + fi
753 +
754 + local options
755 + local sqltmp="$(emktemp)"
756 +
757 + # Fix bug 446200. Don't reference host my.cnf, needs to come first,
758 + # see http://bugs.mysql.com/bug.php?id=31312
759 + use prefix && options="${options} '--defaults-file=${MY_SYSCONFDIR}/my.cnf'"
760 +
761 + # Figure out which options we need to disable to do the setup
762 + local helpfile="${TMPDIR}/mysqld-help"
763 + "${EROOT}/usr/sbin/mysqld" --verbose --help >"${helpfile}" 2>/dev/null
764 + for opt in grant-tables host-cache name-resolve networking slave-start \
765 + federated ssl log-bin relay-log slow-query-log external-locking \
766 + log-slave-updates \
767 + ; do
768 + optexp="--(skip-)?${opt}" optfull="--loose-skip-${opt}"
769 + egrep -sq -- "${optexp}" "${helpfile}" && options="${options} ${optfull}"
770 + done
771 +
772 + einfo "Creating the mysql database and setting proper permissions on it ..."
773 +
774 + # Now that /var/run is a tmpfs mount point, we need to ensure it exists before using it
775 + PID_DIR="${EROOT}/var/run/mysqld"
776 + if [[ ! -d "${PID_DIR}" ]]; then
777 + install -d -m 755 -o mysql -g mysql "${PID_DIR}" || die "Could not create pid directory"
778 + fi
779 +
780 + if [[ ! -d "${MY_DATADIR}" ]]; then
781 + install -d -m 750 -o mysql -g mysql "${MY_DATADIR}" || die "Could not create data directory"
782 + fi
783 +
784 + pushd "${TMPDIR}" &>/dev/null || die
785 +
786 + # Filling timezones, see
787 + # http://dev.mysql.com/doc/mysql/en/time-zone-support.html
788 + "${EROOT}/usr/bin/mysql_tzinfo_to_sql" "${EROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
789 +
790 + local cmd=( "${EROOT}usr/share/mysql/scripts/mysql_install_db" )
791 + [[ -f "${cmd}" ]] || cmd=( "${EROOT}usr/bin/mysql_install_db" )
792 + cmd+=( "--basedir=${EPREFIX}/usr" ${options} "--datadir=${ROOT}/${MY_DATADIR}" "--tmpdir=${ROOT}/${MYSQL_TMPDIR}" )
793 + einfo "Command: ${cmd[*]}"
794 + su -s /bin/sh -c "${cmd[*]}" mysql \
795 + >"${TMPDIR}"/mysql_install_db.log 2>&1
796 + if [ $? -ne 0 ]; then
797 + grep -B5 -A999 -i "ERROR" "${TMPDIR}"/mysql_install_db.log 1>&2
798 + die "Failed to initialize mysqld. Please review ${EPREFIX}/var/log/mysql/mysqld.err AND ${TMPDIR}/mysql_install_db.log"
799 + fi
800 + popd &>/dev/null || die
801 + [[ -f "${ROOT}/${MY_DATADIR}/mysql/user.frm" ]] \
802 + || die "MySQL databases not installed"
803 +
804 + use prefix || options="${options} --user=mysql"
805 +
806 + local socket="${EROOT}/var/run/mysqld/mysqld${RANDOM}.sock"
807 + local pidfile="${EROOT}/var/run/mysqld/mysqld${RANDOM}.pid"
808 + local mysqld="${EROOT}/usr/sbin/mysqld \
809 + ${options} \
810 + --log-warnings=0 \
811 + --basedir=${EROOT}/usr \
812 + --datadir=${ROOT}/${MY_DATADIR} \
813 + --max_allowed_packet=8M \
814 + --net_buffer_length=16K \
815 + --socket=${socket} \
816 + --pid-file=${pidfile} \
817 + --tmpdir=${ROOT}/${MYSQL_TMPDIR}"
818 + #einfo "About to start mysqld: ${mysqld}"
819 + ebegin "Starting mysqld"
820 + einfo "Command ${mysqld}"
821 + ${mysqld} &
822 + rc=$?
823 + while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do
824 + maxtry=$((${maxtry}-1))
825 + echo -n "."
826 + sleep 1
827 + done
828 + eend $rc
829 +
830 + if ! [[ -S "${socket}" ]]; then
831 + die "Completely failed to start up mysqld with: ${mysqld}"
832 + fi
833 +
834 + ebegin "Setting root password"
835 + # Do this from memory, as we don't want clear text passwords in temp files
836 + local sql="UPDATE mysql.user SET Password = PASSWORD('${MYSQL_ROOT_PASSWORD}') WHERE USER='root'; FLUSH PRIVILEGES"
837 + "${EROOT}/usr/bin/mysql" \
838 + "--socket=${socket}" \
839 + -hlocalhost \
840 + -e "${sql}"
841 + eend $?
842 +
843 + if [[ -n "${sqltmp}" ]] ; then
844 + ebegin "Loading \"zoneinfo\", this step may require a few seconds"
845 + "${EROOT}/usr/bin/mysql" \
846 + "--socket=${socket}" \
847 + -hlocalhost \
848 + -uroot \
849 + --password="${MYSQL_ROOT_PASSWORD}" \
850 + mysql < "${sqltmp}"
851 + rc=$?
852 + eend $?
853 + [[ $rc -ne 0 ]] && ewarn "Failed to load zoneinfo!"
854 + fi
855 +
856 + # Stop the server and cleanup
857 + einfo "Stopping the server ..."
858 + kill $(< "${pidfile}" )
859 + rm -f "${sqltmp}"
860 + wait %1
861 + einfo "Done"
862 +}