From: Otto Moerbeek Date: Wed, 19 Jun 2024 11:10:15 +0000 (+0200) Subject: dns.cc: use pdns::views::UnsignedCharView X-Git-Tag: rec-4.9.8~6^2~1 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c4453d209043f3484f2dc2e5c6c02724c1915bf0;p=thirdparty%2Fpdns.git dns.cc: use pdns::views::UnsignedCharView Includes minor cleanup and additions to make UnsignedCharView usable for this use case. Supersedes #14356 Fixes /usr/include/c++/v1/__fwd/string_view.h:22:41: warning: 'char_traits' is deprecated: char_traits for T not equal to char, wchar_t, char8_t, char16_t or char32_t is non-standard and is provided for a temporary period. It will be removed in LLVM 19, so please migrate off of it. [-Wdeprecated-declarations] (cherry picked from commit 949ea9456dbe76e78aeff5f6f37f218549d1b493) --- diff --git a/pdns/dns.cc b/pdns/dns.cc index 99bbd72aa6..5e7e45e1f6 100644 --- a/pdns/dns.cc +++ b/pdns/dns.cc @@ -24,6 +24,7 @@ #endif #include "dns.hh" #include "misc.hh" +#include "views.hh" #include #include #include @@ -102,27 +103,27 @@ std::string Opcode::to_s(uint8_t opcode) { } // goal is to hash based purely on the question name, and turn error into 'default' -uint32_t hashQuestion(const uint8_t* packet, uint16_t packet_len, uint32_t init, bool& ok) +uint32_t hashQuestion(const uint8_t* packet, uint16_t packet_len, uint32_t init, bool& wasOK) { if (packet_len < sizeof(dnsheader)) { - ok = false; + wasOK = false; return init; } - // C++ 17 does not have std::u8string_view - std::basic_string_view name(packet + sizeof(dnsheader), packet_len - sizeof(dnsheader)); - std::basic_string_view::size_type len = 0; + // NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-pointer-arithmetic) + pdns::views::UnsignedCharView name(packet + sizeof(dnsheader), packet_len - sizeof(dnsheader)); + pdns::views::UnsignedCharView::size_type len = 0; while (len < name.length()) { uint8_t labellen = name[len++]; if (labellen == 0) { - ok = true; + wasOK = true; // len is name.length() at max as it was < before the increment return burtleCI(name.data(), len, init); } len += labellen; } // We've encountered a label that is too long - ok = false; + wasOK = false; return init; }