commit:     2f648371abb80406454eb702cb15eae983256c74
Author:     Jakov Smolić <jsmolic <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 25 00:21:46 2025 +0000
Commit:     Jakov Smolić <jsmolic <AT> gentoo <DOT> org>
CommitDate: Sat Jan 25 02:04:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2f648371

dev-db/sqlite: add 3.48.0 (unkeyworded)

Upstream did a complete build system overhaul moving from autoconf to
autosetup. Additionally dev-lang/tcl is not needed as a build dependency
anymore (apart from building tools and tests). There have been some bugs
discovered after the release so add unkeyworded version for testing as
tests are failing at the moment and there is a build issue with USE=icu
that have yet to be investigated.

Signed-off-by: Jakov Smolić <jsmolic <AT> gentoo.org>

 dev-db/sqlite/Manifest             |   2 +
 dev-db/sqlite/sqlite-3.48.0.ebuild | 428 +++++++++++++++++++++++++++++++++++++
 2 files changed, 430 insertions(+)

diff --git a/dev-db/sqlite/Manifest b/dev-db/sqlite/Manifest
index d266c56e8072..eba80916aa82 100644
--- a/dev-db/sqlite/Manifest
+++ b/dev-db/sqlite/Manifest
@@ -1,4 +1,6 @@
 DIST sqlite-doc-3460100.zip 10851427 BLAKE2B 
7462e83ca84e3e9aac7236f575fd2bdddac7744ae700a63fe8fdc9d2df3157c59fd374d99a0526bd4d9f742005ee7a90f3d78057861d3c3fcba9f897630e48db
 SHA512 
1ad7dfc938d182f69ea9367b4f5ead1d48b991626521249e8b58c9fb4c2553e348ce402de9cc81b0ad699d4c45c467de56a98ee39f9c3555c6fafff15fba41ce
 DIST sqlite-doc-3470200.zip 10957830 BLAKE2B 
cbc40dd440d1c5af4ad4333090a7306bd54ec43250a478b6900b8f74bd721035018ea7647f3a208d42cc0639827325be26a9412d17af7d390f4e584d4c6acf44
 SHA512 
48349d512b7cd9bc6f6a5da3a2b2285de159d4653667311adb0f5e6a970060db940a590c2d01b529afc1614065b22434d5b3ac4d8d0122d003d74926745ba56e
+DIST sqlite-doc-3480000.zip 11391112 BLAKE2B 
d28531e5d3ac7802700636a669f165cb9fa2a6077422b1ba956b6b9e29db48941489b5a3bc1c4936723e59343e00c3edc9310db9724d914a30ac9aca775dc70d
 SHA512 
d7cad0da8598a3abcacf0e05ba4e285ad1d790691e571e431f920abf1bf27c5a416408ff60ff051b01a65662c0e60bb63b9ba73872851fe63f379e834c5a0f04
 DIST sqlite-src-3460100.zip 14276926 BLAKE2B 
df16ea944e317df8ed64fdfab289e3699ec71725ce55e2b30450adaeb41c061b4fba1eb8c41ba638b0edcd12b23264a1f9e413b69fd593c2b65fb1037d3fc8b2
 SHA512 
6d32a0db9f95d3cec34f02f3fd45b453bf7c422d4d4d9570790f641e7d190b8b31be8e8715afacc1b6e4417f15a4d15a0b28e608ae0b4b5f3054b075783b916e
 DIST sqlite-src-3470200.zip 14421983 BLAKE2B 
dcaea5be0099b2dad1b53403933f0037ace48b1f248040c1b5cc116ac2ad6c9b44c71b8efe3afd16bef01119b440d1a2ec9d553a22f855e0ba55793684f53d8d
 SHA512 
a6280a02304bfae173d9e9ebf376b2d3624658f04af4d8e95d5a042e24cf0405a47c0a4023f4dbc2790716cd85e16b97fcc0a83c1534e6d554f4eb0bfb0a3ed3
+DIST sqlite-src-3480000.zip 14350897 BLAKE2B 
1dafce5575cbf8eb4e7efb5c033322b887bcce38129756994da45b1d8e0cf136f337e6cb9fa3c4b5abcf1f68bff6763247bec1ad04975fc9de308e3b75fb4e54
 SHA512 
854832e9a5dc486a81934e36c1f1678ce50db55b8bd3c48ed2d569fb0bb7ce23d4b490c0a0f699274ff11ddf2000db4a620e064557084c54b217e7fdd836f4e1

diff --git a/dev-db/sqlite/sqlite-3.48.0.ebuild 
b/dev-db/sqlite/sqlite-3.48.0.ebuild
new file mode 100644
index 000000000000..d5b15dc53f6c
--- /dev/null
+++ b/dev-db/sqlite/sqlite-3.48.0.ebuild
@@ -0,0 +1,428 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit flag-o-matic multilib-minimal toolchain-funcs
+
+DESCRIPTION="SQL database engine"
+HOMEPAGE="https://sqlite.org/";
+
+# On version updates, make sure to read the forum 
(https://sqlite.org/forum/forum)
+# for hints regarding test failures, backports, etc.
+if [[ ${PV} == 9999 ]]; then
+       S="${WORKDIR}"/${PN}
+       PROPERTIES="live"
+else
+       printf -v SRC_PV "%u%02u%02u%02u" $(ver_rs 1- " ")
+       DOC_PV="${SRC_PV}"
+       #printf -v DOC_PV "%u%02u%02u00" $(ver_rs 1-3 " ")
+
+       SRC_URI="
+               https://sqlite.org/2025/${PN}-src-${SRC_PV}.zip
+               doc? ( https://sqlite.org/2025/${PN}-doc-${DOC_PV}.zip )
+       "
+       S="${WORKDIR}/${PN}-src-${SRC_PV}"
+
+       #KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~m68k ~mips ~ppc 
~ppc64 ~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos 
~x64-macos ~x64-solaris"
+fi
+
+LICENSE="public-domain"
+SLOT="3"
+IUSE="debug doc icu +readline secure-delete static-libs tcl test tools"
+RESTRICT="!test? ( test )"
+
+RDEPEND="
+       sys-libs/zlib:=[${MULTILIB_USEDEP}]
+       icu? ( dev-libs/icu:=[${MULTILIB_USEDEP}] )
+       readline? ( sys-libs/readline:=[${MULTILIB_USEDEP}] )
+       tcl? ( dev-lang/tcl:=[${MULTILIB_USEDEP}] )
+       tools? ( dev-lang/tcl:= )
+"
+DEPEND="
+       ${RDEPEND}
+       test? ( >=dev-lang/tcl-8.6:0[${MULTILIB_USEDEP}] )
+"
+if [[ ${PV} == 9999 ]]; then
+       BDEPEND+=" dev-vcs/fossil"
+else
+       BDEPEND+=" app-arch/unzip"
+fi
+
+_fossil_fetch() {
+       local distdir="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}"
+       local repo_id="${1}"
+       local repo_uri="${2}"
+
+       local -x FOSSIL_HOME="${HOME}"
+
+       mkdir -p "${T}/fossil/${repo_id}" || die
+       pushd "${T}/fossil/${repo_id}" > /dev/null || die
+
+       if [[ -n "${EVCS_OFFLINE}" ]]; then
+               if [[ ! -f "${distdir}/fossil-src/${repo_id}/${repo_id}.fossil" 
]]; then
+                       die "Network activity disabled using EVCS_OFFLINE and 
clone of repository missing: 
\"${distdir}/fossil-src/${repo_id}/${repo_id}.fossil\""
+               fi
+       else
+               if [[ ! -f "${distdir}/fossil-src/${repo_id}/${repo_id}.fossil" 
]]; then
+                       einfo fossil clone --verbose "${repo_uri}" 
"${repo_id}.fossil"
+                       fossil clone --verbose "${repo_uri}" 
"${repo_id}.fossil" || die
+                       echo
+               else
+                       cp -p 
"${distdir}/fossil-src/${repo_id}/${repo_id}.fossil" . || die
+                       einfo fossil pull --repository "${repo_id}.fossil" 
--verbose "${repo_uri}"
+                       fossil pull --repository "${repo_id}.fossil" --verbose 
"${repo_uri}" || die
+                       echo
+               fi
+
+               (
+                       addwrite "${distdir}"
+                       mkdir -p "${distdir}/fossil-src/${repo_id}" || die
+                       cp -p "${repo_id}.fossil" 
"${distdir}/fossil-src/${repo_id}/${repo_id}.fossil" || die
+               )
+       fi
+
+       popd > /dev/null || die
+}
+
+_fossil_checkout() {
+       local distdir="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}"
+       local repo_id="${1}"
+       local branch_or_commit="${2}"
+       local target_directory="${3}"
+
+       local -x FOSSIL_HOME="${HOME}"
+
+       if [[ ! -f "${distdir}/fossil-src/${repo_id}/${repo_id}.fossil" ]]; then
+               die "Clone of repository missing: 
\"${distdir}/fossil-src/${repo_id}/${repo_id}.fossil\""
+       fi
+
+       if [[ ! -f "${T}/fossil/${repo_id}/${repo_id}.fossil" ]]; then
+               mkdir -p "${T}/fossil/${repo_id}" || die
+               cp -p "${distdir}/fossil-src/${repo_id}/${repo_id}.fossil" 
"${T}/fossil/${repo_id}" || die
+       fi
+
+       mkdir "${target_directory}" || die
+       pushd "${target_directory}" > /dev/null || die
+
+       einfo fossil open --quiet "${T}/fossil/${repo_id}/${repo_id}.fossil" 
"${branch_or_commit}"
+       fossil open --quiet "${T}/fossil/${repo_id}/${repo_id}.fossil" 
"${branch_or_commit}" || die
+       echo
+
+       popd > /dev/null || die
+}
+
+fossil_fetch() {
+       local repo_id="${1}"
+       local repo_uri="${2}"
+       local target_directory="${3}"
+
+       local branch_or_commit="${EFOSSIL_COMMIT:-${EFOSSIL_BRANCH:-trunk}}"
+
+       _fossil_fetch "${repo_id}" "${repo_uri}"
+       _fossil_checkout "${repo_id}" "${branch_or_commit}" 
"${target_directory}"
+}
+
+src_unpack() {
+       if [[ ${PV} == 9999 ]]; then
+               fossil_fetch sqlite https://sqlite.org/src "${WORKDIR}/${PN}"
+               if use doc; then
+                       fossil_fetch sqlite-doc https://sqlite.org/docsrc 
"${WORKDIR}/${PN}-doc"
+               fi
+       else
+               default
+       fi
+}
+
+src_prepare() {
+
+       # Avoid stripping during the install phase
+       sed -i -e 's/$(INSTALL) -s /$(INSTALL) /' main.mk || die
+       default
+
+       multilib_copy_sources
+}
+
+multilib_src_configure() {
+       local -x CPPFLAGS="${CPPFLAGS}" CFLAGS="${CFLAGS}"
+       local options=()
+
+       options+=(
+               --enable-load-extension
+               --enable-threadsafe
+       )
+
+       # Support detection of misuse of SQLite API.
+       # https://sqlite.org/compile.html#enable_api_armor
+       append-cppflags -DSQLITE_ENABLE_API_ARMOR
+
+       # Support bytecode and tables_used virtual tables.
+       # https://sqlite.org/compile.html#enable_bytecode_vtab
+       # https://sqlite.org/bytecodevtab.html
+       append-cppflags -DSQLITE_ENABLE_BYTECODE_VTAB
+
+       # Support column metadata functions.
+       # https://sqlite.org/compile.html#enable_column_metadata
+       # 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
+       # https://sqlite.org/dbpage.html
+       append-cppflags -DSQLITE_ENABLE_DBPAGE_VTAB
+
+       # Support dbstat virtual table.
+       # https://sqlite.org/compile.html#enable_dbstat_vtab
+       # 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/compile.html#enable_fts3
+       # https://sqlite.org/compile.html#enable_fts3_parenthesis
+       # https://sqlite.org/compile.html#enable_fts4
+       # https://sqlite.org/compile.html#enable_fts5
+       # 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 memsys5 memory allocator.
+       # https://sqlite.org/compile.html#enable_memsys5
+       # 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/compile.html#enable_offset_sql_func
+       # https://sqlite.org/lang_corefunc.html#sqlite_offset
+       append-cppflags -DSQLITE_ENABLE_OFFSET_SQL_FUNC
+
+       # Support pre-update hook functions.
+       # https://sqlite.org/compile.html#enable_preupdate_hook
+       # https://sqlite.org/c3ref/preupdate_count.html
+       append-cppflags -DSQLITE_ENABLE_PREUPDATE_HOOK
+
+       # Support Resumable Bulk Update extension.
+       # https://sqlite.org/compile.html#enable_rbu
+       # https://sqlite.org/rbu.html
+       append-cppflags -DSQLITE_ENABLE_RBU
+
+       # Support R*Trees.
+       # https://sqlite.org/compile.html#enable_rtree
+       # https://sqlite.org/compile.html#enable_geopoly
+       # https://sqlite.org/rtree.html
+       # https://sqlite.org/geopoly.html
+       append-cppflags -DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_GEOPOLY
+
+       # Support Session extension.
+       # https://sqlite.org/compile.html#enable_session
+       # https://sqlite.org/sessionintro.html
+       append-cppflags -DSQLITE_ENABLE_SESSION
+
+       # Support scan status functions.
+       # https://sqlite.org/compile.html#enable_stmt_scanstatus
+       # 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/compile.html#enable_stmtvtab
+       # https://sqlite.org/stmt.html
+       append-cppflags -DSQLITE_ENABLE_STMTVTAB
+
+       # 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/compile.html#enable_unlock_notify
+       # https://sqlite.org/c3ref/unlock_notify.html
+       # 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
+       # 
https://sqlite.org/lang_delete.html#optional_limit_and_order_by_clauses
+       # 
https://sqlite.org/lang_update.html#optional_limit_and_order_by_clauses
+       append-cppflags -DSQLITE_ENABLE_UPDATE_DELETE_LIMIT
+
+       # Support soundex() function.
+       # https://sqlite.org/compile.html#soundex
+       # https://sqlite.org/lang_corefunc.html#soundex
+       append-cppflags -DSQLITE_SOUNDEX
+
+       # Support URI filenames.
+       # https://sqlite.org/compile.html#use_uri
+       # https://sqlite.org/uri.html
+       append-cppflags -DSQLITE_USE_URI
+
+       options+=( $(use_enable debug) )
+
+       if use icu; then
+               # Support ICU extension.
+               # https://sqlite.org/compile.html#enable_icu
+               append-cppflags -DSQLITE_ENABLE_ICU
+               sed -e "s/^TLIBS = @LIBS@/& -licui18n -licuuc/" -i Makefile.in 
|| die "sed failed"
+       fi
+
+       options+=(
+               --disable-editline
+               $(use_enable readline)
+       )
+
+       if use readline; then
+               options+=( 
--with-readline-inc="-I${ESYSROOT}/usr/include/readline" )
+       fi
+
+       if use secure-delete; then
+               # Enable secure_delete pragma by default.
+               # https://sqlite.org/compile.html#secure_delete
+               # https://sqlite.org/pragma.html#pragma_secure_delete
+               append-cppflags -DSQLITE_SECURE_DELETE
+       fi
+
+       options+=( $(use_enable static-libs static) )
+
+       # tcl, test, tools USE flags.
+       if use tcl || use test || { use tools && multilib_is_native_abi; }; then
+               options+=(
+                       --enable-tcl
+                       --with-tcl="${ESYSROOT}/usr/$(get_libdir)"
+               )
+       else
+               options+=( --disable-tcl )
+       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
+
+       # set SONAME for the library
+       options+=( --soname=legacy )
+
+       # https://sqlite.org/forum/forumpost/4f4d06a9f6683bb9
+       tc-export CC
+       CC_FOR_BUILD=${CC} econf "${options[@]}"
+}
+
+multilib_src_compile() {
+       emake HAVE_TCL="$(usev 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
+
+       if [[ ${PV} == 9999 ]] && use doc && multilib_is_native_abi; then
+               emake tclsqlite3.c
+
+               local build_directory="$(pwd)"
+               build_directory="${build_directory##*/}"
+
+               mkdir "${WORKDIR}/${PN}-doc-build" || die
+               pushd "${WORKDIR}/${PN}-doc-build" > /dev/null || die
+
+               emake -f "../${PN}-doc/Makefile" -j1 SRC="../${PN}" 
BLD="../${build_directory}" DOC="../${PN}-doc" CC="$(tc-getBUILD_CC)" TCLINC="" 
TCLFLAGS="$($(tc-getBUILD_PKG_CONFIG) --libs tcl) -ldl -lm" base doc
+               rmdir doc/matrix{/*,} || die
+
+               popd > /dev/null || die
+       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}"
+
+       # e_uri.test tries to open files in /.
+       # bug #839798
+       local SANDBOX_PREDICT=${SANDBOX_PREDICT}
+       addpredict "/test.db"
+       addpredict "/ÿ.db"
+
+       emake -Onone $(usex debug 'fulltest' '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 "${ED}" -name "*.la" -delete || die
+
+       doman sqlite3.1
+
+       if use doc; then
+               if [[ ${PV} == 9999 ]]; then
+                       pushd "${WORKDIR}/${PN}-doc-build/doc" > /dev/null || 
die
+               else
+                       pushd "${WORKDIR}/${PN}-doc-${DOC_PV}" > /dev/null || 
die
+               fi
+
+               find "(" -name "*.db" -o -name "*.txt" ")" -delete || die
+               if [[ ${PV} != 9999 ]]; then
+                       rm search search.d/admin || die
+                       rmdir search.d || die
+                       find -name "*~" -delete || die
+               fi
+
+               (
+                       docinto html
+                       dodoc -r *
+               )
+
+               popd > /dev/null || die
+       fi
+}

Reply via email to