You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
285 lines
8.5 KiB
285 lines
8.5 KiB
## |
|
## sqlite.spec -- OpenPKG RPM Package Specification |
|
## Copyright (c) 2000-2022 OpenPKG Project <http://openpkg.org/> |
|
## |
|
## 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.37.1 |
|
%define V_dist 3370100 |
|
%define V_year 2021 |
|
%define V_odbc 0.9998 |
|
%define V_jdbc 20150419 |
|
|
|
# package information |
|
Name: sqlite |
|
Summary: Lightweight Embedded SQL Database |
|
URL: http://www.sqlite.org/ |
|
Vendor: D. Richard Hipp |
|
Packager: OpenPKG Project |
|
Distribution: OpenPKG Community |
|
Class: BASE |
|
Group: Database |
|
License: PD |
|
Version: %{V_sqlite} |
|
Release: 20211231 |
|
|
|
# package options |
|
%option with_debug no |
|
%option with_readline no |
|
%option with_threads no |
|
%option with_fts3 no |
|
%option with_fts4 no |
|
%option with_fts5 no |
|
%option with_json1 no |
|
%option with_rtree no |
|
%option with_odbc no |
|
%option with_jdbc no |
|
%option with_dlopen no |
|
|
|
# list of sources |
|
Source0: http://www.sqlite.org/%{V_year}/sqlite-src-%{V_dist}.zip |
|
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 |
|
BuildPreReq: OpenPKG, openpkg >= 20160101, make, gawk, tcl |
|
PreReq: OpenPKG, openpkg >= 20160101 |
|
%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 |
|
|
|
%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_dist} |
|
url = http://www.sqlite.org/download.html |
|
regex = sqlite-src-(\d+)\.zip |
|
} |
|
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{8})\.tar\.gz |
|
} |
|
|
|
%prep |
|
%setup -q -n sqlite-src-%{V_dist} |
|
%patch -p0 -P 0 |
|
%if "%{with_odbc}" == "yes" |
|
%setup -q -n sqlite-src-%{V_dist} -D -T -a 1 |
|
%patch -p0 -d sqliteodbc-%{V_odbc} -P 1 |
|
%endif |
|
%if "%{with_jdbc}" == "yes" |
|
%setup -q -n sqlite-src-%{V_dist} -D -T -a 2 |
|
%endif |
|
|
|
%build |
|
# configure SQLite |
|
CC="%{l_cc}" |
|
CFLAGS="%{l_cflags -O}" |
|
CPPFLAGS="-I. %{l_cppflags}" |
|
LDFLAGS="-L. %{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" |
|
--disable-editline \ |
|
--enable-readline \ |
|
--with-readline-lib="`%{l_prefix}/bin/pkg-config --libs readline`" \ |
|
--with-readline-inc="`%{l_prefix}/bin/pkg-config --cflags readline`" \ |
|
%else |
|
--disable-editline \ |
|
--disable-readline \ |
|
%endif |
|
%if "%{with_debug}" == "yes" |
|
--enable-debug \ |
|
%else |
|
--disable-debug \ |
|
%endif |
|
%if "%{with_dlopen}" == "yes" |
|
--enable-load-extension \ |
|
%else |
|
--disable-load-extension \ |
|
%endif |
|
%if "%{with_fts3}" == "yes" |
|
--enable-fts3 \ |
|
%endif |
|
%if "%{with_fts4}" == "yes" |
|
--enable-fts4 \ |
|
%endif |
|
%if "%{with_fts5}" == "yes" |
|
--enable-fts5 \ |
|
%endif |
|
%if "%{with_json1}" == "yes" |
|
--enable-json1 \ |
|
%endif |
|
%if "%{with_rtree}" == "yes" |
|
--enable-rtree \ |
|
%endif |
|
--disable-tcl \ |
|
--disable-amalgamation \ |
|
--disable-shared |
|
|
|
# build SQLite |
|
%{l_make} %{l_mflags -O} |
|
|
|
# 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.. -I../src" |
|
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 |
|
%{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 |
|
|
|
%post |
|
# optionally link into ODBC |
|
%if "%{with_odbc}" == "yes" |
|
if ! $RPM_INSTALL_PREFIX/bin/odbcinst -q -d -n "SQLite3" >/dev/null 2>&1; then |
|
( 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 |
|
fi |
|
%endif |
|
|
|
%preun |
|
if [ $1 -eq 1 ]; then : ; |
|
# optionally unlink from ODBC |
|
%if "%{with_odbc}" == "yes" |
|
$RPM_INSTALL_PREFIX/bin/odbcinst -u -s -l -n "SQLite3" >/dev/null 2>&1 || true |
|
%endif |
|
fi |
|
|
|
|