public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Joonas Niilola" <juippis@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-libs/poco/
Date: Fri, 03 Jan 2025 16:41:17 +0000 (UTC)	[thread overview]
Message-ID: <1735921569.96d3238f330bb3491fbfbad4984aa6969d1c4c04.juippis@gentoo> (raw)

commit:     96d3238f330bb3491fbfbad4984aa6969d1c4c04
Author:     David Roman <droman <AT> ifae <DOT> es>
AuthorDate: Mon Dec  2 16:09:12 2024 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Fri Jan  3 16:26:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=96d3238f

dev-libs/poco: add 1.14.0

Added avahi support

USE changes: "ssl" has been renamed to "crypt" while "jwt" has been dropped.
Previously "ssl" enabled POCO_SSL and POCO_CRYPTO modules.
Now "crypt" enables both of them plus POCO_JWT module.

Closes: https://bugs.gentoo.org/939410
Closes: https://bugs.gentoo.org/940705
Signed-off-by: David Roman <droman <AT> ifae.es>
Closes: https://github.com/gentoo/gentoo/pull/39567
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>

 dev-libs/poco/Manifest           |   1 +
 dev-libs/poco/metadata.xml       |   6 +-
 dev-libs/poco/poco-1.14.0.ebuild | 138 +++++++++++++++++++++++++++++++++++++++
 3 files changed, 143 insertions(+), 2 deletions(-)

diff --git a/dev-libs/poco/Manifest b/dev-libs/poco/Manifest
index dded174642a2..2350488f1bdf 100644
--- a/dev-libs/poco/Manifest
+++ b/dev-libs/poco/Manifest
@@ -1,2 +1,3 @@
 DIST poco-1.12.4.tar.gz 11296139 BLAKE2B 45e1214616e78041d5ca512cee46621c006fe21f51231f3261dc40ca4941eb3cd4e52db493aa826779784f9d3f35cfd08e3e9d08fb35ebec2d610fb6528c635a SHA512 730700a24b5a00d44aa85914e7d3c9eff76969a123a67315ba5e9b2d18c0ace70d2664d8a611496851f497aa4985d36685a67813a95e814461ae0fffdb460d91
 DIST poco-1.13.3.tar.gz 11332562 BLAKE2B 04380cae92bbd2427873f0ea1a3fcade244ee5168390e26081983ded9faaf22e456bdd4ae87f9c77bafc92155f860ea9f56678ec2204bcd7c51a871e7f00d759 SHA512 084064fb462c9e7993d069ebdf395802af900ed92c5b294465a2c246162bb86caa3505985de329e8110d3e9fb3bc39ae9536d523843729d4ed5ce00c35289d92
+DIST poco-1.14.0.tar.gz 12158142 BLAKE2B 3ae9a520941634ac9aa72d323541d6433ac2e73d4d19e0654f932ea031d17870ca4ad764a8e3c5e68d69c5dc9750d779102d80d6d810598db275f269928ae8ea SHA512 4475a0ede5d06e4ce9537295fec92fa39b8fd5635d1cfb38498be4f707bc62b4a8b57672d2a15b557114e4115cc45480d27d0c856b7bd982eeec7adad9ff2582

diff --git a/dev-libs/poco/metadata.xml b/dev-libs/poco/metadata.xml
index f73e85906ed1..b46a644c0216 100644
--- a/dev-libs/poco/metadata.xml
+++ b/dev-libs/poco/metadata.xml
@@ -31,12 +31,14 @@ done quickly and working on the features that make their application unique.
 	</upstream>
 	<use>
 		<flag name="7z">Add Support for the 7z archive format</flag>
+		<flag name="avahi">Add Support for avahi DNS-SD (zeroconf)</flag>
 		<flag name="activerecord">Add ActiveRecord support</flag>
 		<flag name="cppparser">Build and install a minimal C++ parser</flag>
+		<flag name="crypt">Encryption and digital signing classes (including SSL and JWT).</flag>
 		<flag name="data">Database abstraction layer to easily send/retrieve data to/from various databases</flag>
 		<flag name="file2pagecompiler">Utility to convert ordinary files to Page Compiler source files</flag>
 		<flag name="json">Add JSON support</flag>
-		<flag name="jwt" restrict="&gt;=dev-libs/poco-1.12.2-r1">Add JSON Web Token support</flag>
+		<flag name="jwt">Add JSON Web Token support</flag>
 		<flag name="mariadb">Prefer <pkg>dev-db/mariadb-connector-c</pkg> over <pkg>dev-db/mysql-connector-c</pkg></flag>
 		<flag name="mongodb">Add <pkg>dev-db/mongodb</pkg> support</flag>
 		<flag name="net">Classes to write network clients &amp; servers</flag>
@@ -44,7 +46,7 @@ done quickly and working on the features that make their application unique.
 		<flag name="pocodoc">POCO documentation generator</flag>
 		<flag name="prometheus">Add prometheus monitoring system support</flag>
 		<flag name="ssl">Encryption and digital signing classes</flag>
-		<flag name="util">Several utility classes (like logger, timer, config file parser)</flag>
+		<flag name="util">Several utility classes (like logger, timer, config file parser). Also enables JSON</flag>
 		<flag name="zip">Add support for the zip &amp; gz archive formats</flag>
 	</use>
 </pkgmetadata>

diff --git a/dev-libs/poco/poco-1.14.0.ebuild b/dev-libs/poco/poco-1.14.0.ebuild
new file mode 100644
index 000000000000..45f56a16572c
--- /dev/null
+++ b/dev-libs/poco/poco-1.14.0.ebuild
@@ -0,0 +1,138 @@
+# Copyright 1999-2025 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/110"
+KEYWORDS="~amd64 ~arm ~arm64 ~ppc64 ~x86"
+IUSE="7z activerecord avahi cppparser +crypt +data examples +file2pagecompiler 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 )
+	file2pagecompiler? ( pagecompiler )
+	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? ( sys-libs/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
+
+	sed -i 's/ENABLE_DNSSD_AVHAI/ENABLE_DNSSD_AVAHI/' DNSSD/CMakeLists.txt || die
+}
+
+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 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	other threads:[~2025-01-03 16:41 UTC|newest]

Thread overview: 64+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-01-03 16:41 Joonas Niilola [this message]
  -- strict thread matches above, loose matches on Subject: below --
2025-02-15 19:39 [gentoo-commits] repo/gentoo:master commit in: dev-libs/poco/ Jakov Smolić
2025-02-13 17:51 Sam James
2025-02-13 17:51 Sam James
2025-02-13 17:51 Sam James
2025-02-13 17:51 Sam James
2025-02-13 13:48 Sam James
2025-02-13 13:48 Sam James
2025-01-03 16:41 Joonas Niilola
2024-06-11 17:58 Sam James
2024-06-11 17:58 Sam James
2024-06-11 17:18 Sam James
2024-06-11 17:18 Sam James
2024-06-11 16:54 Sam James
2024-05-10  6:20 Arthur Zamarin
2024-05-10  6:20 Arthur Zamarin
2024-05-10  6:20 Arthur Zamarin
2024-01-15  3:32 Ionen Wolkens
2023-12-14  4:15 Sam James
2023-10-05 14:33 Joonas Niilola
2023-08-15 12:17 Joonas Niilola
2023-07-26  5:16 Joonas Niilola
2023-07-26  5:16 Joonas Niilola
2023-07-25 18:14 Arthur Zamarin
2022-12-24  8:59 Andreas Sturmlechner
2022-12-18  4:20 Sam James
2022-12-18  4:20 Sam James
2022-11-15  8:46 Sam James
2022-11-15  8:46 Sam James
2022-11-15  8:46 Sam James
2022-10-25 18:48 Arthur Zamarin
2022-10-25 18:48 Arthur Zamarin
2022-10-24  7:12 Joonas Niilola
2022-10-12 19:22 Sam James
2022-10-10 13:18 Joonas Niilola
2022-10-10 13:18 Joonas Niilola
2022-09-05 14:36 Jakov Smolić
2022-06-23  9:23 Joonas Niilola
2022-06-23  9:23 Joonas Niilola
2022-05-10 19:53 Florian Schmaus
2022-05-06  7:47 Sam James
2022-02-14 20:45 Sam James
2022-02-14  0:55 Sam James
2021-10-10 23:17 Sam James
2021-06-03 22:52 Sam James
2021-06-02 19:01 Sam James
2021-05-02 15:38 Mikle Kolyada
2020-11-24  3:47 Sam James
2019-10-11 18:28 Andreas Sturmlechner
2019-10-10 18:57 Andreas Sturmlechner
2019-07-17 13:59 Agostino Sarubbo
2019-07-16 10:21 Hans de Graaff
2019-07-16 10:21 Hans de Graaff
2019-04-07 21:45 Mikle Kolyada
2019-03-24 10:01 Agostino Sarubbo
2019-03-23 12:25 Pacho Ramos
2019-03-23 12:25 Pacho Ramos
2019-02-10  3:00 Brian Evans
2019-01-07 19:15 Lars Wendler
2018-11-22 23:16 Michał Górny
2018-06-23 21:55 Aaron Bauman
2018-06-15 20:01 Vladimir Smirnov
2018-04-13 23:22 Aaron Bauman
2015-10-05  8:45 Julian Ospald

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1735921569.96d3238f330bb3491fbfbad4984aa6969d1c4c04.juippis@gentoo \
    --to=juippis@gentoo.org \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox