##
## sqlite.spec -- OpenPKG RPM Package Specification
## Copyright (c) 2000-2007 OpenPKG Foundation e.V.
## Copyright (c) 2000-2007 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_sqlite 3.5.0
%define V_odbc 0.75
%define V_jdbc 20070915
# package information
Name: sqlite
Summary: SQL Lite
URL: http://www.sqlite.org/
Vendor: D. Richard Hipp
Packager: OpenPKG Foundation e.V.
Distribution: OpenPKG Community
Class: BASE
Group: Database
License: PD
Version: %{V_sqlite}
Release: 20070920
# package options
%option with_assert no
%option with_readline no
%option with_threads no
%option with_fts1 no
%option with_fts2 no
%option with_odbc no
%option with_jdbc no
# list of sources
Source0: http://www.sqlite.org/sqlite-%{V_sqlite}.tar.gz
Source1: http://www.ch-werner.de/sqliteodbc/sqliteodbc-%{V_odbc}.tar.gz
Source2: http://www.ch-werner.de/javasqlite/javasqlite-%{V_jdbc}.tar.gz
Patch0: sqlite.patch
Patch1: sqlite.patch.odbc
# build information
Prefix: %{l_prefix}
BuildRoot: %{l_buildroot}
BuildPreReq: OpenPKG, openpkg >= 20040130, make, gawk
PreReq: OpenPKG, openpkg >= 20040130
%if "%{with_readline}" == "yes"
BuildPreReq: readline, pkgconfig
PreReq: readline
%endif
%if "%{with_odbc}" == "yes"
BuildPreReq: ODBC
PreReq: ODBC
%endif
%if "%{with_jdbc}" == "yes"
BuildPreReq: java, JAVA-JDK
PreReq: java, JAVA-JDK
%endif
AutoReq: no
AutoReqProv: no
%description
SQLite is a C library that implements an embeddable SQL database
engine. Programs that link with the SQLite library can have SQL
database access without running a separate RDBMS process. The
distribution comes with a standalone command-line access program
(sqlite) that can be used to administer an SQLite database and which
serves as an example of how to use the SQLite library. SQLite is not
a client library used to connect to a big database server. SQLite is
the server. The SQLite library reads and writes directly to and from
the database files on disk.
%track
prog sqlite = {
version = %{V_sqlite}
url = http://www.sqlite.org/download.html
regex = sqlite-(\d+\.\d+\.\d+)\.tar\.gz
}
prog sqlite:odbc = {
version = %{V_odbc}
url = http://www.ch-werner.de/sqliteodbc/
regex = sqliteodbc-(__VER__)\.tar\.gz
}
prog sqlite:jdbc = {
version = %{V_jdbc}
url = http://www.ch-werner.de/javasqlite/overview-summary.html
regex = javasqlite-(\d+)\.tar\.gz
}
%prep
%setup -q
%patch -p0 -P 0
%if "%{with_odbc}" == "yes"
%setup -q -D -T -a 1
%patch -p0 -d sqliteodbc-%{V_odbc} -P 1
%endif
%if "%{with_jdbc}" == "yes"
%setup -q -D -T -a 2
%endif
# post-adjust sources
%{l_shtool} subst \
-e '/LINENO: error: C[+]* preprocessor/{N;N;N;N;s/.*/:/;}' \
configure
%build
# configure and build SQLite
CC="%{l_cc}"
CFLAGS="%{l_cflags -O}"
%if "%{with_assert}" == "no"
CFLAGS="$CFLAGS -DNDEBUG=1"
%endif
CFLAGS="$CFLAGS -DSQLITE_MAX_SQL_LENGTH=10000000"
CPPFLAGS="%{l_cppflags}"
LDFLAGS="%{l_ldflags}"
LIBS="-lm"
export CC
export CPPFLAGS
export CFLAGS
export LDFLAGS
export LIBS
GREP="grep" \
./configure \
--prefix=%{l_prefix} \
%if "%{with_threads}" == "yes"
--enable-threadsafe \
%else
--disable-threadsafe \
%endif
%if "%{with_readline}" == "yes"
--enable-readline \
--with-readline-lib="`%{l_prefix}/bin/pkg-config --libs readline`" \
--with-readline-inc="`%{l_prefix}/bin/pkg-config --cflags readline`" \
%else
--disable-readline \
%endif
--disable-shared
%if "%{with_assert}" == "yes"
%{l_shtool} subst \
-e 's;-DNDEBUG;;' \
Makefile
%endif
MFLAGS=""
%if "%{with_fts1}" == "yes"
MFLAGS="$MFLAGS FTS1=1"
%endif
%if "%{with_fts2}" == "yes"
MFLAGS="$MFLAGS FTS2=1"
%endif
%{l_make} %{l_mflags -O} $MFLAGS
# optionally build ODBC driver
%if "%{with_odbc}" == "yes"
( cd sqliteodbc-%{V_odbc}
export CC="%{l_cc}"
export CFLAGS="%{l_cflags -O}"
export CPPFLAGS=""
export LDFLAGS=""
CPPFLAGS="$CPPFLAGS -I.."
LDFLAGS="$LDFLAGS -L../.libs"
./configure \
--prefix=%{l_prefix} \
--with-sqlite3=.. \
--with-odbc=%{l_prefix} \
--disable-static \
--enable-shared
%{l_make} %{l_mflags -O}
) || exit $?
%endif
# optionally build JDBC driver
%if "%{with_jdbc}" == "yes"
( cd javasqlite-%{V_jdbc}
export JAVA_PLATFORM="sun-jdk"
eval `%{l_prefix}/bin/java-toolkit -e`
export CC="%{l_cc}"
export CFLAGS="%{l_cflags -O}"
export CPPFLAGS=""
export LDFLAGS=""
CPPFLAGS="$CPPFLAGS -I.."
LDFLAGS="$LDFLAGS -L../.libs"
./configure \
--prefix=%{l_prefix} \
--with-jardir=%{l_prefix}/lib \
--with-jdk=$JAVA_HOME \
--with-sqlite3=..
%{l_make} %{l_mflags}
) || exit $?
%endif
%install
# create installation hierarchy
rm -rf $RPM_BUILD_ROOT
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/bin \
$RPM_BUILD_ROOT%{l_prefix}/lib \
$RPM_BUILD_ROOT%{l_prefix}/include \
$RPM_BUILD_ROOT%{l_prefix}/man/man1
# install SQLite
%{l_make} %{l_mflags} install \
prefix=$RPM_BUILD_ROOT%{l_prefix}
%{l_shtool} install -c -m 644 \
sqlite3.1 $RPM_BUILD_ROOT%{l_prefix}/man/man1/sqlite3.1
# install SQLite ODBC driver (optional)
%if "%{with_odbc}" == "yes"
( cd sqliteodbc-%{V_odbc}
%{l_make} %{l_mflags} install \
prefix=$RPM_BUILD_ROOT%{l_prefix}
) || exit $?
%endif
# install SQLite JDBC driver (optional)
%if "%{with_jdbc}" == "yes"
( cd javasqlite-%{V_jdbc}
%{l_make} %{l_mflags} install DESTDIR=$RPM_BUILD_ROOT
) || exit $?
%endif
# strip down installation files
strip $RPM_BUILD_ROOT%{l_prefix}/bin/* >/dev/null 2>&1 || true
# provide convenient symlinks
ln $RPM_BUILD_ROOT%{l_prefix}/bin/sqlite3 \
$RPM_BUILD_ROOT%{l_prefix}/bin/sqlite
ln $RPM_BUILD_ROOT%{l_prefix}/man/man1/sqlite3.1 \
$RPM_BUILD_ROOT%{l_prefix}/man/man1/sqlite.1
# determine installation files
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
%{l_files_std}
%files -f files
%clean
rm -rf $RPM_BUILD_ROOT
%post
if [ $1 -eq 1 ]; then : ;
# optionally link into ODBC
%if "%{with_odbc}" == "yes"
( echo "[SQLite3]"
echo "Description = SQLite 3 ODBC Driver"
echo "Driver = $RPM_INSTALL_PREFIX/lib/libsqlite3odbc.so"
echo "Setup = $RPM_INSTALL_PREFIX/lib/libsqlite3odbc.so"
echo "FileUsage = 1"
) | $RPM_INSTALL_PREFIX/bin/odbcinst -i -d -n "SQLite3" -r >/dev/null 2>&1 || true
( echo "[SQLite3 DataSource]"
echo "Driver = SQLite3"
) | $RPM_INSTALL_PREFIX/bin/odbcinst -i -s -l -n "SQLite3 DataSource" -r >/dev/null 2>&1 || true
%endif
fi
%preun
if [ $1 -eq 1 ]; then : ;
# optionally unlink from ODBC
%if "%{with_odbc}" == "yes"
$RPM_INSTALL_PREFIX/bin/odbcinst -u -s -l -n "SQLite3 DataSource" >/dev/null 2>&1 || true
$RPM_INSTALL_PREFIX/bin/odbcinst -u -d -n "SQLite3" >/dev/null 2>&1 || true
%endif
fi