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

Diff of /eclass/mysql.eclass

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

Revision 1.29 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.29 2006/04/12 21:15:17 chtekk 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="20060411"
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
264 if useq "static" ; then
265 myconf="${myconf} --without-raid"
266 ewarn "disabling raid support, has problem with static"
267 else
268 if mysql_version_is_at_least "5.00.00.00" ; then 464 if ! mysql_version_is_at_least "5.00.00.00" ; then
465 if useq "raid" ; then
466 myconf="${myconf} --with-raid"
467 else
269 myconf="${myconf} --without-raid" 468 myconf="${myconf} --without-raid"
270 else
271 myconf="${myconf} `use_with raid`"
272 fi 469 fi
273 fi 470 fi
274 471
275 if mysql_version_is_at_least "4.01.00.00" ; then 472 if mysql_version_is_at_least "4.01.00.00" && ! useq "latin1" ; then
276 myconf="${myconf} --with-charset=utf8" 473 myconf="${myconf} --with-charset=utf8"
277 myconf="${myconf} --with-collation=utf8_general_ci" 474 myconf="${myconf} --with-collation=utf8_general_ci"
278 else 475 else
279 myconf="${myconf} --with-charset=latin1" 476 myconf="${myconf} --with-charset=latin1"
280 myconf="${myconf} --with-collation=latin1_swedish_ci" 477 myconf="${myconf} --with-collation=latin1_swedish_ci"
281 fi 478 fi
282 479
283 # optional again from 2005-12-05 480 # Optional again with MySQL 5.1
284 if mysql_version_is_at_least "5.01.00.00" ; then 481 if mysql_version_is_at_least "5.01.00.00" ; then
285 myconf="${myconf} $(use_with innodb)" 482 if useq "innodb" ; then
286 else
287 myconf="${myconf} --with-innodb" 483 myconf="${myconf} --with-innodb"
484 else
485 myconf="${myconf} --without-innodb"
288 fi 486 fi
487 fi
289 488
290 # lots of chars 489 # Lots of charsets
291 myconf="${myconf} --with-extra-charsets=all" 490 myconf="${myconf} --with-extra-charsets=all"
292 491
293 #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:
294 #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
295 # it comes down to non-64-bit safety problems 494 # It comes down to non-64-bit safety problems.
296 if useq "sparc" || useq "alpha" || useq "hppa" || useq "mips" \ 495 if useq "sparc" || useq "alpha" || useq "hppa" || useq "mips" || useq "amd64" ; then
297 || 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"
298 then
299 ewarn "bdb berkeley-db disabled due to arch or version"
300 myconf="${myconf} --without-berkeley-db" 497 myconf="${myconf} --without-berkeley-db"
301 else 498 else
302 #TODO berkdb in 5.1 need to be worked on 499 # TODO: berkdb in MySQL 5.1 needs to be worked on
303 useq "berkdb" && \
304 ! 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
305 && myconf="${myconf} --with-berkeley-db=./bdb" \ 501 myconf="${myconf} --with-berkeley-db=./bdb"
502 else
306 || myconf="${myconf} --without-berkeley-db" 503 myconf="${myconf} --without-berkeley-db"
504 fi
307 fi 505 fi
308 506
309 if mysql_version_is_at_least "4.01.03.00" ; then 507 if mysql_version_is_at_least "4.01.03.00" ; then
310 #myconf="${myconf} $(use_with geometry)"
311 myconf="${myconf} --with-geometry" 508 myconf="${myconf} --with-geometry"
509
510 if useq "cluster" ; then
511 myconf="${myconf} --with-ndbcluster"
512 else
312 myconf="${myconf} $(use_with cluster ndbcluster)" 513 myconf="${myconf} --without-ndbcluster"
313 fi 514 fi
515 fi
314 516
315 mysql_version_is_at_least "4.01.11.00" \ 517 if useq "big-tables" ; then
316 && myconf="${myconf} `use_with big-tables`" 518 myconf="${myconf} --with-big-tables"
519 else
520 myconf="${myconf} --without-big-tables"
521 fi
317 522
318 mysql_version_is_at_least "5.01.06.00" \ 523 mysql_version_is_at_least "5.01.06.00" \
319 && myconf="${myconf} --with-ndb-binlog" 524 && myconf="${myconf} --with-ndb-binlog"
320 525
321 if useq "embedded" ; then 526 if useq "embedded" ; then
322 #REMIND, need the privilege control enabled ?
323 myconf="${myconf} --without-embedded-privilege-control" 527 myconf="${myconf} --with-embedded-privilege-control"
324 myconf="${myconf} --with-embedded-server" 528 myconf="${myconf} --with-embedded-server"
325 else 529 else
326 myconf="${myconf} --without-embedded-privilege-control" 530 myconf="${myconf} --without-embedded-privilege-control"
327 myconf="${myconf} --without-embedded-server" 531 myconf="${myconf} --without-embedded-server"
328 fi 532 fi
329 533
330 # benchmarking stuff needs perl 534 # Benchmarking stuff needs Perl
331 if useq "perl" ; then 535 if useq "perl" ; then
332 myconf="${myconf} --with-bench" 536 myconf="${myconf} --with-bench"
333 else 537 else
334 myconf="${myconf} --without-bench" 538 myconf="${myconf} --without-bench"
335 fi 539 fi
336 else 540 else
337 for i in ${minimal_exclude_list}; do 541 for i in ${minimal_exclude_list} ; do
338 myconf="${myconf} --without-${i}" 542 myconf="${myconf} --without-${i}"
339 done 543 done
340 myconf="${myconf} --without-berkeley-db" 544 myconf="${myconf} --without-berkeley-db"
341 myconf="${myconf} --with-extra-charsets=none" 545 myconf="${myconf} --with-extra-charsets=none"
342 fi 546 fi
343 547
344 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
345 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html 549 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
346 myconf="${myconf} --with-archive-storage-engine" 550 myconf="${myconf} --with-archive-storage-engine"
551
347 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html 552 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
348
349 mysql_version_is_at_least "4.01.04.00" \
350 && myconf="${myconf} --with-csv-storage-engine" 553 myconf="${myconf} --with-csv-storage-engine"
351 554
352 mysql_version_is_at_least "4.01.11.00" \ 555 # http://dev.mysql.com/doc/mysql/en/blackhole-storage-engine.html
353 && myconf="${myconf} --with-blackhole-storage-engine" 556 myconf="${myconf} --with-blackhole-storage-engine"
354 557
558 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
355 # http://dev.mysql.com/doc/mysql/en/federated-description.html 559 # http://dev.mysql.com/doc/mysql/en/federated-description.html
356 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html 560 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
357 if mysql_version_is_at_least "5.00.03.00" ; then 561 if mysql_version_is_at_least "5.00.03.00" ; then
358 einfo "before to use federated engine be sure to read" 562 elog "Before using the Federated storage engine, please be sure to read"
359 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"
360 myconf="${myconf} --with-federated-storage-engine" 564 myconf="${myconf} --with-federated-storage-engine"
565 fi
361 566
362 # 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
363 if mysql_version_is_at_least "5.01.00.00" ; then 568 if mysql_version_is_at_least "5.01.00.00" ; then
364 myconf="${myconf} --with-partition" 569 myconf="${myconf} --with-partition"
365 fi 570 fi
366 fi
367
368 fi 571 fi
369 572
370 mysql_version_is_at_least "5.00.18.00" \ 573 mysql_version_is_at_least "5.00.18.00" \
371 && useq "max-idx-128" \ 574 && useq "max-idx-128" \
372 && myconf="${myconf} --with-max-indexes=128" 575 && myconf="${myconf} --with-max-indexes=128"
373 576
374 if mysql_version_is_at_least "5.01.05.00" ; then 577 mysql_version_is_at_least "5.01.05.00" \
375 myconf="${myconf} --with-row-based-replication" 578 && myconf="${myconf} --with-row-based-replication"
376 fi
377 579
378 #TODO rechek again later, had problem with assembler enabled 580 # TODO: Rechek again later, there were problems with assembler enabled
379 # and some combination of use-flags with 5.1 581 # and some combination of USE flags with MySQL 5.1
380 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
381 myconf="${myconf} --disable-assembler" 583 myconf="${myconf} --disable-assembler"
382 else 584 else
383 myconf="${myconf} --enable-assembler" 585 myconf="${myconf} --enable-assembler"
384 fi 586 fi
385 587
386 #Bug #114895,Bug #110149 588 # Bug #114895, bug #110149
387 filter-flags "-O" "-O[01]" 589 filter-flags "-O" "-O[01]"
590
388 #glibc-2.3.2_pre fix; bug #16496 591 # glib-2.3.2_pre fix, bug #16496
389 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 592 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
390 593
391 #the compiler flags are as per their "official" spec ;) 594 append-flags "-fno-exceptions -fno-strict-aliasing"
392 #CFLAGS="${CFLAGS/-O?/} -O3" \
393 export CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" 595 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
394 mysql_version_is_at_least "5.00.00.00" \ 596 mysql_version_is_at_least "5.00.00.00" \
395 && export CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 597 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
598 export CXXFLAGS
396 599
397 econf \ 600 econf \
398 --libexecdir="/usr/sbin" \ 601 --libexecdir="/usr/sbin" \
399 --sysconfdir="${MY_SYSCONFDIR}" \ 602 --sysconfdir="${MY_SYSCONFDIR}" \
400 --localstatedir="${MY_LOCALSTATEDIR}" \ 603 --localstatedir="${MY_LOCALSTATEDIR}" \
408 --enable-thread-safe-client \ 611 --enable-thread-safe-client \
409 --with-comment="Gentoo Linux ${PF}" \ 612 --with-comment="Gentoo Linux ${PF}" \
410 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \ 613 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
411 --without-readline \ 614 --without-readline \
412 --without-docs \ 615 --without-docs \
413 ${myconf} || die "bad ./configure" 616 ${myconf} || die "econf failed"
414 617
415 # TODO Move this before autoreconf !!! 618 # TODO: Move this before autoreconf !!!
416 find . -type f -name Makefile -print0 \ 619 find . -type f -name Makefile -print0 \
417 | xargs -0 -n100 sed -i \ 620 | xargs -0 -n100 sed -i \
418 -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)|'
419 622
420 emake || die "compile problem" 623 emake || die "emake failed"
421} 624}
422 625
423mysql_src_install() { 626mysql_src_install() {
424 627 # Make sure the vars are correctly initialized
425 mysql_init_vars 628 mysql_init_vars
629
426 make install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die 630 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed"
427 631
428 insinto "${MY_INCLUDEDIR}" 632 insinto "${MY_INCLUDEDIR}"
429 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h 633 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h
430 634
431 # convenience links 635 # Convenience links
432 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze" 636 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze"
433 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair" 637 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair"
434 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize" 638 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize"
435 639
436 # various junk (my-*.cnf moved elsewhere) 640 # Various junk (my-*.cnf moved elsewhere)
437 rm -rf "${D}/usr/share/info" 641 rm -Rf "${D}/usr/share/info"
438 for removeme in "mysql-log-rotate" mysql.server* \ 642 for removeme in "mysql-log-rotate" mysql.server* \
439 binary-configure* my-*.cnf mi_test_all* 643 binary-configure* my-*.cnf mi_test_all*
440 do 644 do
441 rm -f ${D}/usr/share/mysql/${removeme} 645 rm -f "${D}"/usr/share/mysql/${removeme}
442 done 646 done
443 647
444 # clean up stuff for a minimal build 648 # Clean up stuff for a minimal build
445 # this is anything server-specific
446 if useq "minimal" ; then 649 if useq "minimal" ; then
447 rm -rf ${D}${MY_SHAREDSTATEDIR}/{mysql-test,sql-bench} 650 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench}
448 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}
449 rm -f "${D}/usr/sbin/mysqld" 652 rm -f "${D}/usr/sbin/mysqld"
450 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
451 fi 654 fi
452 655
453 # 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
454 insinto "${MY_SYSCONFDIR}" 662 insinto "${MY_SYSCONFDIR}"
455 doins scripts/mysqlaccess.conf 663 doins "scripts/mysqlaccess.conf"
456 sed -e "s!@MY_SUFFIX@!!g" \
457 -e "s!@DATADIR@!${DATADIR}!g" \ 664 sed -e "s!@DATADIR@!${DATADIR}!g" \
458 "${FILESDIR}/my.cnf-4.1-r1" \ 665 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
459 > "${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
460 newins "${TMPDIR}/my.cnf.ok" my.cnf 670 newins "${TMPDIR}/my.cnf.ok" my.cnf
461 671
462 insinto "/etc/conf.d" 672 insinto "/etc/conf.d"
463 newins "${FILESDIR}/mysql.conf.d-r1" "mysql" 673 newins "${FILESDIR}/mysql.conf.d" "mysql"
464 mysql_version_is_at_least "5.00.11.00" \ 674 mysql_version_is_at_least "5.00.11.00" \
465 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager" 675 && newins "${FILESDIR}/mysqlmanager.conf.d" "mysqlmanager"
466 676
467 # minimal builds don't have the server 677 # Minimal builds don't have the MySQL server
468 if ! useq "minimal" ; then 678 if ! useq "minimal" ; then
469 exeinto /etc/init.d 679 exeinto "/etc/init.d"
470 newexe "${FILESDIR}/mysql.rc6-r3" "mysql" 680 newexe "${FILESDIR}/mysql.rc6" "mysql"
471
472 mysql_version_is_at_least "5.00.11.00" \ 681 mysql_version_is_at_least "5.00.11.00" \
473 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager" 682 && newexe "${FILESDIR}/mysqlmanager.rc6" "mysqlmanager"
683
474 insinto /etc/logrotate.d 684 insinto "/etc/logrotate.d"
475 newins "${FILESDIR}/logrotate.mysql" "mysql" 685 newins "${FILESDIR}/logrotate.mysql" "mysql"
476 686
477 #empty dirs... 687 # Empty directories ...
478 diropts "-m0750" 688 diropts "-m0750"
479 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 689 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
480 dodir "${DATADIR}" 690 dodir "${DATADIR}"
481 keepdir "${DATADIR}" 691 keepdir "${DATADIR}"
482 chown -R mysql:mysql "${D}/${DATADIR}" 692 chown -R mysql:mysql "${D}/${DATADIR}"
488 keepdir "${folder}" 698 keepdir "${folder}"
489 chown -R mysql:mysql "${D}/${folder}" 699 chown -R mysql:mysql "${D}/${folder}"
490 done 700 done
491 fi 701 fi
492 702
493 # docs 703 # Docs
494 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE 704 dodoc README COPYING ChangeLog EXCEPTIONS-CLIENT INSTALL-SOURCE
705
495 # minimal builds don't have the server 706 # Minimal builds don't have the MySQL server
496 if ! useq "minimal" ; then 707 if ! useq "minimal" ; then
497 docinto "support-files" 708 docinto "support-files"
498 for script in \ 709 for script in \
499 support-files/my-*.cnf \ 710 support-files/my-*.cnf \
500 support-files/magic \ 711 support-files/magic \
511 722
512 ROOT="${D}" mysql_lib_symlinks 723 ROOT="${D}" mysql_lib_symlinks
513} 724}
514 725
515mysql_pkg_preinst() { 726mysql_pkg_preinst() {
516
517 enewgroup mysql 60 || die "problem adding group mysql" 727 enewgroup mysql 60 || die "problem adding 'mysql' group"
518 enewuser mysql 60 -1 /dev/null mysql \ 728 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
519 || die "problem adding user mysql"
520} 729}
521 730
522mysql_pkg_postinst() { 731mysql_pkg_postinst() {
523 732 # Make sure the vars are correctly initialized
524 mysql_init_vars 733 mysql_init_vars
525 734
526 # mind at FEATURES=collision-protect before to remove this 735 # Check FEATURES="collision-protect" before removing this
527 [ -d "${ROOT}/var/log/mysql" ] \ 736 [[ -d "${ROOT}/var/log/mysql" ]] \
528 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}" 737 || install -d -m0750 -o mysql -g mysql "${ROOT}${MY_LOGDIR}"
529 738
530 #secure the logfiles... does this bother anybody? 739 # Secure the logfiles
531 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 740 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
532 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 741 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
533 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 742 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
534 743
535 if ! useq "minimal" ; then 744 if ! useq "minimal" ; then
536 # your friendly public service announcement... 745 # Your friendly public service announcement ...
537 einfo 746 einfo
538 einfo "You might want to run:" 747 elog "You might want to run:"
539 einfo "\"emerge --config =${CATEGORY}/${PF}\"" 748 elog "\"emerge --config =${CATEGORY}/${PF}\""
540 einfo "if this is a new install." 749 elog "if this is a new install."
541 einfo 750 einfo
542 mysql_version_is_at_least "5.01.00.00" \ 751 mysql_version_is_at_least "5.01.00.00" \
543 || 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."
544 fi 753 fi
754 useq "berkdb" && elog "Berkeley DB support is deprecated and will be removed in future versions!"
545} 755}
546 756
547mysql_pkg_config() { 757mysql_pkg_config() {
758 # Make sure the vars are correctly initialized
548 mysql_init_vars 759 mysql_init_vars
760
549 [[ -z "${DATADIR}" ]] && die "sorry, unable to find DATADIR" 761 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR"
550 762
551 if built_with_use dev-db/mysql minimal; then 763 if built_with_use dev-db/mysql minimal ; then
552 die "Minimal builds do NOT include the MySQL server" 764 die "Minimal builds do NOT include the MySQL server"
553 fi 765 fi
554 766
555 local pwd1="a" 767 local pwd1="a"
556 local pwd2="b" 768 local pwd2="b"
562 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."
563 die "MySQL database already exists!" 775 die "MySQL database already exists!"
564 fi 776 fi
565 777
566 einfo "Creating the mysql database and setting proper" 778 einfo "Creating the mysql database and setting proper"
567 einfo "permissions on it..." 779 einfo "permissions on it ..."
568 780
569 einfo "Insert a password for the mysql 'root' user" 781 einfo "Insert a password for the mysql 'root' user"
570 ewarn "Avoid [\"'\\_%] characters in the password" 782 ewarn "Avoid [\"'\\_%] characters in the password"
571
572 read -rsp " >" pwd1 ; echo 783 read -rsp " >" pwd1 ; echo
784
573 einfo "Check the password" 785 einfo "Retype the password"
574 read -rsp " >" pwd2 ; echo 786 read -rsp " >" pwd2 ; echo
575 787
576 if [[ "x$pwd1" != "x$pwd2" ]] ; then 788 if [[ "x$pwd1" != "x$pwd2" ]] ; then
577 die "Passwords are not the same" 789 die "Passwords are not the same"
578 fi 790 fi
579 791
580 local options="" 792 local options=""
581 local sqltmp="$(emktemp)" 793 local sqltmp="$(emktemp)"
582 794
583 local help_tables="${MY_SHAREDSTATEDIR}/fill_help_tables.sql" 795 local help_tables="${ROOT}${MY_SHAREDSTATEDIR}/fill_help_tables.sql"
584 [[ -r "${help_tables}" ]] \ 796 [[ -r "${help_tables}" ]] \
585 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \ 797 && cp "${help_tables}" "${TMPDIR}/fill_help_tables.sql" \
586 || touch "${TMPDIR}/fill_help_tables.sql" 798 || touch "${TMPDIR}/fill_help_tables.sql"
587 help_tables="${TMPDIR}/fill_help_tables.sql" 799 help_tables="${TMPDIR}/fill_help_tables.sql"
588 800
589 pushd "${TMPDIR}" &>/dev/null 801 pushd "${TMPDIR}" &>/dev/null
590 ${ROOT}/usr/bin/mysql_install_db | grep -B5 -A999 -i "ERROR" 802 "${ROOT}/usr/bin/mysql_install_db" | grep -B5 -A999 -i "ERROR"
591 popd &>/dev/null 803 popd &>/dev/null
592 [[ -f ${ROOT}/${DATADIR}/mysql/user.frm ]] \ 804 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \
593 || die "MySQL databases not installed" 805 || die "MySQL databases not installed"
594 chown -R mysql:mysql ${ROOT}/${DATADIR} 2> /dev/null 806 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null
595 chmod 0750 ${ROOT}/${DATADIR} 2> /dev/null 807 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null
596 808
597 if mysql_version_is_at_least "4.01.03.00" ; then 809 if mysql_version_is_at_least "4.01.03.00" ; then
598 options="--skip-ndbcluster" 810 options="--skip-ndbcluster"
599 811
600 # Filling timezones, see 812 # Filling timezones, see
601 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 813 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html
602 ${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
603 > "${sqltmp}" 2>/dev/null
604 815
605 if [[ -r "${help_tables}" ]] ; then 816 if [[ -r "${help_tables}" ]] ; then
606 cat "${help_tables}" >> "${sqltmp}" 817 cat "${help_tables}" >> "${sqltmp}"
607 fi 818 fi
608 fi 819 fi
609 820
610 local socket=${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock 821 local socket="${ROOT}/var/run/mysqld/mysqld${RANDOM}.sock"
611 local pidfile=${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid 822 local pidfile="${ROOT}/var/run/mysqld/mysqld${RANDOM}.pid"
612 local mysqld="${ROOT}/usr/sbin/mysqld \ 823 local mysqld="${ROOT}/usr/sbin/mysqld \
613 ${options} \ 824 ${options} \
614 --user=mysql \ 825 --user=mysql \
615 --skip-grant-tables \ 826 --skip-grant-tables \
616 --basedir=${ROOT}/usr \ 827 --basedir=${ROOT}/usr \
620 --skip-networking \ 831 --skip-networking \
621 --max_allowed_packet=8M \ 832 --max_allowed_packet=8M \
622 --net_buffer_length=16K \ 833 --net_buffer_length=16K \
623 --socket=${socket} \ 834 --socket=${socket} \
624 --pid-file=${pidfile}" 835 --pid-file=${pidfile}"
625 $mysqld & 836 ${mysqld} &
626 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do 837 while ! [[ -S "${socket}" || "${maxtry}" -lt 1 ]] ; do
627 maxtry=$(($maxtry-1)) 838 maxtry=$((${maxtry}-1))
628 echo -n "." 839 echo -n "."
629 sleep 1 840 sleep 1
630 done 841 done
631 842
632 # 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
633 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'"
634 ${ROOT}/usr/bin/mysql \ 845 "${ROOT}/usr/bin/mysql" \
635 --socket=${socket} \ 846 --socket=${socket} \
636 -hlocalhost \ 847 -hlocalhost \
637 -e "${sql}" 848 -e "${sql}"
638 849
639 einfo "Loading \"zoneinfo\" this step may require few seconds" 850 einfo "Loading \"zoneinfo\", this step may require a few seconds ..."
640 851
641 ${ROOT}/usr/bin/mysql \ 852 "${ROOT}/usr/bin/mysql" \
642 --socket=${socket} \ 853 --socket=${socket} \
643 -hlocalhost \ 854 -hlocalhost \
644 -uroot \ 855 -uroot \
645 -p"${pwd1}" \ 856 -p"${pwd1}" \
646 mysql < "${sqltmp}" 857 mysql < "${sqltmp}"
647 858
648 # server stop and cleanup 859 # Stop the server and cleanup
649 kill $(< "${pidfile}" ) 860 kill $(< "${pidfile}" )
650 rm "${sqltmp}" 861 rm -f "${sqltmp}"
651 einfo "stopping the server," 862 einfo "Stopping the server ..."
652 wait %1 863 wait %1
653 einfo "done" 864 einfo "Done"
654} 865}
655 866
656mysql_pkg_postrm() { 867mysql_pkg_postrm() {
657 mysql_lib_symlinks 868 mysql_lib_symlinks
658} 869}

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

  ViewVC Help
Powered by ViewVC 1.1.20