From ee88cf3dcdabdad4ebed400315d00f9cf875ad29 Mon Sep 17 00:00:00 2001 From: tb Date: Thu, 3 Jul 2025 05:33:02 +0000 Subject: [PATCH] kea: pull in upstream fix for build with libc++ 19.1.7 --- net/kea/Makefile | 2 +- net/kea/patches/patch-src_lib_dns_name_cc | 63 +++++++++++++++++++++++ net/kea/patches/patch-src_lib_dns_name_h | 18 +++++++ 3 files changed, 82 insertions(+), 1 deletion(-) create mode 100644 net/kea/patches/patch-src_lib_dns_name_cc create mode 100644 net/kea/patches/patch-src_lib_dns_name_h diff --git a/net/kea/Makefile b/net/kea/Makefile index ae48df9c633..3faf0dfe506 100644 --- a/net/kea/Makefile +++ b/net/kea/Makefile @@ -1,7 +1,7 @@ COMMENT= high-performance and extensible DHCP server engine from ISC VERSION= 2.4.2 -REVISION= 1 +REVISION= 2 PORTROACH= limitw:1,even # 2.6 update notes so far; diff --git a/net/kea/patches/patch-src_lib_dns_name_cc b/net/kea/patches/patch-src_lib_dns_name_cc new file mode 100644 index 00000000000..fa0855744fa --- /dev/null +++ b/net/kea/patches/patch-src_lib_dns_name_cc @@ -0,0 +1,63 @@ +Fix build with libc++ 19.1.7 +https://github.com/isc-projects/kea/commit/d4878ebec89ed1f869940e67cff8f8fe657b2ee4 + +/usr/include/c++/v1/string:820:42: error: implicit instantiation of undefined template 'std::char +_traits' + +Index: src/lib/dns/name.cc +--- src/lib/dns/name.cc.orig ++++ src/lib/dns/name.cc +@@ -305,7 +305,7 @@ Name::Name(const std::string &namestring, bool downcas + // And get the output + labelcount_ = offsets.size(); + isc_throw_assert(labelcount_ > 0 && labelcount_ <= Name::MAX_LABELS); +- ndata_.assign(ndata.data(), ndata.size()); ++ ndata_.assign(ndata.data(), ndata.data() + ndata.size()); + length_ = ndata_.size(); + offsets_.assign(offsets.begin(), offsets.end()); + } +@@ -339,7 +339,7 @@ Name::Name(const char* namedata, size_t data_len, cons + // Get the output + labelcount_ = offsets.size(); + isc_throw_assert(labelcount_ > 0 && labelcount_ <= Name::MAX_LABELS); +- ndata_.assign(ndata.data(), ndata.size()); ++ ndata_.assign(ndata.data(), ndata.data() + ndata.size()); + length_ = ndata_.size(); + offsets_.assign(offsets.begin(), offsets.end()); + +@@ -350,7 +350,7 @@ Name::Name(const char* namedata, size_t data_len, cons + // Drop the last character of the data (the \0) and append a copy of + // the origin's data + ndata_.erase(ndata_.end() - 1); +- ndata_.append(origin->ndata_); ++ ndata_.insert(ndata.end(), origin->ndata_.begin(), origin->ndata_.end()); + + // Do a similar thing with offsets. However, we need to move them + // so they point after the prefix we parsed before. +@@ -586,7 +586,7 @@ Name::concatenate(const Name& suffix) const { + + Name retname; + retname.ndata_.reserve(length); +- retname.ndata_.assign(ndata_, 0, length_ - 1); ++ retname.ndata_.assign(ndata_.data(), ndata_.data() + length_ - 1); + retname.ndata_.insert(retname.ndata_.end(), + suffix.ndata_.begin(), suffix.ndata_.end()); + isc_throw_assert(retname.ndata_.size() == length); +@@ -626,7 +626,7 @@ Name::reverse() const { + NameString::const_iterator n0 = ndata_.begin(); + retname.offsets_.push_back(0); + while (rit1 != offsets_.rend()) { +- retname.ndata_.append(n0 + *rit1, n0 + *rit0); ++ retname.ndata_.insert(retname.ndata_.end(), n0 + *rit1, n0 + *rit0); + retname.offsets_.push_back(retname.ndata_.size()); + ++rit0; + ++rit1; +@@ -666,7 +666,7 @@ Name::split(const unsigned int first, const unsigned i + // original name, and append the trailing dot explicitly. + // + retname.ndata_.reserve(retname.offsets_.back() + 1); +- retname.ndata_.assign(ndata_, offsets_[first], retname.offsets_.back()); ++ retname.ndata_.assign(ndata_.data() + offsets_[first], ndata_.data() + retname.offsets_.back()); + retname.ndata_.push_back(0); + + retname.length_ = retname.ndata_.size(); diff --git a/net/kea/patches/patch-src_lib_dns_name_h b/net/kea/patches/patch-src_lib_dns_name_h new file mode 100644 index 00000000000..0cafaf20a1d --- /dev/null +++ b/net/kea/patches/patch-src_lib_dns_name_h @@ -0,0 +1,18 @@ +Fix build with libc++ 19.1.7 +https://github.com/isc-projects/kea/commit/d4878ebec89ed1f869940e67cff8f8fe657b2ee4 + +/usr/include/c++/v1/string:820:42: error: implicit instantiation of undefined template 'std::char +_traits' + +Index: src/lib/dns/name.h +--- src/lib/dns/name.h.orig ++++ src/lib/dns/name.h +@@ -232,7 +232,7 @@ class Name { + //@{ + private: + /// \brief Name data string +- typedef std::basic_string NameString; ++ typedef std::vector NameString; + /// \brief Name offsets type + typedef std::vector NameOffsets; +