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

Diff of /eclass/mysql.eclass

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

Revision 1.40 Revision 1.51
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.40 2006/10/20 15:22:24 chtekk Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/mysql.eclass,v 1.51 2006/12/29 20:34:02 vivo Exp $
4 4
5# Author: Francesco Riosa <vivo@gentoo.org> 5# Author: Francesco Riosa <vivo@gentoo.org>
6# Maintainer: Luca Longinotti <chtekk@gentoo.org> 6# Maintainer: Luca Longinotti <chtekk@gentoo.org>
7 7
8# Both MYSQL_VERSION_ID and MYSQL_PATCHSET_REV must be set in the ebuild too 8# Both MYSQL_VERSION_ID and MYSQL_PATCHSET_REV must be set in the ebuild too
23 done 23 done
24 # strip leading "0" (otherwise it's considered an octal number by BASH) 24 # strip leading "0" (otherwise it's considered an octal number by BASH)
25 MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"} 25 MYSQL_VERSION_ID=${MYSQL_VERSION_ID##"0"}
26fi 26fi
27 27
28DEPEND="${DEPEND} 28inherit eutils flag-o-matic gnuconfig autotools mysql_fx
29
30# Be warned, *DEPEND are version-dependant
31DEPEND="ssl? ( >=dev-libs/openssl-0.9.6d )
32 userland_GNU? ( sys-process/procps )
33 >=sys-apps/sed-4
34 >=sys-apps/texinfo-4.7-r1
29 >=sys-libs/readline-4.1 35 >=sys-libs/readline-4.1
30 berkdb? ( sys-apps/ed )
31 ssl? ( >=dev-libs/openssl-0.9.6d )
32 userland_GNU? ( sys-process/procps )
33 >=sys-libs/zlib-1.2.3 36 >=sys-libs/zlib-1.2.3"
34 >=sys-apps/texinfo-4.7-r1 37
35 >=sys-apps/sed-4" 38# LEAVE THE SURROUNDING SPACES THERE
39MYSQL_MUTUALLY_EXCLUSIVE=" !dev-db/mysql !dev-db/mysql-community "
40DEPEND="${DEPEND} ${MYSQL_MUTUALLY_EXCLUSIVE/ !${CATEGORY}\/${PN} /}"
41
42mysql_version_is_at_least "5.01.00.00" \
43|| DEPEND="${DEPEND} berkdb? ( sys-apps/ed )"
36 44
37RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )" 45RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )"
38 46
39# dev-perl/DBD-mysql is needed by some scripts installed by MySQL 47# dev-perl/DBD-mysql is needed by some scripts installed by MySQL
40PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )" 48PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )"
41 49
42inherit eutils flag-o-matic gnuconfig autotools mysql_fx
43
44# Shorten the path because the socket path length must be shorter than 107 chars 50# 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 51# and we will run a mysql server during test phase
46S="${WORKDIR}/${PN}" 52S="${WORKDIR}/mysql" # BitKeeper ebuilds
47 53
48# Define $MY_FIXED_PV for MySQL patchsets 54# Define $MY_FIXED_PV for MySQL patchsets
49MY_FIXED_PV="${PV/_alpha/}" 55MY_FIXED_PV="${PV/_alpha/}"
50#MY_FIXED_PV="${MY_FIXED_PV/_beta/}" 56#MY_FIXED_PV="${MY_FIXED_PV/_beta/}"
51#MY_FIXED_PV="${MY_FIXED_PV/_rc/}" 57#MY_FIXED_PV="${MY_FIXED_PV/_rc/}"
52 58
53MY_P="${P/_/-}" 59MY_P="${P/_/-}"
60MY_P="${MY_P/-alpha/-bk-}" # BitKeeper ebuilds
61MY_P="${MY_P/-community/}"
54 62
55# Define correct SRC_URIs 63# Define correct SRC_URIs
56SRC_URI="mirror://mysql/Downloads/MySQL-${PV%.*}/${MY_P}${MYSQL_RERELEASE}.tar.gz" 64SRC_URI="${BASE_URI}/${MY_P}${MYSQL_RERELEASE}.tar.gz"
57if [[ -n "${MYSQL_PATCHSET_REV}" ]] ; then 65if [[ -n "${MYSQL_PATCHSET_REV}" ]] ; then
58 MYSQL_PATCHSET_FILENAME="${PN}-patchset-${MY_FIXED_PV}-r${MYSQL_PATCHSET_REV}.tar.bz2" 66 MYSQL_PATCHSET_FILENAME="${PN}-patchset-${MY_FIXED_PV}-r${MYSQL_PATCHSET_REV}.tar.bz2"
59 # We add the Gentoo mirror here, as we only use primaryuri for the MySQL tarball 67 # We add the Gentoo mirror here, as we only use primaryuri for the MySQL tarball
60 SRC_URI="${SRC_URI} http://gentoo.longitekk.com/${MYSQL_PATCHSET_FILENAME}" 68 SRC_URI="${SRC_URI} http://g3nt8.org/patches/${MYSQL_PATCHSET_FILENAME}"
61fi 69fi
62 70
63DESCRIPTION="A fast, multi-threaded, multi-user SQL database server." 71DESCRIPTION="A fast, multi-threaded, multi-user SQL database server."
64HOMEPAGE="http://www.mysql.com/" 72HOMEPAGE="http://www.mysql.com/"
65SLOT="0" 73SLOT="0"
89 pkg_postinst pkg_config pkg_postrm 97 pkg_postinst pkg_config pkg_postrm
90 98
91# 99#
92# HELPER FUNCTIONS: 100# HELPER FUNCTIONS:
93# 101#
102
103bitkeeper_fetch() {
104
105 local tpv=( ${PV//[-._]/ } )
106 local reposuf="${tpv[0]}.${tpv[1]}"
107 useq "cluster" && reposuf="${reposuf}-ndb"
108 local repo_uri="bk://mysql.bkbits.net/mysql-${reposuf}"
109 ## -- ebk_store_dir: bitkeeper sources store directory
110 local ebk_store_dir="${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}/bk-src"
111 ## -- ebk_fetch_cmd: bitkeeper fetch command
112 # always fetch the latest revision, use -r<revision> if a specified revision is wanted
113 # hint: does not work
114 local ebk_fetch_cmd="sfioball"
115 ## -- ebk_update_cmd: bitkeeper update command
116 local ebk_update_cmd="update"
117
118 #addread "/etc/bitkeeper"
119 addwrite "${ebk_store_dir}"
120
121 if [[ ! -d "${ebk_store_dir}" ]]; then
122 debug-print "${FUNCNAME}: initial checkout. creating bitkeeper directory"
123 mkdir -p "${ebk_store_dir}" || die "${EBK}: can't mkdir ${ebk_store_dir}."
124 fi
125
126 pushd "${ebk_store_dir}" || die "${EBK}: can't chdir to ${ebk_store_dir}"
127
128 local wc_path=mysql-${reposuf}
129
130 if [[ ! -d "${wc_path}" ]]; then
131 local options="-r+"
132 # first check out
133 einfo "bitkeeper check out start -->"
134 einfo " repository: ${repo_uri}"
135 ${ebk_fetch_cmd} ${options} "${repo_uri}" ${wc_path} \
136 || die "${EBK}: can't fetch from ${repo_uri}."
137 else
138 if [[ ! -d "${wc_path}/BK" ]]; then
139 popd
140 die "Look like ${wc_path} is not a bitkeeper path."
141 fi
142
143 # update working copy
144 einfo "bitkeeper update start -->"
145 einfo " repository: ${repo_uri}"
146
147 ${ebk_update_cmd} "${repo_uri}" "${wc_path}" \
148 || die "BK: can't update from ${repo_uri} to ${wc_path}."
149
150 fi
151
152 einfo " working copy: ${wc_path}"
153 cd "${wc_path}"
154 rsync -rlpgo --exclude="BK/" . "${S}" || die "BK: can't export to ${S}."
155
156 echo
157 popd
158
159}
160
161mysql_disable_test() {
162 local testname="${1}" ; shift
163 local reason="${@}"
164 local mysql_disable_file="${S}/mysql-test/t/disabled.def"
165 echo ${testname} : ${reason} >> "${mysql_disable_file}"
166 ewarn "test \"${testname}\" disabled because: \"${reason}\""
167}
94 168
95# void mysql_init_vars() 169# void mysql_init_vars()
96# 170#
97# Initialize global variables 171# Initialize global variables
98# 2005-11-19 <vivo@gentoo.org> 172# 2005-11-19 <vivo@gentoo.org>
147 export MY_INCLUDEDIR 221 export MY_INCLUDEDIR
148 export DATADIR 222 export DATADIR
149} 223}
150 224
151configure_minimal() { 225configure_minimal() {
152 # These are things we exclude from a minimal build, please 226 # These are things we exclude from a minimal build, please
153 # note that the server actually does get built and installed, 227 # note that the server actually does get built and installed,
154 # but we then delete it before packaging. 228 # but we then delete it before packaging.
155 local minimal_exclude_list="server embedded-server extra-tools innodb bench berkeley-db row-based-replication" 229 local minimal_exclude_list="server embedded-server extra-tools innodb bench berkeley-db row-based-replication"
156 230
157 for i in ${minimal_exclude_list} ; do 231 for i in ${minimal_exclude_list} ; do
158 myconf="${myconf} --without-${i}" 232 myconf="${myconf} --without-${i}"
159 done 233 done
160 myconf="${myconf} --with-extra-charsets=none" 234 myconf="${myconf} --with-extra-charsets=none"
235 myconf="${myconf} --enable-local-infile"
236
237 if useq "static" ; then
238 myconf="${myconf} --with-client-ldflags=-all-static"
239 myconf="${myconf} --disable-shared"
240 else
241 myconf="${myconf} --enable-shared --enable-static"
242 fi
243
244 if mysql_version_is_at_least "4.01.00.00" && ! useq "latin1" ; then
245 myconf="${myconf} --with-charset=utf8"
246 myconf="${myconf} --with-collation=utf8_general_ci"
247 else
248 myconf="${myconf} --with-charset=latin1"
249 myconf="${myconf} --with-collation=latin1_swedish_ci"
250 fi
161} 251}
162 252
163configure_common() { 253configure_common() {
164 myconf="${myconf} $(use_with big-tables)" 254 myconf="${myconf} $(use_with big-tables)"
165 myconf="${myconf} --enable-local-infile" 255 myconf="${myconf} --enable-local-infile"
166 myconf="${myconf} --with-extra-charsets=all" 256 myconf="${myconf} --with-extra-charsets=all"
167 myconf="${myconf} --with-mysqld-user=mysql" 257 myconf="${myconf} --with-mysqld-user=mysql"
168 myconf="${myconf} --with-server" 258 myconf="${myconf} --with-server"
169 myconf="${myconf} --with-unix-socket-path='/var/run/mysqld/mysqld.sock'" 259 myconf="${myconf} --with-unix-socket-path=/var/run/mysqld/mysqld.sock"
170 myconf="${myconf} --without-libwrap" 260 myconf="${myconf} --without-libwrap"
171 261
172 if useq "static" ; then 262 if useq "static" ; then
173 myconf="${myconf} --with-mysqld-ldflags=-all-static" 263 myconf="${myconf} --with-mysqld-ldflags=-all-static"
174 myconf="${myconf} --with-client-ldflags=-all-static" 264 myconf="${myconf} --with-client-ldflags=-all-static"
179 269
180 if useq "debug" ; then 270 if useq "debug" ; then
181 myconf="${myconf} --with-debug=full" 271 myconf="${myconf} --with-debug=full"
182 else 272 else
183 myconf="${myconf} --without-debug" 273 myconf="${myconf} --without-debug"
184 mysql_version_is_at_least "4.01.03.00" \ 274 mysql_version_is_at_least "4.1.3" \
185 && useq "cluster" \ 275 && useq "cluster" \
186 && myconf="${myconf} --without-ndb-debug" 276 && myconf="${myconf} --without-ndb-debug"
187 fi 277 fi
188 278
189 if mysql_version_is_at_least "4.01.00.00" && ! useq "latin1" ; then 279 if mysql_version_is_at_least "4.1" && ! useq "latin1" ; then
190 myconf="${myconf} --with-charset=utf8" 280 myconf="${myconf} --with-charset=utf8"
191 myconf="${myconf} --with-collation=utf8_general_ci" 281 myconf="${myconf} --with-collation=utf8_general_ci"
192 else 282 else
193 myconf="${myconf} --with-charset=latin1" 283 myconf="${myconf} --with-charset=latin1"
194 myconf="${myconf} --with-collation=latin1_swedish_ci" 284 myconf="${myconf} --with-collation=latin1_swedish_ci"
208 myconf="${myconf} $(use_with perl bench)" 298 myconf="${myconf} $(use_with perl bench)"
209 myconf="${myconf} --enable-assembler" 299 myconf="${myconf} --enable-assembler"
210 myconf="${myconf} --with-extra-tools" 300 myconf="${myconf} --with-extra-tools"
211 myconf="${myconf} --with-innodb" 301 myconf="${myconf} --with-innodb"
212 myconf="${myconf} --without-readline" 302 myconf="${myconf} --without-readline"
213 mysql_version_is_at_least "5.00.00.00" || myconf="${myconf} $(use_with raid)" 303 mysql_version_is_at_least "5.0" || myconf="${myconf} $(use_with raid)"
214 304
215 if useq "ssl" ; then 305 if useq "ssl" ; then
216 # --with-vio is not needed anymore, it's on by default and 306 # --with-vio is not needed anymore, it's on by default and
217 # has been removed from configure 307 # has been removed from configure
218 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio" 308 mysql_version_is_at_least "5.0.4" || myconf="${myconf} --with-vio"
219 if mysql_version_is_at_least "5.00.06.00" ; then 309 if mysql_version_is_at_least "5.0.6" ; then
220 # myconf="${myconf} --with-yassl" 310 # myconf="${myconf} --with-yassl"
221 myconf="${myconf} --with-openssl" 311 myconf="${myconf} --with-openssl"
222 else 312 else
223 myconf="${myconf} --with-openssl" 313 myconf="${myconf} --with-openssl"
224 fi 314 fi
238 else 328 else
239 myconf="${myconf} --without-berkeley-db" 329 myconf="${myconf} --without-berkeley-db"
240 fi 330 fi
241 fi 331 fi
242 332
243 if mysql_version_is_at_least "4.01.03.00" ; then 333 if mysql_version_is_at_least "4.1.3" ; then
244 myconf="${myconf} --with-geometry" 334 myconf="${myconf} --with-geometry"
245 myconf="${myconf} $(use_with cluster ndbcluster)" 335 myconf="${myconf} $(use_with cluster ndbcluster)"
246 fi 336 fi
247 337
248 if mysql_version_is_at_least "4.01.03.00" && useq "extraengine" ; then 338 if mysql_version_is_at_least "4.1.3" && useq "extraengine" ; then
249 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html 339 # http://dev.mysql.com/doc/mysql/en/archive-storage-engine.html
250 myconf="${myconf} --with-archive-storage-engine" 340 myconf="${myconf} --with-archive-storage-engine"
251 341
252 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html 342 # http://dev.mysql.com/doc/mysql/en/csv-storage-engine.html
253 myconf="${myconf} --with-csv-storage-engine" 343 myconf="${myconf} --with-csv-storage-engine"
256 myconf="${myconf} --with-blackhole-storage-engine" 346 myconf="${myconf} --with-blackhole-storage-engine"
257 347
258 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html 348 # http://dev.mysql.com/doc/mysql/en/federated-storage-engine.html
259 # http://dev.mysql.com/doc/mysql/en/federated-description.html 349 # http://dev.mysql.com/doc/mysql/en/federated-description.html
260 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html 350 # http://dev.mysql.com/doc/mysql/en/federated-limitations.html
261 if mysql_version_is_at_least "5.00.03.00" ; then 351 if mysql_version_is_at_least "5.0.3" ; then
262 elog "Before using the Federated storage engine, please be sure to read" 352 elog "Before using the Federated storage engine, please be sure to read"
263 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html" 353 elog "http://dev.mysql.com/doc/mysql/en/federated-limitations.html"
264 myconf="${myconf} --with-federated-storage-engine" 354 myconf="${myconf} --with-federated-storage-engine"
265 fi 355 fi
266 fi 356 fi
267 357
268 mysql_version_is_at_least "5.00.18.00" \ 358 mysql_version_is_at_least "5.0.18" \
269 && useq "max-idx-128" \ 359 && useq "max-idx-128" \
270 && myconf="${myconf} --with-max-indexes=128" 360 && myconf="${myconf} --with-max-indexes=128"
271} 361}
272 362
273configure_51() { 363configure_51() {
286 # 5.1 introduces a new way to manage storage engines (plugins) 376 # 5.1 introduces a new way to manage storage engines (plugins)
287 # like configuration=none 377 # like configuration=none
288 local plugins="csv,myisam,myisammrg,heap" 378 local plugins="csv,myisam,myisammrg,heap"
289 if useq "extraengine" ; then 379 if useq "extraengine" ; then
290 # like configuration=max-no-ndb, archive and example removed in 5.1.11 380 # like configuration=max-no-ndb, archive and example removed in 5.1.11
291 plugins="${plugins},blackhole,federated,ftexample,partition" 381 plugins="${plugins},archive,blackhole,example,federated,ftexample,partition"
292 382
293 elog "Before using the Federated storage engine, please be sure to read" 383 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" 384 elog "http://dev.mysql.com/doc/refman/5.1/en/federated-limitations.html"
295 fi 385 fi
296 386
305 fi 395 fi
306 396
307 myconf="${myconf} --with-plugins=${plugins}" 397 myconf="${myconf} --with-plugins=${plugins}"
308} 398}
309 399
400pbxt_src_compile() {
401 mysql_init_vars
402
403 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
404
405 einfo "Reconfiguring dir '${PWD}'"
406 AT_GNUCONF_UPDATE="yes" eautoreconf
407
408 local myconf
409 myconf="${myconf} --with-mysql=${S}"
410 mkdir -p ${T}/lib
411 myconf="${myconf} --libdir=${D}/${MY_LIBDIR}"
412 useq "debug" && myconf="${myconf} --with-debug=full"
413 # TODO is safe/needed to use econf here ?
414 ./configure ${myconf} || die "problem configuring pbxt storage engine"
415 # TODO is safe/needed to use emake here ?
416 make || die "problem making pbxt storage engine (${myconf})"
417
418 popd
419 # TODO: modify test suite
420}
421
422pbxt_src_install() {
423 pushd "${WORKDIR}/pbxt-${PBXT_VERSION}" &>/dev/null
424 make install || die "failed pbxt install"
425 popd
426}
427
310# 428#
311# EBUILD FUNCTIONS 429# EBUILD FUNCTIONS
312# 430#
313 431
314mysql_pkg_setup() { 432mysql_pkg_setup() {
315 enewgroup mysql 60 || die "problem adding 'mysql' group" 433 enewgroup mysql 60 || die "problem adding 'mysql' group"
316 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user" 434 enewuser mysql 60 -1 /dev/null mysql || die "problem adding 'mysql' user"
317 435
318 if mysql_version_is_at_least "5.01.12.00" && useq "innodb" ; then
319 eerror "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
320 die "InnoDB now uses cmake to build, this is a TODO item, will be fixed shortly!"
321 fi
322
323 # Check for USE flag problems in pkg_setup 436 # Check for USE flag problems in pkg_setup
324 if useq "static" && useq "ssl" ; then 437 if useq "static" && useq "ssl" ; then
325 eerror "MySQL does not support being built statically with SSL support enabled!" 438 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!" 439 die "MySQL does not support being built statically with SSL support enabled!"
327 fi 440 fi
328 441
329 if ! mysql_version_is_at_least "5.00.00.00" \ 442 if ! mysql_version_is_at_least "5.0" \
330 && useq "raid" \ 443 && useq "raid" \
331 && useq "static" ; then 444 && useq "static" ; then
332 eerror "USE flags 'raid' and 'static' conflict, you cannot build MySQL statically" 445 eerror "USE flags 'raid' and 'static' conflict, you cannot build MySQL statically"
333 eerror "with RAID support enabled." 446 eerror "with RAID support enabled."
334 die "USE flags 'raid' and 'static' conflict!" 447 die "USE flags 'raid' and 'static' conflict!"
335 fi 448 fi
336 449
337 if mysql_version_is_at_least "4.01.03.00" \ 450 if mysql_version_is_at_least "4.1.3" \
338 && ( useq "cluster" || useq "extraengine" ) \ 451 && ( useq "cluster" || useq "extraengine" ) \
339 && useq "minimal" ; then 452 && useq "minimal" ; then
340 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!" 453 eerror "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
341 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!" 454 die "USE flags 'cluster' and 'extraengine' conflict with 'minimal' USE flag!"
342 fi 455 fi
343 456
457 mysql_check_version_range "4.0 to 5.0.99.99" \
458 && useq "berkdb" \
344 useq "berkdb" && elog "Berkeley DB support is deprecated and will be removed in future versions!" 459 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
345} 460}
346 461
347mysql_src_unpack() { 462mysql_src_unpack() {
348 # Initialize the proper variables first 463 # Initialize the proper variables first
349 mysql_init_vars 464 mysql_init_vars
381 -exec rm -f {} \; 496 -exec rm -f {} \;
382 rm -f "ltmain.sh" 497 rm -f "ltmain.sh"
383 rm -f "scripts/mysqlbug" 498 rm -f "scripts/mysqlbug"
384 fi 499 fi
385 500
386 local rebuilddirlist bdbdir d 501 local rebuilddirlist d
387 502
388 if mysql_version_is_at_least "5.01.00.00" ; then 503 if mysql_version_is_at_least "5.1.12" ; then
389 rebuilddirlist=". storage/innobase" 504 rebuilddirlist="."
390 bdbdir='storage/bdb/dist' 505 # TODO IMPO! Check this with a cmake expert
506 useq "innodb" \
507 && cmake \
508 -DCMAKE_C_COMPILER=$(which $(tc-getCC)) \
509 -DCMAKE_CXX_COMPILER=$(which $(tc-getCC)) \
510 "storage/innobase"
391 else 511 else
392 rebuilddirlist=". innobase" 512 rebuilddirlist=". innobase"
393 bdbdir='bdb/dist'
394 fi 513 fi
395 514
396 for d in ${rebuilddirlist} ; do 515 for d in ${rebuilddirlist} ; do
397 einfo "Reconfiguring dir '${d}'" 516 einfo "Reconfiguring dir '${d}'"
398 pushd "${d}" &>/dev/null 517 pushd "${d}" &>/dev/null
399 AT_GNUCONF_UPDATE="yes" eautoreconf 518 AT_GNUCONF_UPDATE="yes" eautoreconf
400 popd &>/dev/null 519 popd &>/dev/null
401 done 520 done
402 521
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 522 if mysql_check_version_range "4.1 to 5.0.99.99" \
523 && useq "berkdb" ; then
406 [[ -w "${bdbdir}/ltmain.sh" ]] && cp -f "ltmain.sh" "${bdbdir}/ltmain.sh" 524 [[ -w "bdb/dist/ltmain.sh" ]] && cp -f "ltmain.sh" "bdb/dist/ltmain.sh"
407 pushd "${bdbdir}" \ 525 pushd "bdb/dist" \
408 && sh s_all \ 526 && sh s_all \
409 || die "Failed bdb reconfigure" \ 527 || die "Failed bdb reconfigure" \
410 &>/dev/null 528 &>/dev/null
411 popd &>/dev/null 529 popd &>/dev/null
412 fi 530 fi
414 532
415mysql_src_compile() { 533mysql_src_compile() {
416 # Make sure the vars are correctly initialized 534 # Make sure the vars are correctly initialized
417 mysql_init_vars 535 mysql_init_vars
418 536
537 # $myconf is modified by the configure_* functions
419 local myconf 538 local myconf=""
420 539
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 540 if useq "minimal" ; then
432 # --with-vio is not needed anymore, it's on by default and 541 configure_minimal
433 # has been removed from configure 542 else
434 mysql_version_is_at_least "5.00.04.00" || myconf="${myconf} --with-vio" 543 configure_common
435 if mysql_version_is_at_least "5.00.06.00" ; then 544 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 545 configure_51
437 # myconf="${myconf} --with-yassl"
438 myconf="${myconf} --with-openssl"
439 else 546 else
440 myconf="${myconf} --with-openssl" 547 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 548 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: Recheck again later, there were problems with assembler enabled
581 # and some combinations 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 549 fi
587 550
588 # Bug #114895, bug #110149 551 # Bug #114895, bug #110149
589 filter-flags "-O" "-O[01]" 552 filter-flags "-O" "-O[01]"
590 553
591 # glib-2.3.2_pre fix, bug #16496 554 # glib-2.3.2_pre fix, bug #16496
592 append-flags "-DHAVE_ERRNO_AS_DEFINE=1" 555 append-flags "-DHAVE_ERRNO_AS_DEFINE=1"
593 556
594 append-flags "-fno-exceptions -fno-strict-aliasing" 557 CXXFLAGS="${CXXFLAGS} -fno-exceptions -fno-strict-aliasing"
595 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti" 558 CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-rtti"
596 mysql_version_is_at_least "5.00.00.00" \ 559 mysql_version_is_at_least "5.0" \
597 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates" 560 && CXXFLAGS="${CXXFLAGS} -fno-implicit-templates"
598 export CXXFLAGS 561 export CXXFLAGS
599 562
600 econf \ 563 econf \
601 --libexecdir="/usr/sbin" \ 564 --libexecdir="/usr/sbin" \
603 --localstatedir="${MY_LOCALSTATEDIR}" \ 566 --localstatedir="${MY_LOCALSTATEDIR}" \
604 --sharedstatedir="${MY_SHAREDSTATEDIR}" \ 567 --sharedstatedir="${MY_SHAREDSTATEDIR}" \
605 --libdir="${MY_LIBDIR}" \ 568 --libdir="${MY_LIBDIR}" \
606 --includedir="${MY_INCLUDEDIR}" \ 569 --includedir="${MY_INCLUDEDIR}" \
607 --with-low-memory \ 570 --with-low-memory \
608 --enable-local-infile \
609 --with-mysqld-user=mysql \
610 --with-client-ldflags=-lstdc++ \ 571 --with-client-ldflags=-lstdc++ \
611 --enable-thread-safe-client \ 572 --enable-thread-safe-client \
612 --with-comment="Gentoo Linux ${PF}" \ 573 --with-comment="Gentoo Linux ${PF}" \
613 --with-unix-socket-path="/var/run/mysqld/mysqld.sock" \
614 --without-readline \
615 --without-docs \ 574 --without-docs \
616 ${myconf} || die "econf failed" 575 ${myconf} || die "econf failed"
617 576
618 # TODO: Move this before autoreconf !!! 577 # TODO: Move this before autoreconf !!!
619 find . -type f -name Makefile -print0 \ 578 find . -type f -name Makefile -print0 \
652 rm -f "${D}/usr/sbin/mysqld" 611 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 612 rm -f "${D}${MY_LIBDIR}"/lib{heap,merge,nisam,my{sys,strings,sqld,isammrg,isam},vio,dbug}.a
654 fi 613 fi
655 614
656 # Configuration stuff 615 # Configuration stuff
657 if mysql_version_is_at_least "4.01.00.00" ; then 616 if mysql_version_is_at_least "4.1" ; then
658 mysql_mycnf_version="4.1" 617 mysql_mycnf_version="4.1"
659 else 618 else
660 mysql_mycnf_version="4.0" 619 mysql_mycnf_version="4.0"
661 fi 620 fi
662 insinto "${MY_SYSCONFDIR}" 621 insinto "${MY_SYSCONFDIR}"
663 doins "scripts/mysqlaccess.conf" 622 doins "scripts/mysqlaccess.conf"
664 sed -e "s!@DATADIR@!${DATADIR}!g" \ 623 sed -e "s!@DATADIR@!${DATADIR}!g" \
665 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \ 624 "${FILESDIR}/my.cnf-${mysql_mycnf_version}" \
666 > "${TMPDIR}/my.cnf.ok" 625 > "${TMPDIR}/my.cnf.ok"
667 if mysql_version_is_at_least "4.01.00.00" && useq "latin1" ; then 626 if mysql_version_is_at_least "4.1" && useq "latin1" ; then
668 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok" 627 sed -e "s|utf8|latin1|g" -i "${TMPDIR}/my.cnf.ok"
669 fi 628 fi
670 newins "${TMPDIR}/my.cnf.ok" my.cnf 629 newins "${TMPDIR}/my.cnf.ok" my.cnf
671 630
672 insinto "/etc/conf.d" 631 insinto "/etc/conf.d"
749 elog "if this is a new install." 708 elog "if this is a new install."
750 einfo 709 einfo
751 mysql_version_is_at_least "5.01.00.00" \ 710 mysql_version_is_at_least "5.01.00.00" \
752 || elog "InnoDB is *not* optional as of MySQL-4.0.24, at the request of upstream." 711 || elog "InnoDB is *not* optional as of MySQL-4.0.24, at the request of upstream."
753 fi 712 fi
713 mysql_check_version_range "4.0 to 5.0.99.99" \
714 && useq "berkdb" \
754 useq "berkdb" && elog "Berkeley DB support is deprecated and will be removed in future versions!" 715 && elog "Berkeley DB support is deprecated and will be removed in future versions!"
755} 716}
756 717
757mysql_pkg_config() { 718mysql_pkg_config() {
758 # Make sure the vars are correctly initialized 719 # Make sure the vars are correctly initialized
759 mysql_init_vars 720 mysql_init_vars
760 721
761 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR" 722 [[ -z "${DATADIR}" ]] && die "Sorry, unable to find DATADIR"
762 723
763 if built_with_use dev-db/mysql minimal ; then 724 if built_with_use ${CATEGORY}/${PN} minimal ; then
764 die "Minimal builds do NOT include the MySQL server" 725 die "Minimal builds do NOT include the MySQL server"
765 fi 726 fi
766 727
767 local pwd1="a" 728 local pwd1="a"
768 local pwd2="b" 729 local pwd2="b"
804 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \ 765 [[ -f "${ROOT}/${DATADIR}/mysql/user.frm" ]] \
805 || die "MySQL databases not installed" 766 || die "MySQL databases not installed"
806 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null 767 chown -R mysql:mysql "${ROOT}/${DATADIR}" 2> /dev/null
807 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null 768 chmod 0750 "${ROOT}/${DATADIR}" 2> /dev/null
808 769
809 if mysql_version_is_at_least "4.01.03.00" ; then 770 if mysql_version_is_at_least "4.1.3" ; then
810 options="--skip-ndbcluster" 771 options="--skip-ndbcluster"
811 772
812 # Filling timezones, see 773 # Filling timezones, see
813 # http://dev.mysql.com/doc/mysql/en/time-zone-support.html 774 # 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 775 "${ROOT}/usr/bin/mysql_tzinfo_to_sql" "${ROOT}/usr/share/zoneinfo" > "${sqltmp}" 2>/dev/null
863 wait %1 824 wait %1
864 einfo "Done" 825 einfo "Done"
865} 826}
866 827
867mysql_pkg_postrm() { 828mysql_pkg_postrm() {
868 mysql_lib_symlinks 829 : #mysql_lib_symlinks
869} 830}

Legend:
Removed from v.1.40  
changed lines
  Added in v.1.51

  ViewVC Help
Powered by ViewVC 1.1.20