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

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

  ViewVC Help
Powered by ViewVC 1.1.20