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

Diff of /eclass/mysql.eclass

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

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

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

  ViewVC Help
Powered by ViewVC 1.1.20