diff options
| author | Dima Panov <fluffy@FreeBSD.org> | 2024-11-20 12:22:33 +0300 |
|---|---|---|
| committer | Dima Panov <fluffy@FreeBSD.org> | 2024-11-20 13:05:18 +0300 |
| commit | a48821ad273386ac6731a3903f954e7dcdc1009c (patch) | |
| tree | c4776bad39d6b1afe0fce3c2afd21df5df33028e /net/libcmis/files/patch-boost-1.86 | |
| parent | devel/boost: update to 1.86.0 release (+) (diff) | |
net/libcmis: fix build with boost-1.86
Sponsored by: Future Crew, LLC
Diffstat (limited to 'net/libcmis/files/patch-boost-1.86')
| -rw-r--r-- | net/libcmis/files/patch-boost-1.86 | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/net/libcmis/files/patch-boost-1.86 b/net/libcmis/files/patch-boost-1.86 new file mode 100644 index 000000000000..0f416e5e3fa1 --- /dev/null +++ b/net/libcmis/files/patch-boost-1.86 @@ -0,0 +1,47 @@ +https://github.com/tdf/libcmis/issues/67 +https://github.com/tdf/libcmis/pull/68 + +From dfcb642a491f7ec2ae52e3e83d31bb6cdf3670c2 Mon Sep 17 00:00:00 2001 +From: David Seifert <soap@gentoo.org> +Date: Sat, 31 Aug 2024 12:39:39 +0200 +Subject: [PATCH] Fix boost 1.86 breakage + +The fix does not break building against <1.86 since we're now accessing the +object representation of the return value. + +Fixes #67 +--- + src/libcmis/xml-utils.cxx | 14 ++++++++++---- + 1 file changed, 10 insertions(+), 4 deletions(-) + +diff --git src/libcmis/xml-utils.cxx src/libcmis/xml-utils.cxx +index e487d17..cdf088f 100644 +--- src/libcmis/xml-utils.cxx ++++ src/libcmis/xml-utils.cxx +@@ -531,16 +531,22 @@ namespace libcmis + boost::uuids::detail::sha1 sha1; + sha1.process_bytes( str.c_str(), str.size() ); + +- unsigned int digest[5]; ++ // on boost < 1.86.0, digest_type is typedef'd as unsigned int[5] ++ // on boost >= 1.86.0, digest_type is typedef'd as unsigned char[20] ++ boost::uuids::detail::sha1::digest_type digest; + sha1.get_digest( digest ); + ++ // by using a pointer to unsigned char, we can read the ++ // object representation of either typedef. ++ const unsigned char* ptr = reinterpret_cast<const unsigned char*>( digest ); ++ + stringstream out; +- // Setup writing mode. Every number must produce eight ++ // Setup writing mode. Every number must produce two + // hexadecimal digits, including possible leading 0s, or we get + // less than 40 digits as result. + out << hex << setfill('0') << right; +- for ( int i = 0; i < 5; ++i ) +- out << setw(8) << digest[i]; ++ for ( int i = 0; i < sizeof( digest ); ++ptr, ++i ) ++ out << setw(2) << static_cast<int>( *ptr ); + return out.str(); + } + |
