/[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.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.39 2006/10/20 14:44:01 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
53MY_P="${P/_/-}" 78 if [[ ${PN} == "mysql-slotted" ]] ; then
79 DEPEND="${DEPEND} app-admin/eselect-mysql"
80 fi
54 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
55# Define correct SRC_URIs 94 # Define correct SRC_URIs
56SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${MY_P}${MYSQL_RERELEASE}.tar.gz" 95 SRC_URI="
57if [[ -n "${MYSQL_PATCHSET_REV}" ]] ; then 96 ${SERVER_URI}
58 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
59 # We add the Gentoo mirror here, as we only use primaryuri for the MySQL tarball 98 "
60 SRC_URI="${SRC_URI} http://gentoo.longitekk.com/${MYSQL_PATCHSET_FILENAME}" 99 mysql_version_is_at_least "5.1.12" \
61fi 100 && [[ -n "${PBXT_VERSION}" ]] \
101 && SRC_URI="${SRC_URI} pbxt? ( mirror://sourceforge/pbxt/pbxt-${PBXT_VERSION}.tar.gz )"
62 102
63DESCRIPTION="A fast, multi-threaded, multi-user SQL database server." 103 DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
64HOMEPAGE="http://www.mysql.com/" 104 HOMEPAGE="http://www.mysql.com/"
65SLOT="0"
66LICENSE="GPL-2" 105 LICENSE="GPL-2"
67IUSE="big-tables debug embedded minimal perl selinux srvdir ssl static" 106 IUSE="big-tables debug embedded minimal perl selinux ssl static"
68RESTRICT="confcache" 107 RESTRICT="confcache"
69 108
70mysql_version_is_at_least "4.01.00.00" \ 109 mysql_version_is_at_least "4.1" \
71&& IUSE="${IUSE} latin1" 110 && IUSE="${IUSE} latin1"
72 111
73mysql_version_is_at_least "4.01.03.00" \ 112 mysql_version_is_at_least "4.1.3" \
74&& IUSE="${IUSE} cluster extraengine" 113 && IUSE="${IUSE} cluster extraengine"
75 114
76mysql_version_is_at_least "5.00.00.00" \ 115 mysql_version_is_at_least "5.0" \
77|| IUSE="${IUSE} raid" 116 || IUSE="${IUSE} raid"
78 117
79mysql_version_is_at_least "5.00.18.00" \ 118 mysql_version_is_at_least "5.0.18" \
80&& IUSE="${IUSE} max-idx-128" 119 && IUSE="${IUSE} max-idx-128"
81 120
82mysql_version_is_at_least "5.01.00.00" \ 121 mysql_version_is_at_least "5.1" \
83&& IUSE="${IUSE} innodb" 122 && IUSE="${IUSE} innodb"
84 123
85mysql_version_is_at_least "5.01.00.00" \ 124 mysql_version_is_at_least "5.1" \
86|| IUSE="${IUSE} berkdb" 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}" ]]
87 133
88EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \ 134EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst \
89 pkg_postinst pkg_config pkg_postrm 135 pkg_postinst pkg_config pkg_postrm
90 136
91# 137#
92# HELPER FUNCTIONS: 138# HELPER FUNCTIONS:
93# 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}
94 211
95# void mysql_init_vars() 212# void mysql_init_vars()
96# 213#
97# Initialize global variables 214# Initialize global variables
98# 2005-11-19 <vivo@gentoo.org> 215# 2005-11-19 <vivo@gentoo.org>
99 216
100mysql_init_vars() { 217mysql_init_vars() {
218 if [[ ${SLOT} == "0" ]] ; then
219 MY_SUFFIX=""
220 else
221 MY_SUFFIX=${MY_SUFFIX:-"-${SLOT}"}
222 fi
101 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR="/usr/share/mysql"} 223 MY_SHAREDSTATEDIR=${MY_SHAREDSTATEDIR:-"/usr/share/mysql${MY_SUFFIX}"}
102 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql"} 224 MY_SYSCONFDIR=${MY_SYSCONFDIR="/etc/mysql${MY_SUFFIX}"}
103 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql"} 225 MY_LIBDIR=${MY_LIBDIR="/usr/$(get_libdir)/mysql${MY_SUFFIX}"}
104 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql"} 226 MY_LOCALSTATEDIR=${MY_LOCALSTATEDIR="/var/lib/mysql${MY_SUFFIX}"}
105 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql"} 227 MY_LOGDIR=${MY_LOGDIR="/var/log/mysql${MY_SUFFIX}"}
106 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql"} 228 MY_INCLUDEDIR=${MY_INCLUDEDIR="/usr/include/mysql${MY_SUFFIX}"}
107 229
108 if [[ -z "${DATADIR}" ]] ; then 230 if [[ -z "${DATADIR}" ]] ; then
109 DATADIR="" 231 DATADIR=""
110 if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then 232 if [[ -f "${MY_SYSCONFDIR}/my.cnf" ]] ; then
111 DATADIR=`"my_print_defaults" mysqld 2>/dev/null \ 233 DATADIR=`"my_print_defaults${MY_SUFFIX}" mysqld 2>/dev/null \
112 | sed -ne '/datadir/s|^--datadir=||p' \ 234 | sed -ne '/datadir/s|^--datadir=||p' \
113 | tail -n1` 235 | tail -n1`
114 if [[ -z "${DATADIR}" ]] ; then 236 if [[ -z "${DATADIR}" ]] ; then
115 if useq "srvdir" ; then
116 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
117 else
118 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \ 237 DATADIR=`grep ^datadir "${MY_SYSCONFDIR}/my.cnf" \
119 | sed -e 's/.*=\s*//'` 238 | sed -e 's/.*=\s*//'`
120 fi
121 fi 239 fi
122 fi 240 fi
123 if [[ -z "${DATADIR}" ]] ; then 241 if [[ -z "${DATADIR}" ]] ; then
124 if useq "srvdir" ; then
125 DATADIR="${ROOT}/srv/localhost/mysql/datadir"
126 else
127 DATADIR="${MY_LOCALSTATEDIR}" 242 DATADIR="${MY_LOCALSTATEDIR}"
128 fi
129 einfo "Using default DATADIR" 243 einfo "Using default DATADIR"
130 fi 244 fi
131 elog "MySQL DATADIR is ${DATADIR}" 245 elog "MySQL DATADIR is ${DATADIR}"
132 246
133 if [[ -z "${PREVIOUS_DATADIR}" ]] ; then 247 if [[ -z "${PREVIOUS_DATADIR}" ]] ; then
140 fi 254 fi
141 export PREVIOUS_DATADIR 255 export PREVIOUS_DATADIR
142 fi 256 fi
143 fi 257 fi
144 258
259 MY_SOURCEDIR=${SERVER_URI##*/}
260 MY_SOURCEDIR=${MY_SOURCEDIR%.tar*}
261
145 export MY_SHAREDSTATEDIR MY_SYSCONFDIR 262 export MY_SUFFIX MY_SHAREDSTATEDIR MY_SYSCONFDIR
146 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR 263 export MY_LIBDIR MY_LOCALSTATEDIR MY_LOGDIR
147 export MY_INCLUDEDIR 264 export MY_INCLUDEDIR DATADIR MY_SOURCEDIR
148 export DATADIR
149} 265}
150 266
151configure_minimal() { 267configure_minimal() {
152 # These are things we exclude from a minimal build, please 268 # These are things we exclude from a minimal build, please
153 # note that the server actually does get built and installed, 269 # note that the server actually does get built and installed,
154 # but we then delete it before packaging. 270 # but we then delete it before packaging.
155 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"
156 272
157 for i in ${minimal_exclude_list} ; do 273 for i in ${minimal_exclude_list} ; do
158 myconf="${myconf} --without-${i}" 274 myconf="${myconf} --without-${i}"
159 done 275 done
160 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
161} 293}
162 294
163configure_common() { 295configure_common() {
164 myconf="${myconf} $(use_with big-tables)" 296 myconf="${myconf} $(use_with big-tables)"
165 myconf="${myconf} --enable-local-infile" 297 myconf="${myconf} --enable-local-infile"
166 myconf="${myconf} --with-extra-charsets=all" 298 myconf="${myconf} --with-extra-charsets=all"
167 myconf="${myconf} --with-mysqld-user=mysql" 299 myconf="${myconf} --with-mysqld-user=mysql"
168 myconf="${myconf} --with-server" 300 myconf="${myconf} --with-server"
169 myconf="${myconf} --with-unix-socket-path='/var/run/mysqld/mysqld.sock'" 301 myconf="${myconf} --with-unix-socket-path=/var/run/mysqld/mysqld.sock"
170 myconf="${myconf} --without-libwrap" 302 myconf="${myconf} --without-libwrap"
171 303
172 if useq "static" ; then 304 if useq "static" ; then
173 myconf="${myconf} --with-mysqld-ldflags=-all-static" 305 myconf="${myconf} --with-mysqld-ldflags=-all-static"
174 myconf="${myconf} --with-client-ldflags=-all-static" 306 myconf="${myconf} --with-client-ldflags=-all-static"
179 311
180 if useq "debug" ; then 312 if useq "debug" ; then
181 myconf="${myconf} --with-debug=full" 313 myconf="${myconf} --with-debug=full"
182 else 314 else
183 myconf="${myconf} --without-debug" 315 myconf="${myconf} --without-debug"
184 mysql_version_is_at_least "4.01.03.00" \ 316 mysql_version_is_at_least "4.1.3" \
185 && useq "cluster" \ 317 && useq "cluster" \
186 && myconf="${myconf} --without-ndb-debug" 318 && myconf="${myconf} --without-ndb-debug"
187 fi 319 fi
188 320
189 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
190 myconf="${myconf} --with-charset=utf8" 322 myconf="${myconf} --with-charset=utf8"
191 myconf="${myconf} --with-collation=utf8_general_ci" 323 myconf="${myconf} --with-collation=utf8_general_ci"
192 else 324 else
193 myconf="${myconf} --with-charset=latin1" 325 myconf="${myconf} --with-charset=latin1"
194 myconf="${myconf} --with-collation=latin1_swedish_ci" 326 myconf="${myconf} --with-collation=latin1_swedish_ci"
208 myconf="${myconf} $(use_with perl bench)" 340 myconf="${myconf} $(use_with perl bench)"
209 myconf="${myconf} --enable-assembler" 341 myconf="${myconf} --enable-assembler"
210 myconf="${myconf} --with-extra-tools" 342 myconf="${myconf} --with-extra-tools"
211 myconf="${myconf} --with-innodb" 343 myconf="${myconf} --with-innodb"
212 myconf="${myconf} --without-readline" 344 myconf="${myconf} --without-readline"
213 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)"
214 346
215 if useq "ssl" ; then 347 if useq "ssl" ; then
216 # --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
217 # has been removed from configure 349 # has been removed from configure
218 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"
219 if mysql_version_is_at_least "5.00.06.00" ; then 351 if mysql_version_is_at_least "5.0.6" ; then
220 # myconf="${myconf} --with-yassl" 352 # myconf="${myconf} --with-yassl"
221 myconf="${myconf} --with-openssl" 353 myconf="${myconf} --with-openssl"
222 else 354 else
223 myconf="${myconf} --with-openssl" 355 myconf="${myconf} --with-openssl"
224 fi 356 fi
238 else 370 else
239 myconf="${myconf} --without-berkeley-db" 371 myconf="${myconf} --without-berkeley-db"
240 fi 372 fi
241 fi 373 fi
242 374
243 if mysql_version_is_at_least "4.01.03.00" ; then 375 if mysql_version_is_at_least "4.1.3" ; then
244 myconf="${myconf} --with-geometry" 376 myconf="${myconf} --with-geometry"
245 myconf="${myconf} $(use_with cluster ndbcluster)" 377 myconf="${myconf} $(use_with cluster ndbcluster)"
246 fi 378 fi
247 379
248 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
249 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html 381 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
250 myconf="${myconf} --with-archive-storage-engine" 382 myconf="${myconf} --with-archive-storage-engine"
251 383
252 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html 384 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
253 myconf="${myconf} --with-csv-storage-engine" 385 myconf="${myconf} --with-csv-storage-engine"
256 myconf="${myconf} --with-blackhole-storage-engine" 388 myconf="${myconf} --with-blackhole-storage-engine"
257 389
258 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html 390 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
259 # http://dev.mysql.com/doc/mysql/en/federated-description.html 391 # http://dev.mysql.com/doc/mysql/en/federated-description.html
260 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html 392 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
261 if mysql_version_is_at_least "5.00.03.00" ; then 393 if mysql_version_is_at_least "5.0.3" ; then
262 elog "Before using the Federated storage engine, please be sure to read" 394 elog "Before using the Federated storage engine, please be sure to read"
263 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html" 395 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
264 myconf="${myconf} --with-federated-storage-engine" 396 myconf="${myconf} --with-federated-storage-engine"
265 fi 397 fi
266 fi 398 fi
267 399
268 mysql_version_is_at_least "5.00.18.00" \ 400 mysql_version_is_at_least "5.0.18" \
269 && useq "max-idx-128" \ 401 && useq "max-idx-128" \
270 && myconf="${myconf} --with-max-indexes=128" 402 && myconf="${myconf} --with-max-indexes=128"
271} 403}
272 404
273configure_51() { 405configure_51() {
274 # TODO : !!!!! readd --withouth-readline 406 # TODO: !!!! readd --without-readline
275 # the failure depend upon config/ac-macros/readline.m4 checking into 407 # the failure depend upon config/ac-macros/readline.m4 checking into
276 # readline.h instead of history.h 408 # readline.h instead of history.h
277 myconf="${myconf} $(use_with ssl)" 409 myconf="${myconf} $(use_with ssl)"
278 myconf="${myconf} --enable-assembler" 410 myconf="${myconf} --enable-assembler"
279 myconf="${myconf} --with-geometry" 411 myconf="${myconf} --with-geometry"
286 # 5.1 introduces a new way to manage storage engines (plugins) 418 # 5.1 introduces a new way to manage storage engines (plugins)
287 # like configuration=none 419 # like configuration=none
288 local plugins="csv,myisam,myisammrg,heap" 420 local plugins="csv,myisam,myisammrg,heap"
289 if useq "extraengine" ; then 421 if useq "extraengine" ; then
290 # 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
291 plugins="${plugins},blackhole,federated,ftexample,partition" 423 plugins="${plugins},archive,blackhole,example,federated,partition"
292 424
293 elog "Before using the Federated storage engine, please be sure to read" 425 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" 426 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
295 fi 427 fi
296 428
305 fi 437 fi
306 438
307 myconf="${myconf} --with-plugins=${plugins}" 439 myconf="${myconf} --with-plugins=${plugins}"
308} 440}
309 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
310# 470#
311# EBUILD FUNCTIONS 471# EBUILD FUNCTIONS
312# 472#
313 473
314mysql_pkg_setup() { 474mysql_pkg_setup() {
315 enewgroup mysql 60 || die "problem adding 'mysql' group" 475 enewgroup mysql 60 || die "problem adding 'mysql' group"
316 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"
317
318 if mysql_version_is_at_least "5.01.12.00" && useq "innodb" ; then
319 eerror "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
320 die "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
321 fi
322 477
323 # Check for USE flag problems in pkg_setup 478 # Check for USE flag problems in pkg_setup
324 if useq "static" && useq "ssl" ; then 479 if useq "static" && useq "ssl" ; then
325 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!"
326 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!"
327 fi 482 fi
328 483
329 if ! mysql_version_is_at_least "5.00.00.00" \ 484 if ! mysql_version_is_at_least "5.0" \
330 && useq "raid" \ 485 && useq "raid" \
331 && useq "static" ; then 486 && useq "static" ; then
332 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"
333 eerror "with RAID support enabled." 488 eerror "with RAID support enabled."
334 die "USE flags 'raid' and 'static' conflict!" 489 die "USE flags 'raid' and 'static' conflict!"
335 fi 490 fi
336 491
337 if mysql_version_is_at_least "4.01.03.00" \ 492 if mysql_version_is_at_least "4.1.3" \
338 && ( useq "cluster" || useq "extraengine" ) \ 493 && ( useq "cluster" || useq "extraengine" ) \
339 && useq "minimal" ; then 494 && useq "minimal" ; then
340 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!" 495 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
341 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!" 496 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
342 fi 497 fi
343 498
499 mysql_check_version_range "4.0 to 5.0.99.99" \
500 && useq "berkdb" \
344 useq "berkdb" && elog "Berkeley 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!"
345} 502}
346 503
347mysql_src_unpack() { 504mysql_src_unpack() {
348 # Initialize the proper variables first 505 # Initialize the proper variables first
349 mysql_init_vars 506 mysql_init_vars
350 507
351 unpack ${A} 508 unpack ${A}
352 509 if [[ ${IS_BITKEEPER} -eq 90 ]] ; then
353 mv -f "${WORKDIR}/${MY_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
354 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
355 524
356 # Apply the patches for this MySQL version 525 # Apply the patches for this MySQL version
357 if [[ -d "${WORKDIR}/${MY_FIXED_PV}" ]] ; then 526 EPATCH_SUFFIX="patch"
358 EPATCH_SOURCE="${WORKDIR}/${MY_FIXED_PV}" EPATCH_SUFFIX="patch" epatch 527 mkdir -p "${EPATCH_SOURCE}" || die "unable to create epatch directory"
359 fi 528 mysql_mv_patches
529 epatch || die "failed to apply all patches"
360 530
361 # Additional checks, remove bundled zlib 531 # Additional checks, remove bundled zlib
362 rm -f "${S}/zlib/"*.[ch] 532 rm -f "${S}/zlib/"*.[ch]
363 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"
364 rm -f "scripts/mysqlbug" 534 rm -f "scripts/mysqlbug"
365 535
366 # Make charsets install in the right place 536 # Make charsets install in the right place
367 find . -name 'Makefile.am' \ 537 find . -name 'Makefile.am' \
368 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \; 538 -exec sed --in-place -e 's!$(pkgdatadir)!'${MY_SHAREDSTATEDIR}'!g' {} \;
369 539
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 540 if mysql_version_is_at_least "4.1" ; then
377 # 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
378 find . -name Makefile \ 542 find . -name Makefile \
379 -o -name Makefile.in \ 543 -o -name Makefile.in \
380 -o -name configure \ 544 -o -name configure \
381 -exec rm -f {} \; 545 -exec rm -f {} \;
382 rm -f "ltmain.sh" 546 rm -f "ltmain.sh"
383 rm -f "scripts/mysqlbug" 547 rm -f "scripts/mysqlbug"
384 fi 548 fi
385 549
386 local rebuilddirlist bdbdir d 550 local rebuilddirlist d
387 551
388 if mysql_version_is_at_least "5.01.00.00" ; then 552 if mysql_version_is_at_least "5.1.12" ; then
389 rebuilddirlist=". storage/innobase" 553 rebuilddirlist="."
390 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"
391 else 560 else
392 rebuilddirlist=". innobase" 561 rebuilddirlist=". innobase"
393 bdbdir='bdb/dist'
394 fi 562 fi
395 563
396 for d in ${rebuilddirlist} ; do 564 for d in ${rebuilddirlist} ; do
397 einfo "Reconfiguring dir '${d}'" 565 einfo "Reconfiguring dir '${d}'"
398 pushd "${d}" &>/dev/null 566 pushd "${d}" &>/dev/null
399 AT_GNUCONF_UPDATE="yes" eautoreconf 567 AT_GNUCONF_UPDATE="yes" eautoreconf
400 popd &>/dev/null 568 popd &>/dev/null
401 done 569 done
402 570
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 571 if mysql_check_version_range "4.1 to 5.0.99.99" \
572 && useq "berkdb" ; then
406 [[ -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"
407 pushd "${bdbdir}" \ 574 pushd "bdb/dist" \
408 && sh s_all \ 575 && sh s_all \
409 || die "Failed bdb reconfigure" \ 576 || die "Failed bdb reconfigure" \
410 &>/dev/null 577 &>/dev/null
411 popd &>/dev/null 578 popd &>/dev/null
412 fi 579 fi
414 581
415mysql_src_compile() { 582mysql_src_compile() {
416 # Make sure the vars are correctly initialized 583 # Make sure the vars are correctly initialized
417 mysql_init_vars 584 mysql_init_vars
418 585
586 # $myconf is modified by the configure_* functions
419 local myconf 587 local myconf=""
420 588
421 if useq "static" ; then
422 myconf="${myconf} --with-mysqld-ldflags=-all-static"
423 myconf="${myconf} --with-client-ldflags=-all-static"
424 myconf="${myconf} --disable-shared"
425 else
426 myconf="${myconf} --enable-shared --enable-static"
427 fi
428
429 myconf="${myconf} --without-libwrap"
430
431 if useq "ssl" ; then 589 if useq "minimal" ; then
432 # --with-vio is not needed anymore, it's on by default and 590 configure_minimal
433 # has been removed from configure 591 else
434 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio" 592 configure_common
435 if mysql_version_is_at_least "5.00.06.00" ; then 593 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 594 configure_51
437 # myconf="${myconf} --with-yassl"
438 myconf="${myconf} --with-openssl"
439 else 595 else
440 myconf="${myconf} --with-openssl" 596 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 597 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 598 fi
587 599
588 # Bug #114895, bug #110149 600 # Bug #114895, bug #110149
589 filter-flags "-O" "-O[01]" 601 filter-flags "-O" "-O[01]"
590 602
591 # glib-2.3.2_pre fix, bug #16496 603 # glib-2.3.2_pre fix, bug #16496
592 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 604 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
593 605
594 append-flags "-fno-exceptions -fno-strict-aliasing" 606 CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-strict-aliasing"
595 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti" 607 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
596 mysql_version_is_at_least "5.00.00.00" \ 608 mysql_version_is_at_least "5.0" \
597 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 609 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
598 export CXXFLAGS 610 export CXXFLAGS
599 611
600 econf \ 612 econf \
613 --program-suffix="${MY_SUFFIX}" \
601 --libexecdir="/usr/sbin" \ 614 --libexecdir="/usr/sbin" \
602 --sysconfdir="${MY_SYSCONFDIR}" \ 615 --sysconfdir="${MY_SYSCONFDIR}" \
603 --localstatedir="${MY_LOCALSTATEDIR}" \ 616 --localstatedir="${MY_LOCALSTATEDIR}" \
604 --sharedstatedir="${MY_SHAREDSTATEDIR}" \ 617 --sharedstatedir="${MY_SHAREDSTATEDIR}" \
605 --libdir="${MY_LIBDIR}" \ 618 --libdir="${MY_LIBDIR}" \
606 --includedir="${MY_INCLUDEDIR}" \ 619 --includedir="${MY_INCLUDEDIR}" \
607 --with-low-memory \ 620 --with-low-memory \
608 --enable-local-infile \
609 --with-mysqld-user=mysql \
610 --with-client-ldflags=-lstdc++ \ 621 --with-client-ldflags=-lstdc++ \
611 --enable-thread-safe-client \ 622 --enable-thread-safe-client \
612 --with-comment="Gentoo Linux ${PF}" \ 623 --with-comment="Gentoo Linux ${PF}" \
613 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
614 --without-readline \
615 --without-docs \ 624 --without-docs \
616 ${myconf} || die "econf failed" 625 ${myconf} || die "econf failed"
617 626
618 # TODO: Move this before autoreconf !!! 627 # TODO: Move this before autoreconf !!!
619 find . -type f -name Makefile -print0 \ 628 find . -type f -name Makefile -print0 \
620 | xargs -0 -n100 sed -i \ 629 | xargs -0 -n100 sed -i \
621 -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)|'
622 631
623 emake || die "emake failed" 632 emake || die "emake failed"
633
634 mysql_version_is_at_least "5.1.1" && useq "pbxt" && pbxt_src_compile
624} 635}
625 636
626mysql_src_install() { 637mysql_src_install() {
627 # Make sure the vars are correctly initialized 638 # Make sure the vars are correctly initialized
628 mysql_init_vars 639 mysql_init_vars
629 640
630 emake install DESTDIR="${D}" benchdir_root="${MY_SHAREDSTATEDIR}" || die "emake install failed" 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
631 644
632 insinto "${MY_INCLUDEDIR}" 645 insinto "${MY_INCLUDEDIR}"
633 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h 646 doins "${MY_INCLUDEDIR}"/my_{config,dir}.h
634 647
635 # Convenience links 648 # Convenience links
636 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlanalyze" 649 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlanalyze${MY_SUFFIX}"
637 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqlrepair" 650 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqlrepair${MY_SUFFIX}"
638 dosym "/usr/bin/mysqlcheck" "/usr/bin/mysqloptimize" 651 dosym "/usr/bin/mysqlcheck${MY_SUFFIX}" "/usr/bin/mysqloptimize${MY_SUFFIX}"
639 652
640 # Various junk (my-*.cnf moved elsewhere) 653 # Various junk (my-*.cnf moved elsewhere)
641 rm -Rf "${D}/usr/share/info" 654 rm -Rf "${D}/usr/share/info"
642 for removeme in "mysql-log-rotate" mysql.server* \ 655 for removeme in "mysql-log-rotate" mysql.server* \
643 binary-configure* my-*.cnf mi_test_all* 656 binary-configure* my-*.cnf mi_test_all*
644 do 657 do
645 rm -f "${D}"/usr/share/mysql/${removeme} 658 rm -f "${D}"/usr/share/mysql/${removeme}
646 done 659 done
647 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
648 # Clean up stuff for a minimal build 670 # clean up stuff for a minimal build
649 if useq "minimal" ; then 671 if useq "minimal" ; then
650 rm -Rf "${D}${MY_SHAREDSTATEDIR}"/{mysql-test,sql-bench} 672 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} 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}
652 rm -f "${D}/usr/sbin/mysqld" 674 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 675 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
654 fi 676 fi
655 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
656 # Configuration stuff 688 # Configuration stuff
657 if mysql_version_is_at_least "4.01.00.00" ; then 689 if mysql_version_is_at_least "4.1" ; then
658 mysql_mycnf_version="4.1" 690 mysql_mycnf_version="4.1"
659 else 691 else
660 mysql_mycnf_version="4.0" 692 mysql_mycnf_version="4.0"
661 fi 693 fi
662 insinto "${MY_SYSCONFDIR}" 694 insinto "${MY_SYSCONFDIR}"
663 doins "scripts/mysqlaccess.conf" 695 doins scripts/mysqlaccess.conf
696 sed -e "s!@MY_SUFFIX@!${MY_SUFFIX}!g" \
664 sed -e "s!@DATADIR@!${DATADIR}!g" \ 697 -e "s!@DATADIR@!${DATADIR}!g" \
665 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \ 698 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
666 > "${TMPDIR}/my.cnf.ok" 699 > "${TMPDIR}/my.cnf.ok"
667 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
668 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok" 701 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok"
669 fi 702 fi
670 newins "${TMPDIR}/my.cnf.ok" my.cnf 703 newins "${TMPDIR}/my.cnf.ok" my.cnf
671
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 704
677 # Minimal builds don't have the MySQL server 705 # Minimal builds don't have the MySQL server
678 if ! useq "minimal" ; then 706 if ! useq "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 ... 707 # Empty directories ...
688 diropts "-m0750" 708 diropts "-m0750"
689 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then 709 if [[ "${PREVIOUS_DATADIR}" != "yes" ]] ; then
690 dodir "${DATADIR}" 710 dodir "${DATADIR}"
691 keepdir "${DATADIR}" 711 keepdir "${DATADIR}"
718 for script in scripts/mysql* ; do 738 for script in scripts/mysql* ; do
719 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}" 739 [[ "${script%.sh}" == "${script}" ]] && dodoc "${script}"
720 done 740 done
721 fi 741 fi
722 742
723 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
724} 763}
725 764
726mysql_pkg_preinst() { 765mysql_pkg_preinst() {
727 enewgroup mysql 60 || die "problem adding 'mysql' group" 766 enewgroup mysql 60 || die "problem adding 'mysql' group"
728 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"
739 # Secure the logfiles 778 # Secure the logfiles
740 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err} 779 touch "${ROOT}${MY_LOGDIR}"/mysql.{log,err}
741 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql* 780 chown mysql:mysql "${ROOT}${MY_LOGDIR}"/mysql*
742 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql* 781 chmod 0660 "${ROOT}${MY_LOGDIR}"/mysql*
743 782
783 # Minimal builds don't have the MySQL server
744 if ! useq "minimal" ; then 784 if ! useq "minimal" ; then
745 # Your friendly public service announcement ... 785 docinto "support-files"
746 einfo 786 for script in \
747 elog "You might want to run:" 787 support-files/my-*.cnf \
748 elog "\"emerge --config =${CATEGORY}/${PF}\"" 788 support-files/magic \
749 elog "if this is a new install." 789 support-files/ndb-config-2-node.ini
750 einfo 790 do
751 mysql_version_is_at_least "5.01.00.00" \ 791 dodoc "${script}"
752 || elog "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
753 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" \
754 useq "berkdb" && elog "Berkeley 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!"
755} 818}
756 819
757mysql_pkg_config() { 820mysql_pkg_config() {
758 # Make sure the vars are correctly initialized 821 # Make sure the vars are correctly initialized
759 mysql_init_vars 822 mysql_init_vars
760 823
761 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR" 824 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR"
762 825
763 if built_with_use dev-db/mysql minimal ; then 826 if built_with_use ${CATEGORY}/${PN} minimal ; then
764 die "Minimal builds do NOT include the MySQL server" 827 die "Minimal builds do NOT include the MySQL server"
765 fi 828 fi
766 829
767 local pwd1="a" 830 local pwd1="a"
768 local pwd2="b" 831 local pwd2="b"
804 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \ 867 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \
805 || die "MySQL databases not installed" 868 || die "MySQL databases not installed"
806 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null 869 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null
807 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null 870 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null
808 871
809 if mysql_version_is_at_least "4.01.03.00" ; then 872 if mysql_version_is_at_least "4.1.3" ; then
810 options="--skip-ndbcluster" 873 options="--skip-ndbcluster"
811 874
812 # Filling timezones, see 875 # Filling timezones, see
813 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 876 # 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 877 "${ROOT}/usr/bin/mysql_tzinfo_to_sql" "${ROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
863 wait %1 926 wait %1
864 einfo "Done" 927 einfo "Done"
865} 928}
866 929
867mysql_pkg_postrm() { 930mysql_pkg_postrm() {
931 if [[ ${PN} == "mysql-slotted" ]] ; then
868 mysql_lib_symlinks 932 mysql_lib_symlinks
933 fi
869} 934}

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

  ViewVC Help
Powered by ViewVC 1.1.20