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

Diff of /eclass/mysql.eclass

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

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

Legend:
Removed from v.1.12  
changed lines
  Added in v.1.49

  ViewVC Help
Powered by ViewVC 1.1.20