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

Diff of /eclass/mysql.eclass

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

Revision 1.25 Revision 1.42
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2006 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.25 2006/03/16 20:39:00 vivo Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.42 2006/10/21 14:32:21 chtekk Exp $
4 4
5# Author: Francesco Riosa <vivo at gentoo.org> 5# Author: Francesco Riosa <vivo@gentoo.org>
6# Maintainer: Francesco Riosa <vivo at gentoo.org> 6# Maintainer: Luca Longinotti <chtekk@gentoo.org>
7
8# Both MYSQL_VERSION_ID and MYSQL_PATCHSET_REV must be set in the ebuild too
9# Note that MYSQL_VERSION_ID must be empty !!!
10
11# MYSQL_VERSION_ID will be:
12# major * 10e6 + minor * 10e4 + micro * 10e2 + gentoo revision number, all [0..99]
13# This is an important part, because many of the choices the MySQL ebuild will do
14# depend on this variable.
15# In particular, the code below transforms a $PVR like "5.0.18-r3" in "5001803"
16
17if [[ -z "${MYSQL_VERSION_ID}" ]] ; then
18 tpv=( ${PV//[-._]/ } ) ; tpv[3]="${PVR:${#PV}}" ; tpv[3]="${tpv[3]##*-r}"
19 for vatom in 0 1 2 3 ; do
20 # pad to length 2
21 tpv[${vatom}]="00${tpv[${vatom}]}"
22 MYSQL_VERSION_ID="${MYSQL_VERSION_ID}${tpv[${vatom}]:0-2}"
23 done
24 # strip leading "0" (otherwise it's considered an octal number by BASH)
25 MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"}
26fi
7 27
8inherit eutils flag-o-matic gnuconfig autotools mysql_fx 28inherit eutils flag-o-matic gnuconfig autotools mysql_fx
9 29
10#major, minor only in the slot 30# Be warned, *DEPEND are version-dependant
11SLOT=$(( ${MYSQL_VERSION_ID} / 10000 )) 31DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d )
32 userland_GNU? ( sys-process/procps )
33 >=sys-apps/sed-4
34 >=sys-apps/texinfo-4.7-r1
35 >=sys-libs/readline-4.1
36 >=sys-libs/zlib-1.2.3"
12 37
38mysql_version_is_at_least "5.01.00.00" \
39|| DEPEND="${DEPEND} berkdb? ( sys-apps/ed )"
40
41RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )"
42
43# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
44PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
45
13# shorten the path because the socket path length must be shorter than 107 chars 46# Shorten the path because the socket path length must be shorter than 107 chars
14# and we will run a mysql server during test phase 47# and we will run a mysql server during test phase
15S="${WORKDIR}/${PN}" 48S="${WORKDIR}/${PN/_alpha/-bk-}" # BitKeeper ebuilds
16 49
50# Define $MY_FIXED_PV for MySQL patchsets
51MY_FIXED_PV="${PV/_alpha/}"
52#MY_FIXED_PV="${MY_FIXED_PV/_beta/}"
53#MY_FIXED_PV="${MY_FIXED_PV/_rc/}"
54
55MY_P="${P/_/-}"
56MY_P="${MY_P/-alpha/-bk-}" # BitKeeper ebuilds
57
58# Define correct SRC_URIs
59SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${MY_P}${MYSQL_RERELEASE}.tar.gz"
60if [[ -n "${MYSQL_PATCHSET_REV}" ]] ; then
61 MYSQL_PATCHSET_FILENAME="${PN}-patchset-${MY_FIXED_PV}-r${MYSQL_PATCHSET_REV}.tar.bz2"
62 # We add the Gentoo mirror here, as we only use primaryuri for the MySQL tarball
63 SRC_URI="${SRC_URI} http://gentoo.longitekk.com/${MYSQL_PATCHSET_FILENAME}"
64fi
65
17DESCRIPTION="A fast, multi-threaded, multi-user SQL database server" 66DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
18HOMEPAGE="http://www.mysql.com/" 67HOMEPAGE="http://www.mysql.com/"
19NEWP="${P/_/-}" 68SLOT="0"
20SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${NEWP}.tar.gz
21 mirror://gentoo/mysql-extras-${MY_EXTRAS_VER}.tar.bz2"
22LICENSE="GPL-2" 69LICENSE="GPL-2"
23IUSE="big-tables berkdb debug embedded minimal perl selinux srvdir ssl static" 70IUSE="big-tables debug embedded minimal perl selinux srvdir ssl static"
24RESTRICT="primaryuri confcache" 71RESTRICT="confcache"
72
73mysql_version_is_at_least "4.01.00.00" \
74&& IUSE="${IUSE} latin1"
25 75
26mysql_version_is_at_least "4.01.03.00" \ 76mysql_version_is_at_least "4.01.03.00" \
27&& IUSE="${IUSE} cluster extraengine" 77&& IUSE="${IUSE} cluster extraengine"
28 78
29mysql_version_is_at_least "5.00.00.00" \ 79mysql_version_is_at_least "5.00.00.00" \
33&& IUSE="${IUSE} max-idx-128" 83&& IUSE="${IUSE} max-idx-128"
34 84
35mysql_version_is_at_least "5.01.00.00" \ 85mysql_version_is_at_least "5.01.00.00" \
36&& IUSE="${IUSE} innodb" 86&& IUSE="${IUSE} innodb"
37 87
88mysql_version_is_at_least "5.01.00.00" \
89|| IUSE="${IUSE} berkdb"
90
38EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst pkg_config pkg_prerm pkg_postrm 91EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \
92 pkg_postinst pkg_config pkg_postrm
93
94#
95# HELPER FUNCTIONS:
96#
39 97
40# void mysql_init_vars() 98# void mysql_init_vars()
41# 99#
42# initialize global variables 100# Initialize global variables
43# 2005-11-19 <vivo at gentoo.org> 101# 2005-11-19 <vivo@gentoo.org>
102
44mysql_init_vars() { 103mysql_init_vars() {
45
46 if [[ ${SLOT} -eq 0 ]] ; then
47 MY_SUFFIX=""
48 else
49 MY_SUFFIX=${MY_SUFFIX:-"-${SLOT}"}
50 fi
51 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR:-"/usr/share/mysql${MY_SUFFIX}"} 104 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"}
52 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql${MY_SUFFIX}"} 105 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"}
53 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql${MY_SUFFIX}"} 106 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"}
54 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql${MY_SUFFIX}"} 107 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"}
55 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql${MY_SUFFIX}"} 108 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql"}
56 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql${MY_SUFFIX}"} 109 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql"}
57 110
58 if [ -z "${DATADIR}" ]; then 111 if [[ -z "${DATADIR}" ]] ; then
59 DATADIR="" 112 DATADIR=""
60 if [ -f "${MY_SYSCONFDIR}/my.cnf" ] ; then 113 if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then
61 DATADIR=`"my_print_defaults${MY_SUFFIX}" mysqld 2>/dev/null | sed -ne '/datadir/s|^--datadir=||p' | tail -n1` 114 DATADIR=`"my_print_defaults" mysqld 2>/dev/null \
115 | sed -ne '/datadir/s|^--datadir=||p' \
116 | tail -n1`
62 if [ -z "${DATADIR}" ]; then 117 if [[ -z "${DATADIR}" ]] ; then
63 if useq "srvdir" ; then 118 if useq "srvdir" ; then
64 DATADIR="${ROOT}/srv/localhost/mysql${MY_SUFFIX}/datadir" 119 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
65 else 120 else
66 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" | sed -e 's/.*=\s*//'` 121 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \
122 | sed -e 's/.*=\s*//'`
67 fi 123 fi
68 fi 124 fi
69 fi 125 fi
70 if [ -z "${DATADIR}" ]; then 126 if [[ -z "${DATADIR}" ]] ; then
71 if useq "srvdir" ; then 127 if useq "srvdir" ; then
72 DATADIR="${ROOT}/srv/localhost/mysql${MY_SUFFIX}/datadir" 128 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
73 else 129 else
74 DATADIR="${MY_LOCALSTATEDIR}" 130 DATADIR="${MY_LOCALSTATEDIR}"
75 fi 131 fi
76 einfo "Using default DATADIR" 132 einfo "Using default DATADIR"
77 fi 133 fi
78 einfo "MySQL DATADIR is ${DATADIR}" 134 elog "MySQL DATADIR is ${DATADIR}"
79 135
80 if [ -z "${PREVIOUS_DATADIR}" ] ; then 136 if [[ -z "${PREVIOUS_DATADIR}" ]] ; then
81 if [ -a "${DATADIR}" ] ; then 137 if [[ -e "${DATADIR}" ]] ; then
82 ewarn "Previous datadir found, it's YOUR job to change" 138 elog "Previous datadir found, it's YOUR job to change"
83 ewarn "ownership and have care of it" 139 elog "ownership and take care of it"
84 PREVIOUS_DATADIR="yes" 140 PREVIOUS_DATADIR="yes"
85 export PREVIOUS_DATADIR
86 else 141 else
87 PREVIOUS_DATADIR="no" 142 PREVIOUS_DATADIR="no"
88 export PREVIOUS_DATADIR
89 fi 143 fi
90 fi 144 export PREVIOUS_DATADIR
91 fi 145 fi
146 fi
92 147
93 export MY_SUFFIX MY_SHAREDSTATEDIR MY_SYSCONFDIR 148 export MY_SHAREDSTATEDIR MY_SYSCONFDIR
94 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR 149 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
95 export MY_INCLUDEDIR 150 export MY_INCLUDEDIR
96 export DATADIR 151 export DATADIR
97} 152}
98 153
99mysql_pkg_setup() { 154configure_minimal() {
155 # These are things we exclude from a minimal build, please
156 # note that the server actually does get built and installed,
157 # but we then delete it before packaging.
158 local minimal_exclude_list="server embedded-server extra-tools innodb bench berkeley-db row-based-replication"
100 159
101 enewgroup mysql 60 || die "problem adding group mysql" 160 for i in ${minimal_exclude_list} ; do
102 enewuser mysql 60 -1 /dev/null mysql \ 161 myconf="${myconf} --without-${i}"
103 || die "problem adding user mysql"
104}
105
106mysql_src_unpack() {
107
108 mysql_init_vars
109
110 if useq static && useq ssl; then
111 local msg="MySQL does not support building statically with SSL support"
112 eerror "${msg}"
113 die "${msg}"
114 fi
115
116 if mysql_version_is_at_least "4.01.03.00" \
117 && useq cluster \
118 || useq extraengine \
119 && useq minimal ; then
120 die "USEs cluster, extraengine conflicts with \"minimal\""
121 fi
122
123 unpack ${A} || die
124
125 mv -f "${WORKDIR}/${NEWP}" "${S}"
126 cd "${S}"
127
128 EPATCH_SUFFIX="patch"
129 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory"
130 mysql_mv_patches
131 epatch || die "failed to apply all patches"
132
133 # additional check, remove bundled zlib
134 rm -f "${S}/zlib/"*.[ch]
135 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
136 rm -f scripts/mysqlbug
137
138 # Make charsets install in the right place
139 find . -name 'Makefile.am' \
140 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
141
142 # Manage mysqlmanager
143 mysql_version_is_at_least "5.00.15.00" \
144 && sed -i -e "s!@GENTOO_EXT@!${MY_SUFFIX}!g" \
145 -e "s!@GENTOO_SOCK_PATH@!var/run/mysqld!g" \
146 "${S}/server-tools/instance-manager/Makefile.am"
147
148 # remove what need to be recreated, so we are sure it's actually done
149 find . -name Makefile -o -name Makefile.in -o -name configure -exec rm -f {} \;
150 rm ltmain.sh
151
152 local rebuilddirlist d buildstep bdbdir
153
154 if mysql_version_is_at_least "5.01.00.00" ; then
155 rebuilddirlist=". storage/innobase"
156 bdbdir='storage/bdb/dist'
157 else
158 rebuilddirlist=". innobase"
159 bdbdir='bdb/dist'
160 fi
161
162 for d in ${rebuilddirlist}; do
163 einfo "reconfiguring dir \"${d}\""
164 pushd "${d}" &>/dev/null
165 AT_GNUCONF_UPDATE="yes" eautoreconf
166 popd &>/dev/null
167 done 162 done
168 163 myconf="${myconf} --with-extra-charsets=none"
169 #TODO berkdb in 5.1 need to be worked on
170 if useq berkdb && ! mysql_check_version_range "5.01.00.00 to 5.01.08.99"
171 then
172 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f ltmain.sh "${bdbdir}/ltmain.sh"
173 pushd "${bdbdir}" && sh s_all || die "failed bdb reconfigure" &>/dev/null
174 popd &>/dev/null
175 fi
176
177} 164}
178 165
179mysql_src_compile() { 166configure_common() {
167 myconf="${myconf} $(use_with big-tables)"
168 myconf="${myconf} --enable-local-infile"
169 myconf="${myconf} --with-extra-charsets=all"
170 myconf="${myconf} --with-mysqld-user=mysql"
171 myconf="${myconf} --with-server"
172 myconf="${myconf} --with-unix-socket-path='/var/run/mysqld/mysqld.sock'"
173 myconf="${myconf} --without-libwrap"
180 174
181 mysql_init_vars
182 local myconf
183
184 if useq static ; then 175 if useq "static" ; then
185 myconf="${myconf} --with-mysqld-ldflags=-all-static" 176 myconf="${myconf} --with-mysqld-ldflags=-all-static"
186 myconf="${myconf} --with-client-ldflags=-all-static" 177 myconf="${myconf} --with-client-ldflags=-all-static"
187 myconf="${myconf} --disable-shared" 178 myconf="${myconf} --disable-shared"
188 else 179 else
189 myconf="${myconf} --enable-shared --enable-static" 180 myconf="${myconf} --enable-shared --enable-static"
190 fi 181 fi
191 182
192 #myconf="${myconf} `use_with tcpd libwrap`" 183 if useq "debug" ; then
184 myconf="${myconf} --with-debug=full"
185 else
186 myconf="${myconf} --without-debug"
187 mysql_version_is_at_least "4.01.03.00" \
188 && useq "cluster" \
189 && myconf="${myconf} --without-ndb-debug"
190 fi
191
192 if mysql_version_is_at_least "4.01.00.00" && ! useq "latin1" ; then
193 myconf="${myconf} --with-charset=utf8"
194 myconf="${myconf} --with-collation=utf8_general_ci"
195 else
196 myconf="${myconf} --with-charset=latin1"
197 myconf="${myconf} --with-collation=latin1_swedish_ci"
198 fi
199
200 if useq "embedded" ; then
201 myconf="${myconf} --with-embedded-privilege-control"
202 myconf="${myconf} --with-embedded-server"
203 else
204 myconf="${myconf} --without-embedded-privilege-control"
205 myconf="${myconf} --without-embedded-server"
206 fi
207
208}
209
210configure_40_41_50() {
211 myconf="${myconf} $(use_with perl bench)"
212 myconf="${myconf} --enable-assembler"
213 myconf="${myconf} --with-extra-tools"
214 myconf="${myconf} --with-innodb"
193 myconf="${myconf} --without-libwrap" 215 myconf="${myconf} --without-readline"
216 mysql_version_is_at_least "5.00.00.00" || myconf="${myconf} $(use_with raid)"
194 217
195 if useq ssl ; then 218 if useq "ssl" ; then
196 # --with-vio is not needed anymore, it's on by default and 219 # --with-vio is not needed anymore, it's on by default and
197 # has been removed from configure 220 # has been removed from configure
198 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio" 221 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio"
199 if mysql_version_is_at_least "5.00.06.00" ; then 222 if mysql_version_is_at_least "5.00.06.00" ; then
200 # yassl-0.96 is young break with gcc-4.0 || amd64
201 #myconf="${myconf} --with-yassl" 223 # myconf="${myconf} --with-yassl"
202 myconf="${myconf} --with-openssl" 224 myconf="${myconf} --with-openssl"
203 else 225 else
204 myconf="${myconf} --with-openssl" 226 myconf="${myconf} --with-openssl"
205 fi 227 fi
206 else 228 else
207 myconf="${myconf} --without-openssl" 229 myconf="${myconf} --without-openssl"
208 fi 230 fi
209 231
210 if useq debug; then 232 # The following fix is due to a bug with bdb on SPARC's. See:
233 # http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
234 # It comes down to non-64-bit safety problems.
235 if useq "sparc" || useq "alpha" || useq "hppa" || useq "mips" || useq "amd64" ; then
236 elog "Berkeley DB support was disabled due to incompatible arch"
211 myconf="${myconf} --with-debug=full" 237 myconf="${myconf} --without-berkeley-db"
212 else 238 else
213 myconf="${myconf} --without-debug" 239 if useq "berkdb" ; then
214 mysql_version_is_at_least "4.01.03.00" && useq cluster && myconf="${myconf} --without-ndb-debug"
215 fi
216
217 # benchmarking stuff needs perl
218 # and shouldn't be bothered with on minimal builds
219 if useq perl && ! useq minimal; then
220 myconf="${myconf} --with-bench" 240 myconf="${myconf} --with-berkeley-db=./bdb"
221 else
222 myconf="${myconf} --without-bench"
223 fi
224
225 # these are things we exclude from a minimal build
226 # note that the server actually does get built and installed
227 # but we then delete it before packaging.
228 local minimal_exclude_list="server embedded-server extra-tools innodb"
229 if ! useq minimal; then
230 for i in ${minimal_exclude_list}; do
231 myconf="${myconf} --with-${i}"
232 done
233
234 if useq static ; then
235 myconf="${myconf} --without-raid"
236 ewarn "disabling raid support, has problem with static"
237 else 241 else
238 if mysql_version_is_at_least "5.00.00.00" ; then
239 myconf="${myconf} --without-raid"
240 else
241 myconf="${myconf} `use_with raid`"
242 fi
243 fi
244
245 if ! mysql_version_is_at_least "5.00.00.00" ; then
246 if mysql_version_is_at_least "4.01.00.00" ; then
247 myconf="${myconf} --with-charset=utf8"
248 myconf="${myconf} --with-collation=utf8_general_ci"
249 else
250 myconf="${myconf} --with-charset=latin1"
251 myconf="${myconf} --with-collation=latin1_swedish_ci"
252 fi
253 fi
254
255 # optional again from 2005-12-05
256 if mysql_version_is_at_least "5.01.00.00" ; then
257 myconf="${myconf} $(use_with innodb)"
258 else
259 myconf="${myconf} --with-innodb"
260 fi
261
262 # lots of chars
263 myconf="${myconf} --with-extra-charsets=all"
264
265 #The following fix is due to a bug with bdb on sparc's. See:
266 #http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
267 # it comes down to non-64-bit safety problems
268 if useq sparc || useq alpha || useq hppa || useq mips || useq amd64 \
269 || mysql_check_version_range "5.01.00.00 to 5.01.06.99"
270 then
271 ewarn "bdb berkeley-db disabled due to arch or version"
272 myconf="${myconf} --without-berkeley-db" 242 myconf="${myconf} --without-berkeley-db"
273 else 243 fi
274 #TODO berkdb in 5.1 need to be worked on
275 useq berkdb && \
276 ! mysql_check_version_range "5.01.00.00 to 5.01.08.99" \
277 && myconf="${myconf} --with-berkeley-db=./bdb" \
278 || myconf="${myconf} --without-berkeley-db"
279 fi 244 fi
280 245
281 if mysql_version_is_at_least "4.01.03.00" ; then 246 if mysql_version_is_at_least "4.01.03.00" ; then
282 #myconf="${myconf} $(use_with geometry)"
283 myconf="${myconf} --with-geometry" 247 myconf="${myconf} --with-geometry"
284 myconf="${myconf} $(use_with cluster ndbcluster)" 248 myconf="${myconf} $(use_with cluster ndbcluster)"
285 fi 249 fi
286 250
287 mysql_version_is_at_least "4.01.11.00" && myconf="${myconf} `use_with big-tables`"
288
289 mysql_version_is_at_least "5.01.06.00" && myconf="${myconf} --with-ndb-binlog"
290
291 if useq embedded ; then
292 #REMIND, need the privilege control enabled ?
293 myconf="${myconf} --without-embedded-privilege-control"
294 myconf="${myconf} --with-embedded-server"
295 else
296 myconf="${myconf} --without-embedded-privilege-control"
297 myconf="${myconf} --without-embedded-server"
298 fi
299 else
300 for i in ${minimal_exclude_list}; do
301 myconf="${myconf} --without-${i}"
302 done
303 myconf="${myconf} --without-berkeley-db"
304 myconf="${myconf} --with-extra-charsets=none"
305 fi
306
307 if mysql_version_is_at_least "4.01.03.00" && useq extraengine; then 251 if mysql_version_is_at_least "4.01.03.00" && useq "extraengine" ; then
308 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html 252 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
309 myconf="${myconf} --with-archive-storage-engine" 253 myconf="${myconf} --with-archive-storage-engine"
254
310 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html 255 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
311
312 mysql_version_is_at_least "4.01.04.00" \
313 && myconf="${myconf} --with-csv-storage-engine" 256 myconf="${myconf} --with-csv-storage-engine"
314 257
315 mysql_version_is_at_least "4.01.11.00" \ 258 # http://dev.mysql.com/doc/mysql/en/blackhole-storage-engine.html
316 && myconf="${myconf} --with-blackhole-storage-engine" 259 myconf="${myconf} --with-blackhole-storage-engine"
317 260
261 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
318 # http://dev.mysql.com/doc/mysql/en/federated-description.html 262 # http://dev.mysql.com/doc/mysql/en/federated-description.html
319 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html 263 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
320 if mysql_version_is_at_least "5.00.03.00" ; then 264 if mysql_version_is_at_least "5.00.03.00" ; then
321 einfo "before to use federated engine be sure to read" 265 elog "Before using the Federated storage engine, please be sure to read"
322 einfo "http://dev.mysql.com/doc/refman/5.0/en/federated-limitations.html" 266 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
323 myconf="${myconf} --with-federated-storage-engine" 267 myconf="${myconf} --with-federated-storage-engine"
324
325 # http://dev.mysql.com/doc/refman/5.1/en/partitioning-overview.html
326 if mysql_version_is_at_least "5.01.00.00" ; then
327 myconf="${myconf} --with-partition"
328 fi 268 fi
329 fi
330
331 fi 269 fi
332 270
333 mysql_version_is_at_least "5.00.18.00" \ 271 mysql_version_is_at_least "5.00.18.00" \
334 && useq "max-idx-128" \ 272 && useq "max-idx-128" \
335 && myconf="${myconf} --with-max-indexes=128" 273 && myconf="${myconf} --with-max-indexes=128"
274}
336 275
337 if mysql_version_is_at_least "5.01.05.00" ; then 276configure_51() {
277 # TODO: !!!! readd --without-readline
278 # the failure depend upon config/ac-macros/readline.m4 checking into
279 # readline.h instead of history.h
280 myconf="${myconf} $(use_with ssl)"
281 myconf="${myconf} --enable-assembler"
282 myconf="${myconf} --with-geometry"
283 myconf="${myconf} --with-readline"
338 myconf="${myconf} --with-row-based-replication" 284 myconf="${myconf} --with-row-based-replication"
339 fi 285 myconf="${myconf} --with-zlib=/usr/$(get_libdir)"
286 myconf="${myconf} --without-pstack"
287 useq "max-idx-128" && myconf="${myconf} --with-max-indexes=128"
340 288
341 #TODO rechek again later, had problem with assembler enabled 289 # 5.1 introduces a new way to manage storage engines (plugins)
342 # and some combination of use-flags with 5.1 290 # like configuration=none
291 local plugins="csv,myisam,myisammrg,heap"
292 if useq "extraengine" ; then
293 # like configuration=max-no-ndb, archive and example removed in 5.1.11
294 plugins="${plugins},archive,blackhole,example,federated,ftexample,partition"
295
296 elog "Before using the Federated storage engine, please be sure to read"
297 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
298 fi
299
300 if useq "innodb" ; then
301 plugins="${plugins},innobase"
302 fi
303
304 # like configuration=max-no-ndb
305 if useq "cluster" ; then
306 plugins="${plugins},ndbcluster"
307 myconf="${myconf} --with-ndb-binlog"
308 fi
309
310 myconf="${myconf} --with-plugins=${plugins}"
311}
312
313#
314# EBUILD FUNCTIONS
315#
316
317mysql_pkg_setup() {
318 enewgroup mysql 60 || die "problem adding 'mysql' group"
319 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
320
321 if mysql_version_is_at_least "5.01.12.00" && useq "innodb" ; then
322 eerror "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
323 die "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
324 fi
325
326 # Check for USE flag problems in pkg_setup
327 if useq "static" && useq "ssl" ; then
328 eerror "MySQL does not support being built statically with SSL support enabled!"
329 die "MySQL does not support being built statically with SSL support enabled!"
330 fi
331
332 if ! mysql_version_is_at_least "5.00.00.00" \
333 && useq "raid" \
334 && useq "static" ; then
335 eerror "USE flags 'raid' and 'static' conflict, you cannot build MySQL statically"
336 eerror "with RAID support enabled."
337 die "USE flags 'raid' and 'static' conflict!"
338 fi
339
340 if mysql_version_is_at_least "4.01.03.00" \
341 && ( useq "cluster" || useq "extraengine" ) \
342 && useq "minimal" ; then
343 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
344 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
345 fi
346
343 if mysql_check_version_range "5.01.00.00 to 5.01.08.99" ; then 347 mysql_check_version_range "4.00.00.00 to 5.00.99.99" \
344 myconf="${myconf} --disable-assembler" 348 && useq "berkdb" \
349 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
350}
351
352mysql_src_unpack() {
353 # Initialize the proper variables first
354 mysql_init_vars
355
356 unpack ${A}
357
358 mv -f "${WORKDIR}/${MY_P}${MYSQL_RERELEASE}" "${S}"
359 cd "${S}"
360
361 # Apply the patches for this MySQL version
362 if [[ -d "${WORKDIR}/${MY_FIXED_PV}" ]] ; then
363 EPATCH_SOURCE="${WORKDIR}/${MY_FIXED_PV}" EPATCH_SUFFIX="patch" epatch
364 fi
365
366 # Additional checks, remove bundled zlib
367 rm -f "${S}/zlib/"*.[ch]
368 sed -i -e "s/zlib\/Makefile dnl/dnl zlib\/Makefile/" "${S}/configure.in"
369 rm -f "scripts/mysqlbug"
370
371 # Make charsets install in the right place
372 find . -name 'Makefile.am' \
373 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
374
375 # Manage mysqlmanager
376 mysql_version_is_at_least "5.00.15.00" \
377 && sed -i -e "s!@GENTOO_EXT@!!g" \
378 -e "s!@GENTOO_SOCK_PATH@!var/run/mysqld!g" \
379 "${S}/server-tools/instance-manager/Makefile.am"
380
381 if mysql_version_is_at_least "4.01.00.00" ; then
382 # Remove what needs to be recreated, so we're sure it's actually done
383 find . -name Makefile \
384 -o -name Makefile.in \
385 -o -name configure \
386 -exec rm -f {} \;
387 rm -f "ltmain.sh"
388 rm -f "scripts/mysqlbug"
389 fi
390
391 local rebuilddirlist bdbdir d
392
393 if mysql_version_is_at_least "5.01.12.00" ; then
394 # TODO: innodb is using cmake now?
395 rebuilddirlist="."
396 bdbdir=''
345 else 397 else
346 myconf="${myconf} --enable-assembler" 398 rebuilddirlist=". innobase"
399 bdbdir='bdb/dist'
400 fi
401
402 for d in ${rebuilddirlist} ; do
403 einfo "Reconfiguring dir '${d}'"
404 pushd "${d}" &>/dev/null
405 AT_GNUCONF_UPDATE="yes" eautoreconf
406 popd &>/dev/null
407 done
408
409 if mysql_check_version_range "4.01.00.00 to 5.00.99.99" \
410 && useq "berkdb" ; then
411 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f "ltmain.sh" "${bdbdir}/ltmain.sh"
412 pushd "${bdbdir}" \
413 && sh s_all \
414 || die "Failed bdb reconfigure" \
415 &>/dev/null
416 popd &>/dev/null
417 fi
418}
419
420mysql_src_compile() {
421 # Make sure the vars are correctly initialized
422 mysql_init_vars
423
424 # $myconf is modified by the configure_* functions
425 local myconf=""
426
427 if useq "minimal" ; then
428 configure_minimal
429 else
430 configure_common
431 if mysql_version_is_at_least "5.01.10.00" ; then
432 configure_51
433 else
434 configure_40_41_50
347 fi 435 fi
436 fi
348 437
349 #Bug #114895,Bug #110149 438 # Bug #114895, bug #110149
350 filter-flags "-O" "-O[01]" 439 filter-flags "-O" "-O[01]"
440
351 #glibc-2.3.2_pre fix; bug #16496 441 # glib-2.3.2_pre fix, bug #16496
352 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 442 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
353 443
354 #the compiler flags are as per their "official" spec ;) 444 append-flags "-fno-exceptions -fno-strict-aliasing"
355 #CFLAGS="${CFLAGS/-O?/} -O3" \
356 export CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" 445 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
357 mysql_version_is_at_least "5.00.00.00" \ 446 mysql_version_is_at_least "5.00.00.00" \
358 && export CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 447 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
448 export CXXFLAGS
359 449
360 econf \ 450 econf \
361 --program-suffix="${MY_SUFFIX}" \
362 --libexecdir="/usr/sbin" \ 451 --libexecdir="/usr/sbin" \
363 --sysconfdir="${MY_SYSCONFDIR}" \ 452 --sysconfdir="${MY_SYSCONFDIR}" \
364 --localstatedir="${MY_LOCALSTATEDIR}" \ 453 --localstatedir="${MY_LOCALSTATEDIR}" \
365 --sharedstatedir="${MY_SHAREDSTATEDIR}" \ 454 --sharedstatedir="${MY_SHAREDSTATEDIR}" \
366 --libdir="${MY_LIBDIR}" \ 455 --libdir="${MY_LIBDIR}" \
367 --includedir="${MY_INCLUDEDIR}" \ 456 --includedir="${MY_INCLUDEDIR}" \
368 --with-low-memory \ 457 --with-low-memory \
369 --enable-local-infile \
370 --with-mysqld-user=mysql \
371 --with-client-ldflags=-lstdc++ \ 458 --with-client-ldflags=-lstdc++ \
372 --enable-thread-safe-client \ 459 --enable-thread-safe-client \
373 --with-comment="Gentoo Linux ${PF}" \ 460 --with-comment="Gentoo Linux ${PF}" \
374 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
375 --with-lib-ccflags="-fPIC" \
376 --without-readline \
377 --without-docs \ 461 --without-docs \
378 ${myconf} || die "bad ./configure" 462 ${myconf} || die "econf failed"
379 463
380 # TODO Move this before autoreconf !!! 464 # TODO: Move this before autoreconf !!!
381 find . -type f -name Makefile -print0 \ 465 find . -type f -name Makefile -print0 \
382 | xargs -0 -n100 sed -i \ 466 | xargs -0 -n100 sed -i \
383 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|' 467 -e 's|^pkglibdir *= *$(libdir)/mysql|pkglibdir = $(libdir)|;s|^pkgincludedir *= *$(includedir)/mysql|pkgincludedir = $(includedir)|'
384 468
385 emake || die "compile problem" 469 emake || die "emake failed"
386} 470}
387 471
388mysql_src_install() { 472mysql_src_install() {
389 473 # Make sure the vars are correctly initialized
390 mysql_init_vars 474 mysql_init_vars
475
391 make install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die 476 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed"
392 477
393 insinto "${MY_INCLUDEDIR}" 478 insinto "${MY_INCLUDEDIR}"
394 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h 479 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h
395 480
396 # convenience links 481 # Convenience links
397 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlanalyze${MY_SUFFIX}" 482 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
398 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlrepair${MY_SUFFIX}" 483 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
399 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqloptimize${MY_SUFFIX}" 484 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize"
400 485
401 # various junk (my-*.cnf moved elsewhere) 486 # Various junk (my-*.cnf moved elsewhere)
402 rm -rf "${D}/usr/share/info" 487 rm -Rf "${D}/usr/share/info"
403 for removeme in "mysql-log-rotate" mysql.server* \ 488 for removeme in "mysql-log-rotate" mysql.server* \
404 binary-configure* my-*.cnf mi_test_all* 489 binary-configure* my-*.cnf mi_test_all*
405 do 490 do
406 rm -f ${D}/usr/share/mysql/${removeme} 491 rm -f "${D}"/usr/share/mysql/${removeme}
407 done 492 done
408 493
409 # TODO change at Makefile-am level
410 for moveme in "mysql_fix_privilege_tables.sql" \
411 "fill_help_tables.sql" "ndb-config-2-node.ini"
412 do
413 mv -f "${D}/usr/share/mysql/${moveme}" "${D}/usr/share/mysql${MY_SUFFIX}/" 2>/dev/null
414 done
415
416 if [[ -n "${MY_SUFFIX}" ]] ; then
417 local notcatched=$(ls "${D}/usr/share/mysql"/*)
418 if [[ -n "${notcatched}" ]] ; then
419 ewarn "QA notice"
420 ewarn "${notcatched} files in /usr/share/mysql"
421 ewarn "bug mysql-herd to manage them"
422 fi
423 rm -rf "${D}/usr/share/mysql"
424 fi
425
426 # clean up stuff for a minimal build 494 # Clean up stuff for a minimal build
427 # this is anything server-specific
428 if useq minimal; then 495 if useq "minimal" ; then
429 rm -rf ${D}${MY_SHAREDSTATEDIR}/{mysql-test,sql-bench} 496 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
430 rm -f ${D}/usr/bin/{mysql{_install_db,manager*,_secure_installation,_fix_privilege_tables,hotcopy,_convert_table_format,d_multi,_fix_extensions,_zap,_explain_log,_tableinfo,d_safe,_install,_waitpid,binlog,test},myisam*,isam*,pack_isam} 497 rm -f "${D}"/usr/bin/{mysql{_install_db,manager*,_secure_installation,_fix_privilege_tables,hotcopy,_convert_table_format,d_multi,_fix_extensions,_zap,_explain_log,_tableinfo,d_safe,_install,_waitpid,binlog,test},myisam*,isam*,pack_isam}
431 rm -f "${D}/usr/sbin/mysqld${MY_SUFFIX}" 498 rm -f "${D}/usr/sbin/mysqld"
432 rm -f ${D}${MY_LIBDIR}/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a 499 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
433 fi 500 fi
434 501
435 # config stuff 502 # Configuration stuff
503 if mysql_version_is_at_least "4.01.00.00" ; then
504 mysql_mycnf_version="4.1"
505 else
506 mysql_mycnf_version="4.0"
507 fi
436 insinto "${MY_SYSCONFDIR}" 508 insinto "${MY_SYSCONFDIR}"
437 doins scripts/mysqlaccess.conf 509 doins "scripts/mysqlaccess.conf"
438 sed -e "s!@MY_SUFFIX@!${MY_SUFFIX}!g" \
439 -e "s!@DATADIR@!${DATADIR}!g" \ 510 sed -e "s!@DATADIR@!${DATADIR}!g" \
440 "${FILESDIR}/my.cnf-4.1-r1" \ 511 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
441 > "${TMPDIR}/my.cnf.ok" 512 > "${TMPDIR}/my.cnf.ok"
513 if mysql_version_is_at_least "4.01.00.00" && useq "latin1" ; then
514 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok"
515 fi
442 newins "${TMPDIR}/my.cnf.ok" my.cnf 516 newins "${TMPDIR}/my.cnf.ok" my.cnf
443 517
444 insinto "/etc/conf.d" 518 insinto "/etc/conf.d"
445 newins "${FILESDIR}/mysql.conf.d-r1" "mysql" 519 newins "${FILESDIR}/mysql.conf.d" "mysql"
446 mysql_version_is_at_least "5.00.11.00" \ 520 mysql_version_is_at_least "5.00.11.00" \
447 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager" 521 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager"
448 522
449 # minimal builds don't have the server 523 # Minimal builds don't have the MySQL server
450 if ! useq minimal; then 524 if ! useq "minimal" ; then
451 exeinto /etc/init.d 525 exeinto "/etc/init.d"
452 newexe "${FILESDIR}/mysql.rc6-r3" "mysql" 526 newexe "${FILESDIR}/mysql.rc6" "mysql"
453
454 mysql_version_is_at_least "5.00.11.00" \ 527 mysql_version_is_at_least "5.00.11.00" \
455 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager" 528 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager"
529
456 insinto /etc/logrotate.d 530 insinto "/etc/logrotate.d"
457 sed -e "s!___MY_SUFFIX___!${MY_SUFFIX}!g" \
458 "${FILESDIR}/logrotate-slot.mysql" \
459 > "${TMPDIR}/logrotate.mysql"
460 newins "${TMPDIR}/logrotate.mysql" "mysql${MY_SUFFIX}" 531 newins "${FILESDIR}/logrotate.mysql" "mysql"
461 532
462 #empty dirs... 533 # Empty directories ...
463 diropts "-m0750" 534 diropts "-m0750"
464 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 535 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
465 dodir "${DATADIR}" 536 dodir "${DATADIR}"
466 keepdir "${DATADIR}" 537 keepdir "${DATADIR}"
467 chown -R mysql:mysql "${D}/${DATADIR}" 538 chown -R mysql:mysql "${D}/${DATADIR}"
473 keepdir "${folder}" 544 keepdir "${folder}"
474 chown -R mysql:mysql "${D}/${folder}" 545 chown -R mysql:mysql "${D}/${folder}"
475 done 546 done
476 fi 547 fi
477 548
478 # docs 549 # Docs
479 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 550 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
551
480 # minimal builds don't have the server 552 # Minimal builds don't have the MySQL server
481 if ! useq minimal; then 553 if ! useq "minimal" ; then
482 docinto "support-files" 554 docinto "support-files"
483 for script in \ 555 for script in \
484 support-files/my-*.cnf \ 556 support-files/my-*.cnf \
485 support-files/magic \ 557 support-files/magic \
486 support-files/ndb-config-2-node.ini 558 support-files/ndb-config-2-node.ini
492 for script in scripts/mysql* ; do 564 for script in scripts/mysql* ; do
493 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 565 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
494 done 566 done
495 fi 567 fi
496 568
497 # oops, temporary fix 569 ROOT="${D}" mysql_lib_symlinks
498 mysql_check_version_range "5.00.16.00 to 5.00.18.99" \
499 && cp -f \
500 "${WORKDIR}/mysql-extras/fill_help_tables.sql-5.0" \
501 "${D}/usr/share/mysql${MY_SUFFIX}/fill_help_tables.sql"
502
503 if [[ ${SLOT} -gt 0 ]] ; then
504 # MOVED HERE DUE TO BUG #121445
505 # create a list of files, to be used
506 # by external utilities
507 mkdir -p "${D}/var/lib/eselect/mysql/"
508 local filelist="${D}/var/lib/eselect/mysql/mysql${MY_SUFFIX}.filelist"
509 pushd "${D}/" &>/dev/null
510 find usr/bin/ usr/sbin/ \
511 -type f -name "*${MY_SUFFIX}*" \
512 -and -not -name "mysql_config${MY_SUFFIX}" \
513 > "${filelist}"
514 find usr/share/man \
515 -type f -name "*${MY_SUFFIX}*" \
516 | sed -e 's/$/.gz/' \
517 >> "${filelist}"
518 echo "${MY_SYSCONFDIR#"/"}" >> "${filelist}"
519 echo "${MY_LIBDIR#"/"}" >> "${filelist}"
520 echo "${MY_SHAREDSTATEDIR#"/"}" >> "${filelist}"
521 popd &>/dev/null
522 fi
523
524 # It's safer portage wis doing this in instal, but we can't
525 # if it's a slotted install
526 [[ ${SLOT} -eq 0 ]] && ROOT="${D}" mysql_lib_symlinks
527} 570}
528 571
529mysql_pkg_preinst() { 572mysql_pkg_preinst() {
530
531 enewgroup mysql 60 || die "problem adding group mysql" 573 enewgroup mysql 60 || die "problem adding 'mysql' group"
532 enewuser mysql 60 -1 /dev/null mysql \ 574 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
533 || die "problem adding user mysql"
534} 575}
535 576
536mysql_pkg_postinst() { 577mysql_pkg_postinst() {
537 578 # Make sure the vars are correctly initialized
538 mysql_init_vars 579 mysql_init_vars
539 # slotted, manage lib symlinks on the real file-system
540 # to cope with other version installed
541 [[ ${SLOT} -ne 0 ]] && mysql_lib_symlinks
542 580
543 # mind at FEATURES=collision-protect before to remove this 581 # Check FEATURES="collision-protect" before removing this
544 [ -d "${ROOT}/var/log/mysql" ] \ 582 [[ -d "${ROOT}/var/log/mysql" ]] \
545 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}" 583 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
546 584
547 #secure the logfiles... does this bother anybody? 585 # Secure the logfiles
548 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 586 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
549 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 587 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
550 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 588 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
551 589
552 if ! useq minimal; then 590 if ! useq "minimal" ; then
553 if [[ ${SLOT} -gt 0 ]] ; then
554 einfo "you may want to read:"
555 einfo "http://www.gentoo.org/doc/en/mysql-upgrade-slotted.xml"
556 einfo "you may want to run \"eselect mysql list\" followed by a "
557 einfo "\"eselect mysql set 1\" to choose the default mysql server"
558 fi
559
560 # your friendly public service announcement... 591 # Your friendly public service announcement ...
561 einfo 592 einfo
562 einfo "You might want to run:" 593 elog "You might want to run:"
563 einfo "\"emerge --config =${CATEGORY}/${PF}\"" 594 elog "\"emerge --config =${CATEGORY}/${PF}\""
564 einfo "if this is a new install." 595 elog "if this is a new install."
565 einfo 596 einfo
566 mysql_version_is_at_least "5.01.00.00" \ 597 mysql_version_is_at_least "5.01.00.00" \
567 || einfo "InnoDB is not optional as of MySQL-4.0.24, at the request of upstream." 598 || elog "InnoDB is *not* optional as of MySQL-4.0.24, at the request of upstream."
568 fi 599 fi
600 mysql_check_version_range "4.00.00.00 to 5.00.99.99" \
601 && useq "berkdb" \
602 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
569} 603}
570 604
571mysql_pkg_config() { 605mysql_pkg_config() {
606 # Make sure the vars are correctly initialized
572 mysql_init_vars 607 mysql_init_vars
608
573 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR" 609 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR"
574 610
575 if built_with_use dev-db/mysql minimal; then 611 if built_with_use dev-db/mysql minimal ; then
576 die "Minimal builds do NOT include the MySQL server" 612 die "Minimal builds do NOT include the MySQL server"
577 fi 613 fi
578 614
579 local pwd1="a" 615 local pwd1="a"
580 local pwd2="b" 616 local pwd2="b"
586 ewarn "Please rename or delete it if you wish to replace it." 622 ewarn "Please rename or delete it if you wish to replace it."
587 die "MySQL database already exists!" 623 die "MySQL database already exists!"
588 fi 624 fi
589 625
590 einfo "Creating the mysql database and setting proper" 626 einfo "Creating the mysql database and setting proper"
591 einfo "permissions on it..." 627 einfo "permissions on it ..."
592 628
593 einfo "Insert a password for the mysql 'root' user" 629 einfo "Insert a password for the mysql 'root' user"
594 ewarn "Avoid [\"'\\_%] characters in the password" 630 ewarn "Avoid [\"'\\_%] characters in the password"
595
596 read -rsp " >" pwd1 ; echo 631 read -rsp " >" pwd1 ; echo
632
597 einfo "Check the password" 633 einfo "Retype the password"
598 read -rsp " >" pwd2 ; echo 634 read -rsp " >" pwd2 ; echo
599 635
600 if [[ "x$pwd1" != "x$pwd2" ]] ; then 636 if [[ "x$pwd1" != "x$pwd2" ]] ; then
601 die "Passwords are not the same" 637 die "Passwords are not the same"
602 fi 638 fi
603 639
604 local options="" 640 local options=""
605 local sqltmp="$(emktemp)" 641 local sqltmp="$(emktemp)"
606 642
607 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql" 643 local help_tables="${ROOT}${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
608 [[ -r "${help_tables}" ]] \ 644 [[ -r "${help_tables}" ]] \
609 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \ 645 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
610 || touch "${TMPDIR}/fill_help_tables.sql" 646 || touch "${TMPDIR}/fill_help_tables.sql"
611 help_tables="${TMPDIR}/fill_help_tables.sql" 647 help_tables="${TMPDIR}/fill_help_tables.sql"
612 648
613 pushd "${TMPDIR}" &>/dev/null 649 pushd "${TMPDIR}" &>/dev/null
614 ${ROOT}/usr/bin/mysql_install_db${MY_SUFFIX} | grep -B5 -A999 -i "ERROR" 650 "${ROOT}/usr/bin/mysql_install_db" | grep -B5 -A999 -i "ERROR"
615 popd &>/dev/null 651 popd &>/dev/null
616 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] || die "MySQL databases not installed" 652 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \
653 || die "MySQL databases not installed"
617 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null 654 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null
618 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null 655 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null
619 656
620 if mysql_version_is_at_least "4.01.03.00" ; then 657 if mysql_version_is_at_least "4.01.03.00" ; then
621 options="--skip-ndbcluster" 658 options="--skip-ndbcluster"
622 659
623 # Filling timezones, see 660 # Filling timezones, see
624 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 661 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html
625 ${ROOT}/usr/bin/mysql_tzinfo_to_sql${MY_SUFFIX} ${ROOT}/usr/share/zoneinfo \ 662 "${ROOT}/usr/bin/mysql_tzinfo_to_sql" "${ROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
626 > "${sqltmp}" 2>/dev/null
627 663
628 if [[ -r "${help_tables}" ]] ; then 664 if [[ -r "${help_tables}" ]] ; then
629 cat "${help_tables}" >> "${sqltmp}" 665 cat "${help_tables}" >> "${sqltmp}"
630 fi 666 fi
631 fi 667 fi
632 668
633 local socket=${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock 669 local socket="${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock"
634 local pidfile=${ROOT}/var/run/mysqld/mysqld${MY_SUFFIX}${RANDOM}.pid 670 local pidfile="${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid"
635 local mysqld="${ROOT}/usr/sbin/mysqld${MY_SUFFIX} \ 671 local mysqld="${ROOT}/usr/sbin/mysqld \
636 ${options} \ 672 ${options} \
637 --user=mysql \ 673 --user=mysql \
638 --skip-grant-tables \ 674 --skip-grant-tables \
639 --basedir=${ROOT}/usr \ 675 --basedir=${ROOT}/usr \
640 --datadir=${ROOT}/${DATADIR} \ 676 --datadir=${ROOT}/${DATADIR} \
643 --skip-networking \ 679 --skip-networking \
644 --max_allowed_packet=8M \ 680 --max_allowed_packet=8M \
645 --net_buffer_length=16K \ 681 --net_buffer_length=16K \
646 --socket=${socket} \ 682 --socket=${socket} \
647 --pid-file=${pidfile}" 683 --pid-file=${pidfile}"
648 $mysqld & 684 ${mysqld} &
649 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do 685 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do
650 maxtry=$(($maxtry-1)) 686 maxtry=$((${maxtry}-1))
651 echo -n "." 687 echo -n "."
652 sleep 1 688 sleep 1
653 done 689 done
654 690
655 # do this from memory we don't want clear text password in temp files 691 # Do this from memory, as we don't want clear text passwords in temp files
656 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'" 692 local sql="UPDATE mysql.user SET Password = PASSWORD('${pwd1}') WHERE USER='root'"
657 ${ROOT}/usr/bin/mysql${MY_SUFFIX} \ 693 "${ROOT}/usr/bin/mysql" \
658 --socket=${socket} \ 694 --socket=${socket} \
659 -hlocalhost \ 695 -hlocalhost \
660 -e "${sql}" 696 -e "${sql}"
661 697
662 einfo "Loading \"zoneinfo\" this step may require few seconds" 698 einfo "Loading \"zoneinfo\", this step may require a few seconds ..."
663 699
664 ${ROOT}/usr/bin/mysql${MY_SUFFIX} \ 700 "${ROOT}/usr/bin/mysql" \
665 --socket=${socket} \ 701 --socket=${socket} \
666 -hlocalhost \ 702 -hlocalhost \
667 -uroot \ 703 -uroot \
668 -p"${pwd1}" \ 704 -p"${pwd1}" \
669 mysql < "${sqltmp}" 705 mysql < "${sqltmp}"
670 706
671 # server stop and cleanup 707 # Stop the server and cleanup
672 kill $(< "${pidfile}" ) 708 kill $(< "${pidfile}" )
673 rm "${sqltmp}" 709 rm -f "${sqltmp}"
674 einfo "stopping the server," 710 einfo "Stopping the server ..."
675 wait %1 711 wait %1
676 einfo "done" 712 einfo "Done"
677}
678
679mysql_pkg_prerm() {
680 if [[ ${SLOT} -gt 0 ]] ; then
681 # external program
682 eselect mysql slot_remove "${SLOT}"
683 fi
684} 713}
685 714
686mysql_pkg_postrm() { 715mysql_pkg_postrm() {
687 mysql_lib_symlinks 716 mysql_lib_symlinks
688 if [[ ${SLOT} -gt 0 ]] ; then
689 einfo "you may want to run \"eselect mysql list\" followed by a "
690 einfo "\"eselect mysql list\" to choose the default mysql server"
691 fi
692} 717}

Legend:
Removed from v.1.25  
changed lines
  Added in v.1.42

  ViewVC Help
Powered by ViewVC 1.1.20