commit:     057ef5f7fb628c2ed24a37b0b50d62be04bb4af6
Author:     Oliver Freyermuth <o.freyermuth <AT> googlemail <DOT> com>
AuthorDate: Thu Dec 18 18:34:41 2025 +0000
Commit:     Guilherme Amadio <amadio <AT> gentoo <DOT> org>
CommitDate: Tue Jan 13 13:07:53 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=057ef5f7

dev-cpp/jwt-cpp: add 0.7.1

Closes: https://bugs.gentoo.org/964511
Signed-off-by: Oliver Freyermuth <o.freyermuth <AT> googlemail.com>
Signed-off-by: Guilherme Amadio <amadio <AT> gentoo.org>

 dev-cpp/jwt-cpp/Manifest                           |  1 +
 .../files/jwt-cpp-0.7.1-cmake-minversion.patch     | 42 +++++++++++
 dev-cpp/jwt-cpp/jwt-cpp-0.7.1.ebuild               | 83 ++++++++++++++++++++++
 3 files changed, 126 insertions(+)

diff --git a/dev-cpp/jwt-cpp/Manifest b/dev-cpp/jwt-cpp/Manifest
index 056eade7e21c..552238a059bb 100644
--- a/dev-cpp/jwt-cpp/Manifest
+++ b/dev-cpp/jwt-cpp/Manifest
@@ -1 +1,2 @@
 DIST jwt-cpp-0.6.0.tar.gz 275126 BLAKE2B 
4bf9bed9b2aa9584b497b2ab4d1d2582d9b5e4ded402200ea3f70b0e6752338fd4e2ef9c5836c728a6907a0190209c7baeaecd26032ce64dc6bf12a23594f27b
 SHA512 
b6d5ebb3a7eeb6fef9a1d41c707251d1ab05bf47920c280d5203f1b9ee5bf6f8e914cd2ffaed66550cfa6d78c34465d4cf86517a759d5f8739b429faf1c2c0ef
+DIST jwt-cpp-0.7.1.tar.gz 159954 BLAKE2B 
af90d42349404fbb0955e4cd677361a34afd1dbf8776b8ac66df68163c99a7e32344964a92e7942bf02a26553ceac341287abb70abda932ef260824c58843e9c
 SHA512 
1d52816e4d04a50c57e3655e1ebd0fa4e54d03aef49950b800c9c43715cdaceec7a572a02ffff5d358d5f8cde242112da06804fc7a53bc154b3860cf133716a0

diff --git a/dev-cpp/jwt-cpp/files/jwt-cpp-0.7.1-cmake-minversion.patch 
b/dev-cpp/jwt-cpp/files/jwt-cpp-0.7.1-cmake-minversion.patch
new file mode 100644
index 000000000000..32f88080dd29
--- /dev/null
+++ b/dev-cpp/jwt-cpp/files/jwt-cpp-0.7.1-cmake-minversion.patch
@@ -0,0 +1,42 @@
+From 3972ac2d1773087fa9cebafebbb94e8e781481ea Mon Sep 17 00:00:00 2001
+From: Oliver Freyermuth <[email protected]>
+Date: Sat, 25 Oct 2025 02:43:17 +0200
+Subject: [PATCH] CMake: synchronize cmake_minimum_required from main
+ CMakeLists.txt (#398)
+
+The examples have been using older cmake_minimum_required,
+given support for versions <3.10 is deprecated since 3.31,
+synchronize the minimum required version from the main CMakeLists.txt
+(version 3.14) into examples and tests.
+
+closes #397
+---
+ example/CMakeLists.txt        | 2 +-
+ example/traits/CMakeLists.txt | 2 +-
+ tests/cmake/CMakeLists.txt    | 2 +-
+ 3 files changed, 3 insertions(+), 3 deletions(-)
+
+--- a/example/CMakeLists.txt
++++ b/example/CMakeLists.txt
+@@ -1,4 +1,4 @@
+-cmake_minimum_required(VERSION 3.8)
++cmake_minimum_required(VERSION 3.14)
+ project(jwt-cpp-examples)
+ 
+ if(NOT TARGET jwt-cpp)
+--- a/example/traits/CMakeLists.txt
++++ b/example/traits/CMakeLists.txt
+@@ -1,4 +1,4 @@
+-cmake_minimum_required(VERSION 3.8)
++cmake_minimum_required(VERSION 3.14)
+ project(jwt-cpp-traits)
+ 
+ if(NOT TARGET jwt-cpp)
+--- a/tests/cmake/CMakeLists.txt
++++ b/tests/cmake/CMakeLists.txt
+@@ -1,4 +1,4 @@
+-cmake_minimum_required(VERSION 3.8)
++cmake_minimum_required(VERSION 3.14)
+ project(jwt-cpp-installation-tests)
+ 
+ set(TEST CACHE STRING "The test source file to be used")

diff --git a/dev-cpp/jwt-cpp/jwt-cpp-0.7.1.ebuild 
b/dev-cpp/jwt-cpp/jwt-cpp-0.7.1.ebuild
new file mode 100644
index 000000000000..4c717e017c89
--- /dev/null
+++ b/dev-cpp/jwt-cpp/jwt-cpp-0.7.1.ebuild
@@ -0,0 +1,83 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit cmake
+
+if [[ ${PV} == *9999* ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/Thalhammer/jwt-cpp.git";
+else
+       
SRC_URI="https://github.com/Thalhammer/${PN}/archive/refs/tags/v${PV}.tar.gz -> 
${P}.tar.gz"
+       KEYWORDS="amd64 x86"
+fi
+
+DESCRIPTION="header only library for creating and validating JSON Web Tokens 
in C++11"
+HOMEPAGE="https://thalhammer.github.io/jwt-cpp/";
+
+LICENSE="MIT"
+SLOT="0"
+IUSE="doc +picojson test"
+
+DEPEND="
+       dev-cpp/nlohmann_json
+       dev-libs/openssl
+       picojson? ( dev-cpp/picojson )
+"
+RDEPEND="${DEPEND}"
+BDEPEND="
+       doc? ( app-text/doxygen[dot] )
+       test? ( dev-cpp/gtest )
+"
+RESTRICT="
+       !picojson? ( test )
+       !test? ( test )
+"
+PATCHES=(
+       "${FILESDIR}"/${PN}-0.7.1-cmake-minversion.patch
+)
+DOCS=( README.md docs/{faqs,ssl,traits}.md )
+
+src_prepare() {
+       # Unbundle dev-cpp/nlohmann_json.
+       rm -vrf include/nhlomann || die
+       # Unbundle dev-cpp/picojson and fix include paths.
+       # See also: https://github.com/Thalhammer/jwt-cpp/issues/213
+       rm -vrf include/picojson || die
+       find -name '*.h' -type f -print0 | xargs -0 sed -r -e 
"s:picojson/picojson\.h:picojson.h:g" -i || die
+       # Prevent installation of bundled dev-cpp/picojson.
+       sed -i -e 's:^\s*install.*picojson/picojson\.h.*$::' CMakeLists.txt || 
die
+       cmake_src_prepare
+}
+
+src_configure() {
+       local mycmakeargs=(
+                       -DJWT_EXTERNAL_NLOHMANN_JSON=YES
+                       -DJWT_DISABLE_PICOJSON="$(usex !picojson)"
+                       # Not useful for now, asks for non-existent CMake 
module.
+                       #-DJWT_EXTERNAL_PICOJSON="$(usex picojson)"
+                       # Examples are not installed and for development only.
+                       -DJWT_BUILD_EXAMPLES=NO
+                       -DJWT_BUILD_TESTS="$(usex test)"
+                       
-DJWT_CMAKE_FILES_INSTALL_DIR="${EPREFIX}"/usr/share/cmake
+                       )
+       cmake_src_configure
+}
+
+src_compile() {
+       cmake_src_compile
+       if use doc; then
+               doxygen || die
+       fi
+}
+
+src_test() {
+       "${BUILD_DIR}"/tests/jwt-cpp-test || die
+}
+
+src_install() {
+       cmake_src_install
+       use doc && local HTML_DOCS=(doxy/html/.)
+       einstalldocs
+}

Reply via email to