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

Diff of /eclass/mysql.eclass

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

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

Legend:
Removed from v.1.38  
changed lines
  Added in v.1.57

  ViewVC Help
Powered by ViewVC 1.1.20