commit:     d294ec27fc083a99ae9c6d2140d4bb368f09dc6d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 18 04:01:18 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 18 04:01:28 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d294ec27

dev-libs/poco: add 1.12.4

Note that release notes mention a "security issue" but it's
just about bundled libs.

Signed-off-by: Sam James <sam <AT> gentoo.org>

 dev-libs/poco/Manifest           |   1 +
 dev-libs/poco/poco-1.12.4.ebuild | 145 +++++++++++++++++++++++++++++++++++++++
 2 files changed, 146 insertions(+)

diff --git a/dev-libs/poco/Manifest b/dev-libs/poco/Manifest
index 8767155dec9b..be9006b70e27 100644
--- a/dev-libs/poco/Manifest
+++ b/dev-libs/poco/Manifest
@@ -1,3 +1,4 @@
 DIST poco-1.10.1.tar.gz 10224204 BLAKE2B 
644bb2134c571e10b63937ca15b3f5d7255767bcc99dd6b6107a13d64ed7ac83d499d74f04084c666bbf5ef6f033d57d2fb1de0b8b8487844e3aaf8cefe6fba8
 SHA512 
40aa8049c68651f461280937c1c733e13d1cedbec12bc44a7f3a6c131d31229c5445067052441427071f6102fd1965d238b2222c0689279dd156b4e261ac9e73
 DIST poco-1.11.2.tar.gz 10935312 BLAKE2B 
66b4cdb6cb4b5dd4f5f0eee744e1d147d66e98561ec4286ed09693b638d565fbf084c3e40eff3f6a9a88cff167b1d774da08e8c8424986aefe13d029a540afe2
 SHA512 
3f9e46dbfb0a85f19389b269725cb6272172d993d8239f13da8110c0c6ce9ed2b6595708d5dba91a027292c74358c87da988e22587a74011e84707816a6a277c
 DIST poco-1.12.2.tar.gz 11268579 BLAKE2B 
fe23216884d1effb7e93072c5e90d5eabf813c6cf0326af5c4b6d3646d54e5411966485e97d50960df97cd545b3a265eb4b43c1cb041ff97b4457f53f6bd06bc
 SHA512 
86b6b106e9a677397c73139e949a65925e78611cad478fc4206a6a7365613307fc1549b1160faf6ca8f02fb7f7ae58858c3913cb701111b7cbb5ffcbe5363bb3
+DIST poco-1.12.4.tar.gz 11296139 BLAKE2B 
45e1214616e78041d5ca512cee46621c006fe21f51231f3261dc40ca4941eb3cd4e52db493aa826779784f9d3f35cfd08e3e9d08fb35ebec2d610fb6528c635a
 SHA512 
730700a24b5a00d44aa85914e7d3c9eff76969a123a67315ba5e9b2d18c0ace70d2664d8a611496851f497aa4985d36685a67813a95e814461ae0fffdb460d91

diff --git a/dev-libs/poco/poco-1.12.4.ebuild b/dev-libs/poco/poco-1.12.4.ebuild
new file mode 100644
index 000000000000..596b7ffa8933
--- /dev/null
+++ b/dev-libs/poco/poco-1.12.4.ebuild
@@ -0,0 +1,145 @@
+# Copyright 1999-2022 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/94"
+KEYWORDS="~amd64 ~arm ~arm64 ~ppc64 ~x86"
+IUSE="7z activerecord cppparser +data examples +file2pagecompiler iodbc +json 
jwt mariadb +mongodb mysql +net odbc +pagecompiler pdf pocodoc postgres 
prometheus sqlite +ssl test +util +xml +zip"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="
+       7z? ( xml )
+       file2pagecompiler? ( pagecompiler )
+       iodbc? ( odbc )
+       jwt? ( json ssl )
+       mongodb? ( data )
+       mysql? ( data )
+       odbc? ( data )
+       postgres? ( data )
+       pagecompiler? ( json net util xml )
+       pocodoc? ( cppparser util xml )
+       sqlite? ( data )
+       ssl? ( util )
+       test? ( data? ( sqlite ) json util xml )
+"
+
+BDEPEND="virtual/pkgconfig"
+RDEPEND="
+       >=dev-libs/libpcre2-10.40
+       activerecord? ( !app-arch/arc )
+       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 )
+       )
+       sqlite? ( dev-db/sqlite:3 )
+       ssl? (
+               dev-libs/openssl:=
+       )
+       xml? ( dev-libs/expat )
+       zip? ( sys-libs/zlib:= )
+"
+DEPEND="${RDEPEND}"
+
+PATCHES=( "${FILESDIR}/${PN}-1.10.1-iodbc-incdir.patch" )
+
+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,PDF,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
+               # ignore failing Crypto test since upstream does not seem to 
care,
+               # see https://github.com/pocoproject/poco/issues/1209
+               sed -i -e '/RSATest, testRSACipherLarge/d' \
+                       Crypto/testsuite/src/RSATest.cpp || die
+       fi
+
+       # Fix MariaDB and MySQL detection
+       sed -i -e 's~/usr/include/mysql~~' \
+               -e 's/mysqlclient_r/mysqlclient/' \
+               -e 's/STATUS "Couldn/FATAL_ERROR "Couldn/' \
+               cmake/FindMySQL.cmake || die
+
+       # Add missing directory that breaks the build
+       mkdir -p Encodings/testsuite/data || die
+
+       if ! use iodbc ; then
+               sed -i -e 's|iodbc||' cmake/FindODBC.cmake || 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 ssl)"
+               -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_JSON="$(usex util)"
+               -DENABLE_JWT="$(usex jwt)"
+               -DENABLE_MONGODB="$(usex mongodb)"
+               -DENABLE_NET="$(usex net)"
+               -DENABLE_NETSSL="$(usex ssl)"
+               -DENABLE_NETSSL_WIN=OFF
+               -DENABLE_PAGECOMPILER="$(usex pagecompiler)"
+               -DENABLE_PAGECOMPILER_FILE2PAGE="$(usex file2pagecompiler)"
+               -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
+}

Reply via email to