## ## mysql3.spec -- OpenPKG RPM Specification ## Copyright (c) 2000-2003 Cable & Wireless Deutschland GmbH ## Copyright (c) 2000-2003 The OpenPKG Project ## Copyright (c) 2000-2003 Ralf S. Engelschall ## ## Permission to use, copy, modify, and distribute this software for ## any purpose with or without fee is hereby granted, provided that ## the above copyright notice and this permission notice appear in all ## copies. ## ## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED ## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. ## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR ## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT ## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF ## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, ## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT ## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF ## SUCH DAMAGE. ## # package version %define V_major 3.23 %define V_minor 56 # package information Name: mysql3 Summary: Fast Relational Database Management System URL: http://www.mysql.com/ Vendor: MySQL AB Packager: The OpenPKG Project Distribution: OpenPKG [PLUS] Group: Database License: GPL Version: %{V_major}.%{V_minor} Release: 20030614 # package options %option with_berkeleydb yes %option with_innobase no %option with_gemini no # list of sources Source0: http://sunsite.informatik.rwth-aachen.de/mysql/Downloads/MySQL-%{V_major}/mysql-%{version}.tar.gz Source1: my.cnf Source2: my.pwd Source3: rc.mysql3 Patch0: mysql3.patch # build information Prefix: %{l_prefix} BuildRoot: %{l_buildroot} BuildPreReq: OpenPKG, openpkg >= 20030103, gcc, zlib PreReq: OpenPKG, openpkg >= 20030103, zlib AutoReq: no AutoReqProv: no Provides: MYSQL Conflicts: mysql %description MySQL is a multi-user Relational Database Management System (RDBMS), which is controlled through Structured Query Language (SQL) operating in full multi-threading mode. The main goals of MySQL are speed, robustness and ease of use. MySQL was originally developed because of the need for a SQL server that could handle very big databases with magnitude higher speed than what any database vendor could offer. NOTICE: This package contains the old and already deprecated MySQL 3.x version. Please use the "mysql" package, containing the current stable MySQL 4.x version. %prep %setup -q -n mysql-%{version} %patch -p0 # fix broken conftest %{l_shtool} subst \ -e 's; close(file); fclose(file);g' \ configure %build # patch file search path %{l_shtool} subst \ -e 's;@l_prefix@;%{l_prefix};g' \ mysys/default.c # patch socklen_t for Sol6 case "%{l_target}" in *-solaris2.6* ) %{l_shtool} subst \ -e 's;socklen_t;size_t;g' \ acinclude.m4 \ aclocal.m4 \ configure \ include/global.h \ include/my_global.h \ libmysql/acinclude.m4 %{l_shtool} subst \ -e 's;socklen_t;size_socket;g' \ sql/mini_client.cc \ sql/mysqld.cc ;; esac # determine additional configure options case "%{l_target}" in *-freebsd* ) opt="--with-client-ldflags=-static --with-mysqld-ldflags=-static" ;; *-linux* ) opt="--with-client-ldflags=-static --with-mysqld-ldflags=-static" ;; *-solaris* ) opt="--with-client-ldflags=-static --with-mysqld-ldflags=-static" ;; esac # only use system default path unset LD_LIBRARY_PATH || true # configure source tree CC="%{l_cc}" \ CXX="%{l_cxx}" \ CFLAGS="%{l_cflags -O}" \ CXXFLAGS="%{l_cxxflags -O}" \ ./configure \ --prefix=%{l_prefix} \ --sysconfdir=%{l_prefix}/etc/mysql \ --localstatedir=%{l_prefix}/var/mysql \ --with-unix-socket-path=%{l_prefix}/var/mysql/mysql.sock \ --with-mysqld-user=%{l_musr} \ --enable-thread-safe-client \ %if "%{with_berkeleydb}" == "yes" --with-berkeley-db \ %endif %if "%{with_innobase}" == "yes" --with-innodb \ %endif %if "%{with_gemini}" == "yes" --with-gemini \ %endif --with-low-memory \ --disable-shared \ $opt # build source tree %{l_make} %{l_mflags -O} %install rm -rf $RPM_BUILD_ROOT # patch init script %{l_shtool} subst \ -e 's;@l_prefix@;%{l_prefix};g' \ scripts/mysql_install_db.sh # perform standard installation procedure %{l_make} %{l_mflags} install \ AM_MAKEFLAGS="DESTDIR=$RPM_BUILD_ROOT" \ DESTDIR=$RPM_BUILD_ROOT # KLUDGE: my_dir.h is not installed! %{l_shtool} install -c -m 644 \ include/my_dir.h $RPM_BUILD_ROOT%{l_prefix}/include/mysql/ # strip installation area rm -rf $RPM_BUILD_ROOT%{l_prefix}/mysql-test rm -rf $RPM_BUILD_ROOT%{l_prefix}/sql-bench rm -f $RPM_BUILD_ROOT%{l_prefix}/info/dir rm -f $RPM_BUILD_ROOT%{l_prefix}/share/mysql/mysql-%{version}.spec rm -f $RPM_BUILD_ROOT%{l_prefix}/share/mysql/binary-configure strip $RPM_BUILD_ROOT%{l_prefix}/bin/* 2>/dev/null || true strip $RPM_BUILD_ROOT%{l_prefix}/libexec/* 2>/dev/null || true # determine default parameters %if "%{with_berkeleydb}" == "yes" l_mysql_bdb_cache_size=8M l_mysql_bdb_log_buffer_size=32k l_mysql_bdb_max_lock=10000 %else l_mysql_bdb_cache_size=0 l_mysql_bdb_log_buffer_size=0 l_mysql_bdb_max_lock=0 %endif %if "%{with_berkeleydb}" == "yes" || "%{with_innobase}" == "yes" || "%{with_gemini}" == "yes" l_mysqld=mysqld %else l_mysqld=mysqld-max %endif # install global configuration %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/etc/mysql %{l_shtool} install -c -m 644 \ -e 's;@l_prefix@;%{l_prefix};g' \ -e 's;@l_rusr@;%{l_rusr};g' \ -e "s;@l_mysql_bdb_cache_size@;${l_mysql_bdb_cache_size};g" \ -e "s;@l_mysql_bdb_log_buffer_size@;${l_mysql_bdb_log_buffer_size};g" \ -e "s;@l_mysql_bdb_max_lock@;${l_mysql_bdb_max_lock};g" \ %{SOURCE my.cnf} \ $RPM_BUILD_ROOT%{l_prefix}/etc/mysql/ %{l_shtool} install -c -m 600 \ %{SOURCE my.pwd} \ $RPM_BUILD_ROOT%{l_prefix}/etc/mysql/ # install run-command script %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d %{l_shtool} install -c -m 755 \ -e 's;@l_prefix@;%{l_prefix};g' \ -e 's;@l_rusr@;%{l_rusr};g' \ -e 's;@l_rgrp@;%{l_rgrp};g' \ -e "s;@l_mysqld@;${l_mysqld};g" \ %{SOURCE rc.mysql3} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/ # make sure the database directory exists %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/var/mysql # determine the package files %{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \ %{l_files_std} \ '%config %{l_prefix}/etc/mysql/my.cnf' \ '%config %{l_prefix}/etc/mysql/my.pwd' %files -f files %clean rm -rf $RPM_BUILD_ROOT %post # create initial database $RPM_INSTALL_PREFIX/bin/mysql_install_db \ --defaults-file=$RPM_INSTALL_PREFIX/etc/mysql/my.cnf chown %{l_rusr}:%{l_rgrp} \ $RPM_INSTALL_PREFIX/etc/mysql/my.cnf \ $RPM_INSTALL_PREFIX/etc/mysql/my.pwd chown -R %{l_rusr}:%{l_rgrp} $RPM_INSTALL_PREFIX/var/mysql/ ( echo "The MySQL package includes automated maintenance procedures" echo "that require administrator access to the database. For this" echo "to work you must keep a copy (plain text) of the administrator" echo "account in '$RPM_INSTALL_PREFIX/etc/mysql/my.pwd'." ) | %{l_rpmtool} msg -b -t notice