commit: e3d1b831e94c81f039f8d4f02daa2b90deace5ea Author: David Roman <droman <AT> ifae <DOT> es> AuthorDate: Mon Feb 16 11:09:24 2026 +0000 Commit: Arthur Zamarin <arthurzam <AT> gentoo <DOT> org> CommitDate: Tue Feb 17 20:03:36 2026 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e3d1b831
dev-libs/poco: add 1.15.0 Signed-off-by: David Roman <droman <AT> ifae.es> Part-of: https://codeberg.org/gentoo/gentoo/pulls/73 Merges: https://codeberg.org/gentoo/gentoo/pulls/73 Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org> dev-libs/poco/Manifest | 1 + dev-libs/poco/poco-1.15.0.ebuild | 135 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 136 insertions(+) diff --git a/dev-libs/poco/Manifest b/dev-libs/poco/Manifest index 3908c8f15084..1f7613129751 100644 --- a/dev-libs/poco/Manifest +++ b/dev-libs/poco/Manifest @@ -1 +1,2 @@ DIST poco-1.14.2.tar.gz 12179163 BLAKE2B cc6bf5a9daa625f0de08b5bf2934c644fffa474578c075e2017a8f4ec12d47a322cc7dec3a1f44cc39d7012a54d01ec7601de4562a4826debd187e6c03b105a0 SHA512 3bd90fd270f8becc583e6615a9399a2abe6f1e06fd42cbb33fb8eac061ac29ba36c3831f0a88451c173c1fa0ef2505ddd773c29c842e4924be835f4f570b1468 +DIST poco-1.15.0.tar.gz 11214675 BLAKE2B f9a9b26cff7f7d9086475fc2e6ace4a82bd40d847c03459482717cfd1d08d269238a0166aaf14b69b4d94e4ab77a92f21a578859432ecb96fe746b89180d9acd SHA512 97aef122d28157cbf0990400290bbb6667cfac3207fa6144239a6c1868427e5531895a333d95eeec968b2cc55168dad977b74f76d5b80f9cd75a16b6f2d50552 diff --git a/dev-libs/poco/poco-1.15.0.ebuild b/dev-libs/poco/poco-1.15.0.ebuild new file mode 100644 index 000000000000..8efb73b02656 --- /dev/null +++ b/dev-libs/poco/poco-1.15.0.ebuild @@ -0,0 +1,135 @@ +# Copyright 1999-2026 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +inherit cmake + +DESCRIPTION="C++ libraries for building network-based applications" +HOMEPAGE="https://pocoproject.org/" +SRC_URI="https://github.com/pocoproject/${PN}/archive/${P}-release.tar.gz -> ${P}.tar.gz" +S="${WORKDIR}/${PN}-${P}-release" + +LICENSE="Boost-1.0" +# SHARED_LIBRARY_VERSION -> "${S}"/libversion +SLOT="0/120" +KEYWORDS="~amd64 ~arm ~arm64 ~ppc64 ~x86" +IUSE="7z activerecord avahi cppparser +crypt +data examples iodbc mariadb +mongodb mysql +net odbc +pagecompiler pdf pocodoc postgres prometheus sqlite test +util +xml +zip" +RESTRICT="!test? ( test )" +REQUIRED_USE=" + activerecord? ( util xml ) + 7z? ( xml ) + iodbc? ( odbc ) + mongodb? ( data ) + mysql? ( data ) + odbc? ( data ) + postgres? ( data ) + pagecompiler? ( net util xml ) + pocodoc? ( cppparser util xml ) + sqlite? ( data ) + crypt? ( util ) + test? ( data? ( sqlite ) activerecord cppparser crypt pdf prometheus xml ) +" + +BDEPEND=" + virtual/pkgconfig +" + +RDEPEND=" + >=dev-libs/libpcre2-10.40:= + dev-libs/libutf8proc:= + + activerecord? ( !app-arch/arc ) + avahi? ( net-dns/avahi:= ) + mysql? ( dev-db/mysql-connector-c:= ) + mariadb? ( dev-db/mariadb-connector-c:= ) + postgres? ( dev-db/postgresql:= ) + odbc? ( + iodbc? ( dev-db/libiodbc ) + !iodbc? ( dev-db/unixODBC ) + ) + pdf? ( media-libs/libpng:= ) + sqlite? ( dev-db/sqlite:3 ) + crypt? ( + dev-libs/openssl:= + ) + xml? ( dev-libs/expat ) + zip? ( virtual/zlib:= ) +" +DEPEND="${RDEPEND}" + +src_prepare() { + cmake_src_prepare + + if [[ ${SLOT} != 0/$(< "${S}"/libversion) ]] ; then + die "Please update subslot in ebuild to the version in ${S}/libversion" + fi + + if use test ; then + # ignore missing tests on experimental library + # and tests requiring running DB-servers, internet connections, etc. + sed -i -e '/testsuite/d' \ + {Data/{,MySQL,ODBC},MongoDB,Net,NetSSL_OpenSSL,Redis}/CMakeLists.txt || die + + # Poco expands ~ using passwd, which does not match $HOME in the build environment + sed -i -e '/CppUnit_addTest.*testExpand/d' \ + Foundation/testsuite/src/PathTest.cpp || die + fi +} + +src_configure() { + # apache support is dead and buggy, https://github.com/pocoproject/poco/issues/1764 + local mycmakeargs=( + -DPOCO_UNBUNDLED=ON + -DENABLE_APACHECONNECTOR=OFF + -DENABLE_ACTIVERECORD="$(usex activerecord)" + -DENABLE_ACTIVERECORD_COMPILER="$(usex activerecord)" + -DENABLE_CPPPARSER="$(usex cppparser)" + -DENABLE_CRYPTO="$(usex crypt)" + -DENABLE_DATA="$(usex data)" + -DENABLE_DATA_MYSQL="$(usex mysql)" + -DENABLE_DATA_ODBC="$(usex odbc)" + -DENABLE_DATA_POSTGRESQL="$(usex postgres)" + -DENABLE_DATA_SQLITE="$(usex sqlite)" + -DENABLE_DNSSD="$(usex avahi)" + -DENABLE_DNSSD_AVAHI="$(usex avahi)" + -DENABLE_JSON="$(usex util)" + -DENABLE_JWT="$(usex crypt)" + -DENABLE_MONGODB="$(usex mongodb)" + -DENABLE_NET="$(usex net)" + -DENABLE_NETSSL="$(usex crypt)" + -DENABLE_NETSSL_WIN=OFF + -DENABLE_PAGECOMPILER="$(usex pagecompiler)" + -DENABLE_PAGECOMPILER_FILE2PAGE="$(usex pagecompiler)" + -DENABLE_PDF="$(usex pdf)" + -DENABLE_POCODOC="$(usex pocodoc)" + -DENABLE_PROMETHEUS="$(usex prometheus)" + -DENABLE_SEVENZIP="$(usex 7z)" + -DENABLE_TESTS="$(usex test)" + -DENABLE_UTIL="$(usex util)" + -DENABLE_XML="$(usex xml)" + -DENABLE_ZIP="$(usex zip)" + ) + + cmake_src_configure +} + +src_test() { + POCO_BASE="${S}" cmake_src_test -E DataPostgreSQL +} + +src_install() { + cmake_src_install + + if use examples ; then + for sd in */samples ; do + docinto examples/${sd%/samples} + dodoc -r ${sd} + done + + find "${D}/usr/share/doc/${PF}/examples" \ + -iname "*.sln" -or -iname "*.vcproj" -or \ + -iname "*.vmsbuild" -or -iname "*.properties" \ + | xargs rm -v || die + fi +}
