# Copyright 1999-2019 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI="7" inherit autotools flag-o-matic multilib-minimal toolchain-funcs SRC_PV="$(printf "%u%02u%02u%02u" $(ver_rs 1- " "))" DOC_PV="${SRC_PV}" # DOC_PV="$(printf "%u%02u%02u00" $(ver_rs 1-3 " "))" DESCRIPTION="SQL database engine" HOMEPAGE="https://sqlite.org/" SRC_URI="doc? ( https://sqlite.org/2019/${PN}-doc-${DOC_PV}.zip ) tcl? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip ) test? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip ) tools? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip ) !tcl? ( !test? ( !tools? ( https://sqlite.org/2019/${PN}-autoconf-${SRC_PV}.tar.gz ) ) )" LICENSE="public-domain" SLOT="3" KEYWORDS="alpha amd64 arm arm64 hppa ia64 ~m68k ~mips ppc ppc64 ~riscv s390 ~sh sparc x86 ~ppc-aix ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris" IUSE="debug doc icu +readline secure-delete static-libs tcl test tools" RESTRICT="!test? ( test )" BDEPEND="doc? ( app-arch/unzip ) tcl? ( app-arch/unzip >=dev-lang/tcl-8.6:0 ) test? ( app-arch/unzip >=dev-lang/tcl-8.6:0 ) tools? ( app-arch/unzip >=dev-lang/tcl-8.6:0 )" RDEPEND="sys-libs/zlib:0=[${MULTILIB_USEDEP}] icu? ( dev-libs/icu:0=[${MULTILIB_USEDEP}] ) readline? ( sys-libs/readline:0=[${MULTILIB_USEDEP}] ) tcl? ( dev-lang/tcl:0=[${MULTILIB_USEDEP}] ) tools? ( dev-lang/tcl:0=[${MULTILIB_USEDEP}] )" DEPEND="${RDEPEND} test? ( >=dev-lang/tcl-8.6:0[${MULTILIB_USEDEP}] )" full_archive() { use tcl || use test || use tools } pkg_setup() { if full_archive; then S="${WORKDIR}/${PN}-src-${SRC_PV}" else S="${WORKDIR}/${PN}-autoconf-${SRC_PV}" fi } src_prepare() { if full_archive; then eapply "${FILESDIR}/${PN}-3.28.0-full_archive-build.patch" eapply "${FILESDIR}/${PN}-3.28.0-full_archive-segmentation_fault_fixes.patch" eapply "${FILESDIR}/${PN}-3.28.0-full_archive-tests.patch" eapply_user # Fix AC_CHECK_FUNCS. # https://mailinglists.sqlite.org/cgi-bin/mailman/private/sqlite-dev/2016-March/002762.html sed -e "s/AC_CHECK_FUNCS(.*)/AC_CHECK_FUNCS([fdatasync fullfsync gmtime_r isnan localtime_r localtime_s malloc_usable_size posix_fallocate pread pread64 pwrite pwrite64 strchrnul usleep utime])/" -i configure.ac || die "sed failed" else eapply "${FILESDIR}/${PN}-3.25.0-nonfull_archive-build.patch" eapply "${FILESDIR}/${PN}-3.28.0-nonfull_archive-segmentation_fault_fixes.patch" eapply_user # Fix AC_CHECK_FUNCS. # https://mailinglists.sqlite.org/cgi-bin/mailman/private/sqlite-dev/2016-March/002762.html sed \ -e "s/AC_CHECK_FUNCS(\[fdatasync.*/AC_CHECK_FUNCS([fdatasync fullfsync gmtime_r isnan localtime_r localtime_s malloc_usable_size posix_fallocate pread pread64 pwrite pwrite64 strchrnul usleep utime])/" \ -e "/AC_CHECK_FUNCS(posix_fallocate)/d" \ -i configure.ac || die "sed failed" fi eautoreconf multilib_copy_sources } multilib_src_configure() { local CPPFLAGS="${CPPFLAGS}" CFLAGS="${CFLAGS}" options=() options+=( --enable-$(full_archive && echo load-extension || echo dynamic-extensions) --enable-threadsafe ) if ! full_archive; then options+=(--disable-static-shell) fi # Support detection of misuse of SQLite API. # https://sqlite.org/compile.html#enable_api_armor append-cppflags -DSQLITE_ENABLE_API_ARMOR # Support column metadata functions. # https://sqlite.org/c3ref/column_database_name.html append-cppflags -DSQLITE_ENABLE_COLUMN_METADATA # Support sqlite_dbpage virtual table. # https://sqlite.org/compile.html#enable_dbpage_vtab append-cppflags -DSQLITE_ENABLE_DBPAGE_VTAB # Support dbstat virtual table. # https://sqlite.org/dbstat.html append-cppflags -DSQLITE_ENABLE_DBSTAT_VTAB # Support sqlite3_serialize() and sqlite3_deserialize() functions. # https://sqlite.org/compile.html#enable_deserialize # https://sqlite.org/c3ref/serialize.html # https://sqlite.org/c3ref/deserialize.html append-cppflags -DSQLITE_ENABLE_DESERIALIZE # Support comments in output of EXPLAIN. # https://sqlite.org/compile.html#enable_explain_comments append-cppflags -DSQLITE_ENABLE_EXPLAIN_COMMENTS # Support Full-Text Search versions 3, 4 and 5. # https://sqlite.org/fts3.html # https://sqlite.org/fts5.html append-cppflags -DSQLITE_ENABLE_FTS3 -DSQLITE_ENABLE_FTS3_PARENTHESIS -DSQLITE_ENABLE_FTS4 options+=(--enable-fts5) # Support hidden columns. append-cppflags -DSQLITE_ENABLE_HIDDEN_COLUMNS # Support JSON1 extension. # https://sqlite.org/json1.html append-cppflags -DSQLITE_ENABLE_JSON1 # Support memsys5 memory allocator. # https://sqlite.org/malloc.html#memsys5 append-cppflags -DSQLITE_ENABLE_MEMSYS5 # Support sqlite3_normalized_sql() function. # https://sqlite.org/c3ref/expanded_sql.html append-cppflags -DSQLITE_ENABLE_NORMALIZE # Support sqlite_offset() function. # https://sqlite.org/lang_corefunc.html#sqlite_offset append-cppflags -DSQLITE_ENABLE_OFFSET_SQL_FUNC # Support pre-update hook functions. # https://sqlite.org/c3ref/preupdate_count.html append-cppflags -DSQLITE_ENABLE_PREUPDATE_HOOK # Support Resumable Bulk Update extension. # https://sqlite.org/rbu.html append-cppflags -DSQLITE_ENABLE_RBU # Support R*Trees. # https://sqlite.org/rtree.html # https://sqlite.org/geopoly.html append-cppflags -DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_GEOPOLY # Support scan status functions. # https://sqlite.org/c3ref/stmt_scanstatus.html # https://sqlite.org/c3ref/stmt_scanstatus_reset.html append-cppflags -DSQLITE_ENABLE_STMT_SCANSTATUS # Support sqlite_stmt virtual table. # https://sqlite.org/stmt.html append-cppflags -DSQLITE_ENABLE_STMTVTAB # Support Session extension. # https://sqlite.org/sessionintro.html options+=(--enable-session) # Support unknown() function. # https://sqlite.org/compile.html#enable_unknown_sql_function append-cppflags -DSQLITE_ENABLE_UNKNOWN_SQL_FUNCTION # Support unlock notification. # https://sqlite.org/unlock_notify.html append-cppflags -DSQLITE_ENABLE_UNLOCK_NOTIFY # Support LIMIT and ORDER BY clauses on DELETE and UPDATE statements. # https://sqlite.org/compile.html#enable_update_delete_limit append-cppflags -DSQLITE_ENABLE_UPDATE_DELETE_LIMIT # Support PRAGMA function_list, PRAGMA module_list and PRAGMA pragma_list statements. # https://sqlite.org/pragma.html#pragma_function_list # https://sqlite.org/pragma.html#pragma_module_list # https://sqlite.org/pragma.html#pragma_pragma_list append-cppflags -DSQLITE_INTROSPECTION_PRAGMAS # Support soundex() function. # https://sqlite.org/lang_corefunc.html#soundex append-cppflags -DSQLITE_SOUNDEX # Support URI filenames. # https://sqlite.org/uri.html append-cppflags -DSQLITE_USE_URI # debug USE flag. if full_archive; then options+=($(use_enable debug)) else if use debug; then append-cppflags -DSQLITE_DEBUG else append-cppflags -DNDEBUG fi fi # icu USE flag. if use icu; then # Support ICU extension. # https://sqlite.org/compile.html#enable_icu append-cppflags -DSQLITE_ENABLE_ICU if full_archive; then sed -e "s/^TLIBS = @LIBS@/& -licui18n -licuuc/" -i Makefile.in || die "sed failed" else sed -e "s/^LIBS = @LIBS@/& -licui18n -licuuc/" -i Makefile.in || die "sed failed" fi fi # readline USE flag. options+=( --disable-editline $(use_enable readline) ) if full_archive && use readline; then options+=(--with-readline-inc="-I${EPREFIX}/usr/include/readline") fi # secure-delete USE flag. if use secure-delete; then # Enable secure_delete pragma by default. # https://sqlite.org/pragma.html#pragma_secure_delete append-cppflags -DSQLITE_SECURE_DELETE fi # static-libs USE flag. options+=($(use_enable static-libs static)) # tcl, test, tools USE flags. if full_archive; then options+=(--enable-tcl) fi if [[ "${CHOST}" == *-mint* ]]; then append-cppflags -DSQLITE_OMIT_WAL fi if [[ "${ABI}" == "x86" ]]; then if $(tc-getCC) ${CPPFLAGS} ${CFLAGS} -E -P -dM - < /dev/null 2> /dev/null | grep -q "^#define __SSE__ 1$"; then append-cflags -mfpmath=sse else append-cflags -ffloat-store fi fi econf "${options[@]}" } multilib_src_compile() { emake HAVE_TCL="$(usex tcl 1 "")" TCLLIBDIR="${EPREFIX}/usr/$(get_libdir)/${P}" if use tools && multilib_is_native_abi; then emake changeset dbdump dbhash dbtotxt index_usage rbu scrub showdb showjournal showshm showstat4 showwal sqldiff sqlite3_analyzer sqlite3_checker sqlite3_expert sqltclsh fi } multilib_src_test() { if [[ "${EUID}" -eq 0 ]]; then ewarn "Skipping tests due to root permissions" return fi local -x SQLITE_HISTORY="${T}/sqlite_history_${ABI}" emake HAVE_TCL="$(usex tcl 1 "")" $(use debug && echo fulltest || echo test) } multilib_src_install() { emake DESTDIR="${D}" HAVE_TCL="$(usex tcl 1 "")" TCLLIBDIR="${EPREFIX}/usr/$(get_libdir)/${P}" install if use tools && multilib_is_native_abi; then install_tool() { if [[ -f ".libs/${1}" ]]; then newbin ".libs/${1}" "${2}" else newbin "${1}" "${2}" fi } install_tool changeset sqlite3-changeset install_tool dbdump sqlite3-db-dump install_tool dbhash sqlite3-db-hash install_tool dbtotxt sqlite3-db-to-txt install_tool index_usage sqlite3-index-usage install_tool rbu sqlite3-rbu install_tool scrub sqlite3-scrub install_tool showdb sqlite3-show-db install_tool showjournal sqlite3-show-journal install_tool showshm sqlite3-show-shm install_tool showstat4 sqlite3-show-stat4 install_tool showwal sqlite3-show-wal install_tool sqldiff sqlite3-diff install_tool sqlite3_analyzer sqlite3-analyzer install_tool sqlite3_checker sqlite3-checker install_tool sqlite3_expert sqlite3-expert install_tool sqltclsh sqlite3-tclsh unset -f install_tool fi } multilib_src_install_all() { find "${D}" -name "*.la" -delete || die doman sqlite3.1 if use doc; then rm "${WORKDIR}/${PN}-doc-${DOC_PV}/"*.{db,txt} ( docinto html dodoc -r "${WORKDIR}/${PN}-doc-${DOC_PV}/"* ) fi }