1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
|
# Copyright 1999-2004 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql/mysql-4.1.8.ebuild,v 1.1 2004/12/23 10:56:52 robbat2 Exp $
inherit eutils gnuconfig
#to accomodate -laadeedah releases
NEWP=${P}
SVER=${PV%.*}
#normal releases:
SDIR=MySQL-${SVER}
#for a pre-release:
#SDIR=MySQL-${SVER}-Pre
S=${WORKDIR}/${NEWP}
DESCRIPTION="A fast, multi-threaded, multi-user SQL database server"
HOMEPAGE="http://www.mysql.com/"
SRC_URI="mirror://mysql/Downloads/${SDIR}/${NEWP}.tar.gz"
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="~amd64 ~x86"
IUSE="static readline innodb berkdb tcpd ssl perl ruby selinux debug cluster"
RESTRICT="nomirror"
DEPEND="
!<dev-db/mysql-4.1*
readline? ( >=sys-libs/readline-4.1 )
tcpd? ( >=sys-apps/tcp-wrappers-7.6-r6 )
ssl? ( >=dev-libs/openssl-0.9.6d )
perl? ( dev-lang/perl )
>=sys-libs/zlib-1.1.3
sys-apps/procps
>=sys-apps/texinfo-4.7
>=sys-apps/sed-4"
PDEPEND="perl? ( >=dev-perl/DBD-mysql-2.9004 )
ruby? ( >=dev-ruby/mysql-ruby-2.5 )"
RDEPEND="${DEPEND} selinux? ( sec-policy/selinux-mysql )"
warning() {
ewarn
ewarn "If you're upgrading from MySQL-3.x to 4.0, or 4.0.x to 4.1.x, you"
ewarn "must recompile the other packages on your system that link with"
ewarn "libmysqlclient after the upgrade completes. To obtain such a list"
ewarn "of packages for your system, you may use 'revdep-rebuild' from"
ewarn "app-portage/gentoolkit."
ewarn
ewarn "TODO: you must also follow the official upgrade instructions (research and write this up here)"
epause 5
}
pkg_setup() {
warning
}
src_unpack() {
if use static && use ssl; then
local msg="MySQL does not support building statically with SSL support"
eerror "${msg}"
die "${msg}"
fi
unpack ${A} || die
#zap startup script messages
EPATCH_OPTS="-p1 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0.23-install-db-sh.diff
#zap binary distribution stuff
EPATCH_OPTS="-p1 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0.18-mysqld-safe-sh.diff
#required for qmail-mysql
EPATCH_OPTS="-p0 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0-nisam.h.diff
#for correct hardcoded sysconf directory
EPATCH_OPTS="-p1 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0-my-print-defaults.diff
# NPTL support
EPATCH_OPTS="-p1 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0.18-gentoo-nptl.diff
# attempt to get libmysqlclient_r linked against ssl if USE="ssl" enabled
# i would really prefer to fix this at the Makefile.am level, but can't
# get the software to autoreconf as distributed - too many missing files
EPATCH_OPTS="-p1 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0.21-thrssl.patch
if use tcpd; then
EPATCH_OPTS="-p1 -d ${S}" \
epatch ${FILESDIR}/${PN}-4.0.14-r1-tcpd-vars-fix.diff
fi
cd ${S}
# this does the libtoolize stuff
autoreconf --install --force
# Saving this for a rainy day, in case we need it again
#WANT_AUTOMAKE=1.7 automake
gnuconfig_update
}
src_compile() {
local myconf
#The following fix is due to a bug with bdb on sparc's. See:
#http://www.geocrawler.com/mail/msg.php3?msg_id=4754814&list=8
if use sparc || use alpha || use hppa || use mips
then
myconf="${myconf} --without-berkeley-db"
else
use berkdb \
&& myconf="${myconf} --with-berkeley-db=./bdb" \
|| myconf="${myconf} --without-berkeley-db"
fi
#readline pair reads backwards on purpose, DONT change it around, Ok?
# this is because it refers to the building of a bundled readline
# versus the system copy
use readline && myconf="${myconf} --without-readline"
use readline || myconf="${myconf} --with-readline"
use static \
&& myconf="${myconf} --with-mysqld-ldflags=-all-static --disable-shared" \
|| myconf="${myconf} --enable-shared --enable-static"
myconf="${myconf} `use_with tcpd libwrap`"
myconf="${myconf} `use_with innodb`"
use ssl \
&& myconf="${myconf} --with-vio --with-openssl" \
|| myconf="${myconf} --without-openssl"
myconf="${myconf} `use_with debug`"
# MySQL CLuster UseFlag
if use cluster; then
myconf="${myconf} --with-ndbcluster"
fi
#glibc-2.3.2_pre fix; bug #16496
export CFLAGS="${CFLAGS} -DHAVE_ERRNO_AS_DEFINE=1"
#bug fix for #15099, should make this api backward compatible
export CFLAGS="${CFLAGS} -DUSE_OLD_FUNCTIONS"
#the compiler flags are as per their "official" spec ;)
#CFLAGS="${CFLAGS/-O?/} -O3" \
CXXFLAGS="${CXXFLAGS} -felide-constructors -fno-exceptions -fno-rtti" \
econf \
--libexecdir=/usr/sbin \
--sysconfdir=/etc/mysql \
--localstatedir=/var/lib/mysql \
--with-raid \
--with-low-memory \
--enable-assembler \
--with-charset=latin1 \
--enable-local-infile \
--with-mysqld-user=mysql \
--with-extra-charsets=all \
--enable-thread-safe-client \
--with-client-ldflags=-lstdc++ \
--with-comment="Gentoo Linux ${PF}" \
--with-unix-socket-path=/var/run/mysqld/mysqld.sock \
--with-embedded-server \
${myconf} || die "bad ./configure"
emake || die "compile problem"
}
src_install() {
make install DESTDIR=${D} benchdir_root=/usr/share/mysql || die
#move client libs, install a couple of missing headers
mv ${D}/usr/$(get_libdir)/mysql/libmysqlclient*.so* ${D}/usr/$(get_libdir)
dosym ../libmysqlclient.so /usr/$(get_libdir)/mysql/libmysqlclient.so
dosym ../libmysqlclient_r.so /usr/$(get_libdir)/mysql/libmysqlclient_r.so
insinto /usr/include/mysql ; doins include/{my_config.h,my_dir.h}
#convenience links
dosym /usr/bin/mysqlcheck /usr/bin/mysqlanalyze
dosym /usr/bin/mysqlcheck /usr/bin/mysqlrepair
dosym /usr/bin/mysqlcheck /usr/bin/mysqloptimize
#various junk
rm -f ${D}/usr/share/mysql/mysql.server
rm -f ${D}/usr/share/mysql/binary-configure
rm -f ${D}/usr/share/mysql/make_binary_distribution
rm -f ${D}/usr/share/mysql/mysql-log-rotate
rm -f ${D}/usr/share/mysql/{post,pre}install
rm -f ${D}/usr/share/mysql/mi_test*
rm -f ${D}/usr/share/mysql/*.spec # Redhat gunk
rm -f ${D}/usr/share/mysql/*.plist # Apple gunk
rm -f ${D}/usr/share/mysql/my-*.cnf # Put them elsewhere
# All of these (ab)use Perl.
if ! use perl; then
rm -f ${D}/usr/bin/mysql_setpermission
rm -rf ${D}/usr/share/mysql/sql-bench
fi
dohtml Docs/*.html
rm -f Docs/*.html
dodoc README COPYING COPYING.LIB Docs/manual.*
docinto conf-samples
dodoc support-files/my-*.cnf
insinto /etc/mysql
newins ${FILESDIR}/my.cnf-4.0.14-r1 my.cnf
doins scripts/mysqlaccess.conf
exeinto /etc/init.d
newexe ${FILESDIR}/mysql-4.0.15.rc6 mysql
insinto /etc/logrotate.d
newins ${FILESDIR}/logrotate.mysql mysql
}
pkg_config() {
local DATADIR=""
if [ -f '/etc/mysql/my.cnf' ] ; then
#DATADIR=`grep ^datadir /etc/mysql/my.cnf | sed -e 's/.*= //'`
#DATADIR=`/usr/sbin/mysqld --help |grep '^datadir' | awk '{print $2}'`
#DATADIR=`my_print_defaults mysqld | grep -- '^--datadir' | tail -n1 | sed -e 's|^--datadir=||'`
DATADIR=`my_print_defaults mysqld | sed -ne '/datadir/s|^--datadir=||p' | tail -n1`
fi
if [ -z "${DATADIR}" ]; then
DATADIR="/var/lib/mysql/"
einfo "Using default DATADIR"
fi
einfo "MySQL DATADIR is ${DATADIR}"
if [ ! -d ${ROOT}/${DATADIR}/mysql ] ; then
einfo "Press ENTER to create the mysql database and set proper"
einfo "permissions on it, or Control-C to abort now..."
read
${ROOT}/usr/bin/mysql_install_db #>>/var/log/mysql/mysql.err 2>&1
# changing ownership of newly created databases to mysql.mysql
chown -R mysql:mysql ${ROOT}/${DATADIR}
chmod 0750 ${ROOT}/${DATADIR}
ewarn "For security reasons you should set your MySQL root"
ewarn "password as soon as possible."
else
einfo "Hmm, it appears as though you already have the mysql"
einfo "database in place. If you are having problems trying"
einfo "to start mysqld, perhaps you need to manually run"
einfo "/usr/bin/mysql_install_db and/or check your config"
einfo "file(s) and/or database(s) and/or logfile(s)."
fi
}
pkg_preinst() {
enewgroup mysql 60 || die "problem adding group mysql"
enewuser mysql 60 /dev/null /var/lib/mysql mysql || die "problem adding user mysql"
}
pkg_postinst() {
#empty dirs...
install -d -m0750 -o mysql -g mysql ${ROOT}/var/lib/mysql
install -d -m0755 -o mysql -g mysql ${ROOT}/var/run/mysqld
install -d -m0755 -o mysql -g mysql ${ROOT}/var/log/mysql
#secure the logfiles... does this bother anybody?
touch ${ROOT}/var/log/mysql/mysql.{log,err}
chown mysql:mysql ${ROOT}/var/log/mysql/mysql*
chmod 0660 ${ROOT}/var/log/mysql/mysql*
# secure some directories
chmod 0750 ${ROOT}/var/log/mysql ${ROOT}/var/lib/mysql
#your friendly public service announcement...
einfo
einfo "You might want to run:"
einfo "\"ebuild /var/db/pkg/dev-db/${PF}/${PF}.ebuild config\""
einfo "if this is a new install."
einfo
warning
}
|