mirror of https://github.com/nodejs/node.git
deps: update ada to 2.9.1
PR-URL: https://github.com/nodejs/node/pull/54679 Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com> Reviewed-By: Daniel Lemire <daniel@lemire.me> Reviewed-By: Marco Ippolito <marcoippolito54@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com> Reviewed-By: Michael Dawson <midawson@redhat.com> Reviewed-By: Jake Yuesong Li <jake.yuesong@gmail.com>pull/55513/head
parent
d54d3b24c3
commit
c2b5ebfeca
|
@ -1,4 +1,4 @@
|
|||
/* auto-generated on 2024-07-06 17:38:56 -0400. Do not edit! */
|
||||
/* auto-generated on 2024-09-02 20:07:32 -0400. Do not edit! */
|
||||
/* begin file src/ada.cpp */
|
||||
#include "ada.h"
|
||||
/* begin file src/checkers.cpp */
|
||||
|
@ -11553,21 +11553,21 @@ ada_really_inline bool url::parse_scheme(const std::string_view input) {
|
|||
// If url's scheme is not a special scheme and buffer is a special scheme,
|
||||
// then return.
|
||||
if (is_special() != is_input_special) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
// If url includes credentials or has a non-null port, and buffer is
|
||||
// "file", then return.
|
||||
if ((has_credentials() || port.has_value()) &&
|
||||
parsed_type == ada::scheme::type::FILE) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
// If url's scheme is "file" and its host is an empty host, then return.
|
||||
// An empty host is the empty string.
|
||||
if (type == ada::scheme::type::FILE && host.has_value() &&
|
||||
host.value().empty()) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -13215,21 +13215,21 @@ template <bool has_state_override>
|
|||
// If url's scheme is not a special scheme and buffer is a special scheme,
|
||||
// then return.
|
||||
if (is_special() != is_input_special) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
// If url includes credentials or has a non-null port, and buffer is
|
||||
// "file", then return.
|
||||
if ((has_credentials() || components.port != url_components::omitted) &&
|
||||
parsed_type == ada::scheme::type::FILE) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
// If url's scheme is "file" and its host is an empty host, then return.
|
||||
// An empty host is the empty string.
|
||||
if (type == ada::scheme::type::FILE &&
|
||||
components.host_start == components.host_end) {
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -13830,7 +13830,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return "null";
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_username() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_username() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_username");
|
||||
if (has_non_empty_username()) {
|
||||
return helpers::substring(buffer, components.protocol_end + 2,
|
||||
|
@ -13839,7 +13840,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return "";
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_password() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_password() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_password");
|
||||
if (has_non_empty_password()) {
|
||||
return helpers::substring(buffer, components.username_end + 1,
|
||||
|
@ -13848,7 +13850,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return "";
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_port() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_port() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_port");
|
||||
if (components.port == url_components::omitted) {
|
||||
return "";
|
||||
|
@ -13857,7 +13860,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
components.pathname_start);
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_hash() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_hash() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_hash");
|
||||
// If this's URL's fragment is either null or the empty string, then return
|
||||
// the empty string. Return U+0023 (#), followed by this's URL's fragment.
|
||||
|
@ -13870,7 +13874,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return helpers::substring(buffer, components.hash_start);
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_host() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_host() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_host");
|
||||
// Technically, we should check if there is a hostname, but
|
||||
// the code below works even if there isn't.
|
||||
|
@ -13888,7 +13893,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return helpers::substring(buffer, start, components.pathname_start);
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_hostname() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_hostname() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_hostname");
|
||||
// Technically, we should check if there is a hostname, but
|
||||
// the code below works even if there isn't.
|
||||
|
@ -13902,7 +13908,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return helpers::substring(buffer, start, components.host_end);
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_pathname() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_pathname() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_pathname pathname_start = ",
|
||||
components.pathname_start, " buffer.size() = ", buffer.size(),
|
||||
" components.search_start = ", components.search_start,
|
||||
|
@ -13916,7 +13923,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return helpers::substring(buffer, components.pathname_start, ending_index);
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_search() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_search() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_search");
|
||||
// If this's URL's query is either null or the empty string, then return the
|
||||
// empty string. Return U+003F (?), followed by this's URL's query.
|
||||
|
@ -13933,7 +13941,8 @@ bool url_aggregator::set_hostname(const std::string_view input) {
|
|||
return helpers::substring(buffer, components.search_start, ending_index);
|
||||
}
|
||||
|
||||
[[nodiscard]] std::string_view url_aggregator::get_protocol() const noexcept {
|
||||
[[nodiscard]] std::string_view url_aggregator::get_protocol() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_protocol");
|
||||
return helpers::substring(buffer, 0, components.protocol_end);
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
/* auto-generated on 2024-07-06 17:38:56 -0400. Do not edit! */
|
||||
/* auto-generated on 2024-09-02 20:07:32 -0400. Do not edit! */
|
||||
/* begin file include/ada.h */
|
||||
/**
|
||||
* @file ada.h
|
||||
|
@ -479,6 +479,18 @@ namespace ada {
|
|||
#define ADA_NEON 1
|
||||
#endif
|
||||
|
||||
#ifndef __has_cpp_attribute
|
||||
#define ada_lifetime_bound
|
||||
#elif __has_cpp_attribute(msvc::lifetimebound)
|
||||
#define ada_lifetime_bound [[msvc::lifetimebound]]
|
||||
#elif __has_cpp_attribute(clang::lifetimebound)
|
||||
#define ada_lifetime_bound [[clang::lifetimebound]]
|
||||
#elif __has_cpp_attribute(lifetimebound)
|
||||
#define ada_lifetime_bound [[lifetimebound]]
|
||||
#else
|
||||
#define ada_lifetime_bound
|
||||
#endif
|
||||
|
||||
#endif // ADA_COMMON_DEFS_H
|
||||
/* end file include/ada/common_defs.h */
|
||||
#include <cstdint>
|
||||
|
@ -4845,35 +4857,38 @@ struct url_aggregator : url_base {
|
|||
* @see https://url.spec.whatwg.org/#dom-url-href
|
||||
* @see https://url.spec.whatwg.org/#concept-url-serializer
|
||||
*/
|
||||
[[nodiscard]] inline std::string_view get_href() const noexcept;
|
||||
[[nodiscard]] inline std::string_view get_href() const noexcept
|
||||
ada_lifetime_bound;
|
||||
/**
|
||||
* The username getter steps are to return this's URL's username.
|
||||
* This function does not allocate memory.
|
||||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-username
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_username() const noexcept;
|
||||
[[nodiscard]] std::string_view get_username() const noexcept
|
||||
ada_lifetime_bound;
|
||||
/**
|
||||
* The password getter steps are to return this's URL's password.
|
||||
* This function does not allocate memory.
|
||||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-password
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_password() const noexcept;
|
||||
[[nodiscard]] std::string_view get_password() const noexcept
|
||||
ada_lifetime_bound;
|
||||
/**
|
||||
* Return this's URL's port, serialized.
|
||||
* This function does not allocate memory.
|
||||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-port
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_port() const noexcept;
|
||||
[[nodiscard]] std::string_view get_port() const noexcept ada_lifetime_bound;
|
||||
/**
|
||||
* Return U+0023 (#), followed by this's URL's fragment.
|
||||
* This function does not allocate memory.
|
||||
* @return a lightweight std::string_view..
|
||||
* @see https://url.spec.whatwg.org/#dom-url-hash
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_hash() const noexcept;
|
||||
[[nodiscard]] std::string_view get_hash() const noexcept ada_lifetime_bound;
|
||||
/**
|
||||
* Return url's host, serialized, followed by U+003A (:) and url's port,
|
||||
* serialized.
|
||||
|
@ -4882,7 +4897,7 @@ struct url_aggregator : url_base {
|
|||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-host
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_host() const noexcept;
|
||||
[[nodiscard]] std::string_view get_host() const noexcept ada_lifetime_bound;
|
||||
/**
|
||||
* Return this's URL's host, serialized.
|
||||
* This function does not allocate memory.
|
||||
|
@ -4890,7 +4905,8 @@ struct url_aggregator : url_base {
|
|||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-hostname
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_hostname() const noexcept;
|
||||
[[nodiscard]] std::string_view get_hostname() const noexcept
|
||||
ada_lifetime_bound;
|
||||
/**
|
||||
* The pathname getter steps are to return the result of URL path serializing
|
||||
* this's URL.
|
||||
|
@ -4898,7 +4914,8 @@ struct url_aggregator : url_base {
|
|||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-pathname
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_pathname() const noexcept;
|
||||
[[nodiscard]] std::string_view get_pathname() const noexcept
|
||||
ada_lifetime_bound;
|
||||
/**
|
||||
* Compute the pathname length in bytes without instantiating a view or a
|
||||
* string.
|
||||
|
@ -4912,7 +4929,7 @@ struct url_aggregator : url_base {
|
|||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-search
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_search() const noexcept;
|
||||
[[nodiscard]] std::string_view get_search() const noexcept ada_lifetime_bound;
|
||||
/**
|
||||
* The protocol getter steps are to return this's URL's scheme, followed by
|
||||
* U+003A (:).
|
||||
|
@ -4920,7 +4937,8 @@ struct url_aggregator : url_base {
|
|||
* @return a lightweight std::string_view.
|
||||
* @see https://url.spec.whatwg.org/#dom-url-protocol
|
||||
*/
|
||||
[[nodiscard]] std::string_view get_protocol() const noexcept;
|
||||
[[nodiscard]] std::string_view get_protocol() const noexcept
|
||||
ada_lifetime_bound;
|
||||
|
||||
/**
|
||||
* A URL includes credentials if its username or password is not the empty
|
||||
|
@ -5828,7 +5846,7 @@ inline void url::set_scheme(std::string &&new_scheme) noexcept {
|
|||
type = ada::scheme::get_scheme_type(new_scheme);
|
||||
// We only move the 'scheme' if it is non-special.
|
||||
if (!is_special()) {
|
||||
non_special_scheme = new_scheme;
|
||||
non_special_scheme = std::move(new_scheme);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -5877,10 +5895,15 @@ inline void url::copy_scheme(const ada::url &u) {
|
|||
ada_really_inline size_t url::parse_port(std::string_view view,
|
||||
bool check_trailing_content) noexcept {
|
||||
ada_log("parse_port('", view, "') ", view.size());
|
||||
if (!view.empty() && view[0] == '-') {
|
||||
ada_log("parse_port: view[0] == '0' && view.size() > 1");
|
||||
is_valid = false;
|
||||
return 0;
|
||||
}
|
||||
uint16_t parsed_port{};
|
||||
auto r = std::from_chars(view.data(), view.data() + view.size(), parsed_port);
|
||||
if (r.ec == std::errc::result_out_of_range) {
|
||||
ada_log("parse_port: std::errc::result_out_of_range");
|
||||
ada_log("parse_port: r.ec == std::errc::result_out_of_range");
|
||||
is_valid = false;
|
||||
return 0;
|
||||
}
|
||||
|
@ -6776,8 +6799,8 @@ inline bool url_aggregator::has_port() const noexcept {
|
|||
buffer[components.host_end + 1] == '.';
|
||||
}
|
||||
|
||||
[[nodiscard]] inline std::string_view url_aggregator::get_href()
|
||||
const noexcept {
|
||||
[[nodiscard]] inline std::string_view url_aggregator::get_href() const noexcept
|
||||
ada_lifetime_bound {
|
||||
ada_log("url_aggregator::get_href");
|
||||
return buffer;
|
||||
}
|
||||
|
@ -6785,10 +6808,15 @@ inline bool url_aggregator::has_port() const noexcept {
|
|||
ada_really_inline size_t url_aggregator::parse_port(
|
||||
std::string_view view, bool check_trailing_content) noexcept {
|
||||
ada_log("url_aggregator::parse_port('", view, "') ", view.size());
|
||||
if (!view.empty() && view[0] == '-') {
|
||||
ada_log("parse_port: view[0] == '0' && view.size() > 1");
|
||||
is_valid = false;
|
||||
return 0;
|
||||
}
|
||||
uint16_t parsed_port{};
|
||||
auto r = std::from_chars(view.data(), view.data() + view.size(), parsed_port);
|
||||
if (r.ec == std::errc::result_out_of_range) {
|
||||
ada_log("parse_port: std::errc::result_out_of_range");
|
||||
ada_log("parse_port: r.ec == std::errc::result_out_of_range");
|
||||
is_valid = false;
|
||||
return 0;
|
||||
}
|
||||
|
@ -7279,14 +7307,14 @@ url_search_params_entries_iter::next() {
|
|||
#ifndef ADA_ADA_VERSION_H
|
||||
#define ADA_ADA_VERSION_H
|
||||
|
||||
#define ADA_VERSION "2.9.0"
|
||||
#define ADA_VERSION "2.9.2"
|
||||
|
||||
namespace ada {
|
||||
|
||||
enum {
|
||||
ADA_VERSION_MAJOR = 2,
|
||||
ADA_VERSION_MINOR = 9,
|
||||
ADA_VERSION_REVISION = 0,
|
||||
ADA_VERSION_REVISION = 2,
|
||||
};
|
||||
|
||||
} // namespace ada
|
||||
|
|
Loading…
Reference in New Issue