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

Diff of /eclass/mysql.eclass

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

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

Legend:
Removed from v.1.26  
changed lines
  Added in v.1.39

  ViewVC Help
Powered by ViewVC 1.1.20