2023-03-06 14:42:04 +01:00
|
|
|
// SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
// Copyright CM4all GmbH
|
|
|
|
// author: Max Kellermann <mk@cm4all.com>
|
2018-08-21 08:26:12 +02:00
|
|
|
|
2022-05-31 13:33:33 +02:00
|
|
|
#pragma once
|
2018-08-21 08:26:12 +02:00
|
|
|
|
2022-05-31 13:33:33 +02:00
|
|
|
#include <string_view>
|
2018-08-21 08:26:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Result type for ExtractHost().
|
|
|
|
*/
|
|
|
|
struct ExtractHostResult {
|
|
|
|
/**
|
|
|
|
* The host part of the address.
|
|
|
|
*
|
|
|
|
* If nothing was parsed, then this is nullptr.
|
|
|
|
*/
|
2022-05-31 13:33:33 +02:00
|
|
|
std::string_view host;
|
2018-08-21 08:26:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Pointer to the first character that was not parsed. On
|
|
|
|
* success, this is usually a pointer to the zero terminator or to
|
|
|
|
* a colon followed by a port number.
|
|
|
|
*
|
|
|
|
* If nothing was parsed, then this is a pointer to the given
|
|
|
|
* source string.
|
|
|
|
*/
|
|
|
|
const char *end;
|
|
|
|
|
2019-01-21 21:20:43 +01:00
|
|
|
constexpr bool HasFailed() const noexcept {
|
2022-05-31 13:33:33 +02:00
|
|
|
return host.data() == nullptr;
|
2018-08-21 08:26:12 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract the host from a string in the form "IP:PORT" or
|
|
|
|
* "[IPv6]:PORT". Stops at the first invalid character (e.g. the
|
|
|
|
* colon).
|
|
|
|
*
|
|
|
|
* @param src the input string
|
|
|
|
*/
|
2021-02-08 14:59:40 +01:00
|
|
|
[[gnu::pure]]
|
2018-08-21 08:26:12 +02:00
|
|
|
ExtractHostResult
|
2019-01-21 21:20:43 +01:00
|
|
|
ExtractHost(const char *src) noexcept;
|