mirror of
https://git.freebsd.org/ports.git
synced 2025-04-28 09:36:41 -04:00
As noted in the libc++ 19 release notes [1], std::char_traits<> is now only provided for char, char8_t, char16_t, char32_t and wchar_t, and any instantiation for other types will fail. This causes ports using devel/py-Levenshtein to fail to compile with clang 19 and libc++ 19, resulting in errors similar to: /usr/include/c++/v1/string:820:42: error: implicit instantiation of undefined template 'std::char_traits<unsigned int>' 820 | static_assert(is_same<_CharT, typename traits_type::char_type>::value, | ^ /wrkdirs/usr/ports/devel/py-Levenshtein/work-py311/Levenshtein-0.22.0/src/Levenshtein/Levenshtein-c/_levenshtein.hpp:144:43: note: in instantiation of template class 'std::basic_string<unsigned int>' requested here 144 | static inline std::basic_string<uint32_t> lev_greedy_median(const std::vector<RF_String>& strings, | ^ /usr/include/c++/v1/__fwd/string.h:23:29: note: template is declared here 23 | struct _LIBCPP_TEMPLATE_VIS char_traits; | ^ Unfortunately py-Levenshtein and its embedded copy of rapidfuzz-cpp make heavy use of the no-longer-existing `std::basic_string<uint8_t>`, so I had to do quite a lots of search and replace operations, replacing these with equivalent `std::vector` types. This is similar to the fixes for devel/rapidfuzz-cpp in bug 281193, and for devel/py-rapidfuzz in bug 281194. [1] https://libcxx.llvm.org/ReleaseNotes/19.html#deprecations-and-removals PR: 281534 Approved by: maintainer timeout (2 weeks) MFH: 2024Q3
53 lines
2.5 KiB
C++
53 lines
2.5 KiB
C++
--- extern/rapidfuzz-cpp/rapidfuzz/distance.hpp.orig 2023-09-26 11:15:29 UTC
|
|
+++ extern/rapidfuzz-cpp/rapidfuzz/distance.hpp
|
|
@@ -16,13 +16,13 @@ template <typename CharT, typename InputIt1, typename
|
|
namespace rapidfuzz {
|
|
|
|
template <typename CharT, typename InputIt1, typename InputIt2>
|
|
-std::basic_string<CharT> editops_apply(const Editops& ops, InputIt1 first1, InputIt1 last1, InputIt2 first2,
|
|
- InputIt2 last2)
|
|
+std::vector<CharT> editops_apply(const Editops& ops, InputIt1 first1, InputIt1 last1, InputIt2 first2,
|
|
+ InputIt2 last2)
|
|
{
|
|
auto len1 = static_cast<size_t>(std::distance(first1, last1));
|
|
auto len2 = static_cast<size_t>(std::distance(first2, last2));
|
|
|
|
- std::basic_string<CharT> res_str;
|
|
+ std::vector<CharT> res_str;
|
|
res_str.resize(len1 + len2);
|
|
size_t src_pos = 0;
|
|
size_t dest_pos = 0;
|
|
@@ -62,20 +62,20 @@ template <typename CharT, typename Sentence1, typename
|
|
}
|
|
|
|
template <typename CharT, typename Sentence1, typename Sentence2>
|
|
-std::basic_string<CharT> editops_apply(const Editops& ops, const Sentence1& s1, const Sentence2& s2)
|
|
+std::vector<CharT> editops_apply(const Editops& ops, const Sentence1& s1, const Sentence2& s2)
|
|
{
|
|
return editops_apply<CharT>(ops, detail::to_begin(s1), detail::to_end(s1), detail::to_begin(s2),
|
|
detail::to_end(s2));
|
|
}
|
|
|
|
template <typename CharT, typename InputIt1, typename InputIt2>
|
|
-std::basic_string<CharT> opcodes_apply(const Opcodes& ops, InputIt1 first1, InputIt1 last1, InputIt2 first2,
|
|
- InputIt2 last2)
|
|
+std::vector<CharT> opcodes_apply(const Opcodes& ops, InputIt1 first1, InputIt1 last1, InputIt2 first2,
|
|
+ InputIt2 last2)
|
|
{
|
|
auto len1 = static_cast<size_t>(std::distance(first1, last1));
|
|
auto len2 = static_cast<size_t>(std::distance(first2, last2));
|
|
|
|
- std::basic_string<CharT> res_str;
|
|
+ std::vector<CharT> res_str;
|
|
res_str.resize(len1 + len2);
|
|
size_t dest_pos = 0;
|
|
|
|
@@ -101,7 +101,7 @@ template <typename CharT, typename Sentence1, typename
|
|
}
|
|
|
|
template <typename CharT, typename Sentence1, typename Sentence2>
|
|
-std::basic_string<CharT> opcodes_apply(const Opcodes& ops, const Sentence1& s1, const Sentence2& s2)
|
|
+std::vector<CharT> opcodes_apply(const Opcodes& ops, const Sentence1& s1, const Sentence2& s2)
|
|
{
|
|
return opcodes_apply<CharT>(ops, detail::to_begin(s1), detail::to_end(s1), detail::to_begin(s2),
|
|
detail::to_end(s2));
|