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

Diff of /eclass/mysql.eclass

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

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

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

  ViewVC Help
Powered by ViewVC 1.1.20