Skip to content

Commit

Permalink
Work around a warning in GCC 13
Browse files Browse the repository at this point in the history
... which claims that the replaced code creates a 'possibly dangling reference'.
I'm quite sure that this warning is a false positive but let's be safe.
  • Loading branch information
reneme committed Dec 22, 2023
1 parent ca992bd commit df92d38
Showing 1 changed file with 10 additions and 10 deletions.
20 changes: 10 additions & 10 deletions src/cli/tls_utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -123,8 +123,8 @@ class TLS_Client_Hello_Reader final : public Command {
const std::variant<Botan::TLS::Client_Hello_13, Botan::TLS::Client_Hello_12>& hello) {
std::ostringstream oss;

const auto& hello_base =
std::visit([](const auto& ch) -> const Botan::TLS::Client_Hello& { return ch; }, hello);
const auto* hello_base =
std::visit([](const auto& ch) -> const Botan::TLS::Client_Hello* { return &ch; }, hello);

const auto version = std::visit(Botan::overloaded{
[](const Botan::TLS::Client_Hello_12&) { return "1.2"; },
Expand All @@ -133,12 +133,12 @@ class TLS_Client_Hello_Reader final : public Command {
hello);

oss << "Version: " << version << "\n"
<< "Random: " << Botan::hex_encode(hello_base.random()) << "\n";
<< "Random: " << Botan::hex_encode(hello_base->random()) << "\n";

if(!hello_base.session_id().empty()) {
oss << "SessionID: " << Botan::hex_encode(hello_base.session_id().get()) << "\n";
if(!hello_base->session_id().empty()) {
oss << "SessionID: " << Botan::hex_encode(hello_base->session_id().get()) << "\n";
}
for(uint16_t csuite_id : hello_base.ciphersuites()) {
for(uint16_t csuite_id : hello_base->ciphersuites()) {
const auto csuite = Botan::TLS::Ciphersuite::by_id(csuite_id);
if(csuite && csuite->valid()) {
oss << "Cipher: " << csuite->to_string() << "\n";
Expand All @@ -151,10 +151,10 @@ class TLS_Client_Hello_Reader final : public Command {

oss << "Supported signature schemes: ";

if(hello_base.signature_schemes().empty()) {
if(hello_base->signature_schemes().empty()) {
oss << "Did not send signature_algorithms extension\n";
} else {
for(Botan::TLS::Signature_Scheme scheme : hello_base.signature_schemes()) {
for(Botan::TLS::Signature_Scheme scheme : hello_base->signature_schemes()) {
try {
auto s = scheme.to_string();
oss << s << " ";
Expand All @@ -165,7 +165,7 @@ class TLS_Client_Hello_Reader final : public Command {
oss << "\n";
}

if(auto sg = hello_base.extensions().get<Botan::TLS::Supported_Groups>()) {
if(auto sg = hello_base->extensions().get<Botan::TLS::Supported_Groups>()) {
oss << "Supported Groups: ";
for(const auto group : sg->groups()) {
oss << group.to_string().value_or(Botan::fmt("Unknown group: {}", group.wire_code())) << " ";
Expand All @@ -174,7 +174,7 @@ class TLS_Client_Hello_Reader final : public Command {
}

std::map<std::string, bool> hello_flags;
hello_flags["ALPN"] = hello_base.supports_alpn();
hello_flags["ALPN"] = hello_base->supports_alpn();

std::visit(Botan::overloaded{
[&](const Botan::TLS::Client_Hello_12& ch12) {
Expand Down

0 comments on commit df92d38

Please sign in to comment.