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

Diff of /eclass/mysql.eclass

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

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

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

  ViewVC Help
Powered by ViewVC 1.1.20