Ada 2.9.2
Fast spec-compliant URL parser
Loading...
Searching...
No Matches
ada::url_aggregator Struct Reference

Lightweight URL struct. More...

#include <url_aggregator.h>

Inheritance diagram for ada::url_aggregator:
ada::url_base ada::url_base

Public Member Functions

 url_aggregator ()=default
 
 url_aggregator (const url_aggregator &u)=default
 
 url_aggregator (url_aggregator &&u) noexcept=default
 
url_aggregatoroperator= (url_aggregator &&u) noexcept=default
 
url_aggregatoroperator= (const url_aggregator &u)=default
 
 ~url_aggregator () override=default
 
bool set_href (std::string_view input)
 
bool set_host (std::string_view input)
 
bool set_hostname (std::string_view input)
 
bool set_protocol (std::string_view input)
 
bool set_username (std::string_view input)
 
bool set_password (std::string_view input)
 
bool set_port (std::string_view input)
 
bool set_pathname (std::string_view input)
 
void set_search (std::string_view input)
 
void set_hash (std::string_view input)
 
bool has_valid_domain () const noexcept override
 
std::string get_origin () const noexcept override
 
std::string_view get_href () const noexcept ada_lifetime_bound
 
std::string_view get_username () const noexcept ada_lifetime_bound
 
std::string_view get_password () const noexcept ada_lifetime_bound
 
std::string_view get_port () const noexcept ada_lifetime_bound
 
std::string_view get_hash () const noexcept ada_lifetime_bound
 
std::string_view get_host () const noexcept ada_lifetime_bound
 
std::string_view get_hostname () const noexcept ada_lifetime_bound
 
std::string_view get_pathname () const noexcept ada_lifetime_bound
 
ada_really_inline uint32_t get_pathname_length () const noexcept
 
std::string_view get_search () const noexcept ada_lifetime_bound
 
std::string_view get_protocol () const noexcept ada_lifetime_bound
 
ada_really_inline bool has_credentials () const noexcept
 
ada_really_inline const ada::url_componentsget_components () const noexcept
 
std::string to_string () const override
 
std::string to_diagram () const
 
bool validate () const noexcept
 
bool has_empty_hostname () const noexcept
 
bool has_hostname () const noexcept
 
bool has_non_empty_username () const noexcept
 
bool has_non_empty_password () const noexcept
 
bool has_port () const noexcept
 
bool has_password () const noexcept
 
bool has_hash () const noexcept override
 
bool has_search () const noexcept override
 
void clear_port ()
 
void clear_hash ()
 
void clear_search () override
 
 url_aggregator ()=default
 
 url_aggregator (const url_aggregator &u)=default
 
 url_aggregator (url_aggregator &&u) noexcept=default
 
url_aggregatoroperator= (url_aggregator &&u) noexcept=default
 
url_aggregatoroperator= (const url_aggregator &u)=default
 
 ~url_aggregator () override=default
 
bool set_href (std::string_view input)
 
bool set_host (std::string_view input)
 
bool set_hostname (std::string_view input)
 
bool set_protocol (std::string_view input)
 
bool set_username (std::string_view input)
 
bool set_password (std::string_view input)
 
bool set_port (std::string_view input)
 
bool set_pathname (std::string_view input)
 
void set_search (std::string_view input)
 
void set_hash (std::string_view input)
 
bool has_valid_domain () const noexcept override
 
std::string get_origin () const noexcept override
 
std::string_view get_href () const noexcept ada_lifetime_bound
 
std::string_view get_username () const noexcept ada_lifetime_bound
 
std::string_view get_password () const noexcept ada_lifetime_bound
 
std::string_view get_port () const noexcept ada_lifetime_bound
 
std::string_view get_hash () const noexcept ada_lifetime_bound
 
std::string_view get_host () const noexcept ada_lifetime_bound
 
std::string_view get_hostname () const noexcept ada_lifetime_bound
 
std::string_view get_pathname () const noexcept ada_lifetime_bound
 
ada_really_inline uint32_t get_pathname_length () const noexcept
 
std::string_view get_search () const noexcept ada_lifetime_bound
 
std::string_view get_protocol () const noexcept ada_lifetime_bound
 
ada_really_inline bool has_credentials () const noexcept
 
ada_really_inline const ada::url_componentsget_components () const noexcept
 
std::string to_string () const override
 
std::string to_diagram () const
 
bool validate () const noexcept
 
bool has_empty_hostname () const noexcept
 
bool has_hostname () const noexcept
 
bool has_non_empty_username () const noexcept
 
bool has_non_empty_password () const noexcept
 
bool has_port () const noexcept
 
bool has_password () const noexcept
 
bool has_hash () const noexcept override
 
bool has_search () const noexcept override
 
void clear_port ()
 
void clear_hash ()
 
void clear_search () override
 
- Public Member Functions inherited from ada::url_base
virtual ~url_base ()=default
 
ada_really_inline bool is_special () const noexcept
 
virtual ~url_base ()=default
 
ada_really_inline bool is_special () const noexcept
 

Friends

ada::url_aggregator ada::parser::parse_url (std::string_view, const ada::url_aggregator *)
 
void ada::helpers::strip_trailing_spaces_from_opaque_path (ada::url_aggregator &url) noexcept
 
ada::url_aggregator ada::parser::parse_url_impl (std::string_view, const ada::url_aggregator *)
 
ada::url_aggregator ada::parser::parse_url_impl (std::string_view, const ada::url_aggregator *)
 
ada::url_aggregator ada::parser::parse_url (std::string_view, const ada::url_aggregator *)
 
void ada::helpers::strip_trailing_spaces_from_opaque_path (ada::url_aggregator &url) noexcept
 
ada::url_aggregator ada::parser::parse_url_impl (std::string_view, const ada::url_aggregator *)
 
ada::url_aggregator ada::parser::parse_url_impl (std::string_view, const ada::url_aggregator *)
 

Additional Inherited Members

- Public Attributes inherited from ada::url_base
bool is_valid {true}
 
bool has_opaque_path {false}
 
url_host_type host_type = url_host_type::DEFAULT
 

Detailed Description

Lightweight URL struct.

The url_aggregator class aims to minimize temporary memory allocation while representing a parsed URL. Internally, it contains a single normalized URL (the href), and it makes available the components, mostly using std::string_view.

Definition at line 25 of file url_aggregator.h.

Constructor & Destructor Documentation

◆ url_aggregator() [1/6]

ada::url_aggregator::url_aggregator ( )
default

◆ url_aggregator() [2/6]

ada::url_aggregator::url_aggregator ( const url_aggregator & u)
default

◆ url_aggregator() [3/6]

ada::url_aggregator::url_aggregator ( url_aggregator && u)
defaultnoexcept

◆ ~url_aggregator() [1/2]

ada::url_aggregator::~url_aggregator ( )
overridedefault

◆ url_aggregator() [4/6]

ada::url_aggregator::url_aggregator ( )
default

◆ url_aggregator() [5/6]

ada::url_aggregator::url_aggregator ( const url_aggregator & u)
default

◆ url_aggregator() [6/6]

ada::url_aggregator::url_aggregator ( url_aggregator && u)
defaultnoexcept

◆ ~url_aggregator() [2/2]

ada::url_aggregator::~url_aggregator ( )
overridedefault

Member Function Documentation

◆ clear_hash() [1/2]

◆ clear_hash() [2/2]

void ada::url_aggregator::clear_hash ( )
inline

◆ clear_port() [1/2]

◆ clear_port() [2/2]

void ada::url_aggregator::clear_port ( )
inline

◆ clear_search() [1/2]

◆ clear_search() [2/2]

void ada::url_aggregator::clear_search ( )
inlineoverridevirtual

Implements ada::url_base.

◆ get_components() [1/2]

ada_really_inline const ada::url_components & ada::url_aggregator::get_components ( ) const
noexcept

Useful for implementing efficient serialization for the URL.

https://user:pass@example.com:1234/foo/bar?baz#quux | | | | ^^^^| | | | | | | | | | ----- hash_start | | | | | |------— search_start | | | | | ----------------- pathname_start | | | |------------------— port | | | ----------------------- host_end | |-------------------------------— host_start | --------------------------------------- username_end ------------------------------------------— protocol_end

Inspired after servo/url

Returns
a constant reference to the underlying component attribute.
See also
https://github.com/servo/rust-url/blob/b65a45515c10713f6d212e6726719a020203cc98/url/src/quirks.rs#L31

Definition at line 731 of file url_aggregator-inl.h.

◆ get_components() [2/2]

ada_really_inline const ada::url_components & ada::url_aggregator::get_components ( ) const
noexcept

Useful for implementing efficient serialization for the URL.

https://user:pass@example.com:1234/foo/bar?baz#quux | | | | ^^^^| | | | | | | | | | ----- hash_start | | | | | |------— search_start | | | | | ----------------- pathname_start | | | |------------------— port | | | ----------------------- host_end | |-------------------------------— host_start | --------------------------------------- username_end ------------------------------------------— protocol_end

Inspired after servo/url

Returns
a constant reference to the underlying component attribute.
See also
https://github.com/servo/rust-url/blob/b65a45515c10713f6d212e6726719a020203cc98/url/src/quirks.rs#L31

◆ get_hash() [1/2]

std::string_view ada::url_aggregator::get_hash ( ) const
noexcept

Return U+0023 (#), followed by this's URL's fragment. This function does not allocate memory.

Returns
a lightweight std::string_view..
See also
https://url.spec.whatwg.org/#dom-url-hash

Definition at line 13863 of file ada.cpp.

References ada_log.

Referenced by clear_hash(), and to_string().

◆ get_hash() [2/2]

std::string_view ada::url_aggregator::get_hash ( ) const
noexcept

Return U+0023 (#), followed by this's URL's fragment. This function does not allocate memory.

Returns
a lightweight std::string_view..
See also
https://url.spec.whatwg.org/#dom-url-hash

◆ get_host() [1/2]

std::string_view ada::url_aggregator::get_host ( ) const
noexcept

Return url's host, serialized, followed by U+003A (:) and url's port, serialized. This function does not allocate memory. When there is no host, this function returns the empty view.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-host

Definition at line 13877 of file ada.cpp.

References ada_log.

Referenced by to_string().

◆ get_host() [2/2]

std::string_view ada::url_aggregator::get_host ( ) const
noexcept

Return url's host, serialized, followed by U+003A (:) and url's port, serialized. This function does not allocate memory. When there is no host, this function returns the empty view.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-host

◆ get_hostname() [1/2]

std::string_view ada::url_aggregator::get_hostname ( ) const
noexcept

Return this's URL's host, serialized. This function does not allocate memory. When there is no host, this function returns the empty view.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-hostname

Definition at line 13896 of file ada.cpp.

References ada_log.

Referenced by has_valid_domain().

◆ get_hostname() [2/2]

std::string_view ada::url_aggregator::get_hostname ( ) const
noexcept

Return this's URL's host, serialized. This function does not allocate memory. When there is no host, this function returns the empty view.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-hostname

◆ get_href() [1/2]

std::string_view ada::url_aggregator::get_href ( ) const
inlinenoexcept

Return the normalized string. This function does not allocate memory. It is highly efficient.

Returns
a constant reference to the underlying normalized URL.
See also
https://url.spec.whatwg.org/#dom-url-href
https://url.spec.whatwg.org/#concept-url-serializer

Definition at line 847 of file url_aggregator-inl.h.

References ada_log.

◆ get_href() [2/2]

std::string_view ada::url_aggregator::get_href ( ) const
inlinenoexcept

Return the normalized string. This function does not allocate memory. It is highly efficient.

Returns
a constant reference to the underlying normalized URL.
See also
https://url.spec.whatwg.org/#dom-url-href
https://url.spec.whatwg.org/#concept-url-serializer

◆ get_origin() [1/2]

std::string ada::url_aggregator::get_origin ( ) const
overridevirtualnoexcept

The origin getter steps are to return the serialization of this's URL's origin. [HTML]

Returns
a newly allocated string.
See also
https://url.spec.whatwg.org/#concept-url-origin

Implements ada::url_base.

Definition at line 13806 of file ada.cpp.

References ada_log, and ada::parse().

◆ get_origin() [2/2]

std::string ada::url_aggregator::get_origin ( ) const
overridevirtualnoexcept

The origin getter steps are to return the serialization of this's URL's origin. [HTML]

Returns
a newly allocated string.
See also
https://url.spec.whatwg.org/#concept-url-origin

Implements ada::url_base.

◆ get_password() [1/2]

std::string_view ada::url_aggregator::get_password ( ) const
noexcept

The password getter steps are to return this's URL's password. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-password

Definition at line 13843 of file ada.cpp.

References ada_log.

Referenced by to_string().

◆ get_password() [2/2]

std::string_view ada::url_aggregator::get_password ( ) const
noexcept

The password getter steps are to return this's URL's password. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-password

◆ get_pathname() [1/2]

std::string_view ada::url_aggregator::get_pathname ( ) const
noexcept

The pathname getter steps are to return the result of URL path serializing this's URL. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-pathname

Definition at line 13911 of file ada.cpp.

References ada_log.

Referenced by to_string().

◆ get_pathname() [2/2]

std::string_view ada::url_aggregator::get_pathname ( ) const
noexcept

The pathname getter steps are to return the result of URL path serializing this's URL. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-pathname

◆ get_pathname_length() [1/2]

ada_really_inline uint32_t ada::url_aggregator::get_pathname_length ( ) const
noexcept

Compute the pathname length in bytes without instantiating a view or a string.

Returns
size of the pathname in bytes
See also
https://url.spec.whatwg.org/#dom-url-pathname

Definition at line 156 of file url_aggregator-inl.h.

References ada_log, ada::url_components::hash_start, ada::url_components::omitted, ada::parse(), ada::url_components::pathname_start, and ada::url_components::search_start.

◆ get_pathname_length() [2/2]

ada_really_inline uint32_t ada::url_aggregator::get_pathname_length ( ) const
noexcept

Compute the pathname length in bytes without instantiating a view or a string.

Returns
size of the pathname in bytes
See also
https://url.spec.whatwg.org/#dom-url-pathname

◆ get_port() [1/2]

std::string_view ada::url_aggregator::get_port ( ) const
noexcept

Return this's URL's port, serialized. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-port

Definition at line 13853 of file ada.cpp.

References ada_log.

◆ get_port() [2/2]

std::string_view ada::url_aggregator::get_port ( ) const
noexcept

Return this's URL's port, serialized. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-port

◆ get_protocol() [1/2]

std::string_view ada::url_aggregator::get_protocol ( ) const
noexcept

The protocol getter steps are to return this's URL's scheme, followed by U+003A (:). This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-protocol

Definition at line 13944 of file ada.cpp.

References ada_log.

Referenced by to_string().

◆ get_protocol() [2/2]

std::string_view ada::url_aggregator::get_protocol ( ) const
noexcept

The protocol getter steps are to return this's URL's scheme, followed by U+003A (:). This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-protocol

◆ get_search() [1/2]

std::string_view ada::url_aggregator::get_search ( ) const
noexcept

Return U+003F (?), followed by this's URL's query. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-search

Definition at line 13926 of file ada.cpp.

References ada_log.

Referenced by clear_search(), and to_string().

◆ get_search() [2/2]

std::string_view ada::url_aggregator::get_search ( ) const
noexcept

Return U+003F (?), followed by this's URL's query. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-search

◆ get_username() [1/2]

std::string_view ada::url_aggregator::get_username ( ) const
noexcept

The username getter steps are to return this's URL's username. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-username

Definition at line 13833 of file ada.cpp.

References ada_log.

Referenced by to_string().

◆ get_username() [2/2]

std::string_view ada::url_aggregator::get_username ( ) const
noexcept

The username getter steps are to return this's URL's username. This function does not allocate memory.

Returns
a lightweight std::string_view.
See also
https://url.spec.whatwg.org/#dom-url-username

◆ has_credentials() [1/2]

ada_really_inline bool ada::url_aggregator::has_credentials ( ) const
noexcept

A URL includes credentials if its username or password is not the empty string.

Definition at line 719 of file url_aggregator-inl.h.

References ada_log, has_non_empty_password(), and has_non_empty_username().

Referenced by to_string().

◆ has_credentials() [2/2]

ada_really_inline bool ada::url_aggregator::has_credentials ( ) const
noexcept

A URL includes credentials if its username or password is not the empty string.

◆ has_empty_hostname() [1/2]

bool ada::url_aggregator::has_empty_hostname ( ) const
inlinenoexcept
Returns
true if it has an host but it is the empty string

Definition at line 791 of file url_aggregator-inl.h.

References has_hostname(), ada::url_components::host_end, ada::url_components::host_start, and ada::url_components::username_end.

◆ has_empty_hostname() [2/2]

bool ada::url_aggregator::has_empty_hostname ( ) const
inlinenoexcept
Returns
true if it has an host but it is the empty string

◆ has_hash() [1/2]

bool ada::url_aggregator::has_hash ( ) const
inlineoverridevirtualnoexcept
Returns
true if the URL has a hash component

Implements ada::url_base.

Definition at line 709 of file url_aggregator-inl.h.

References ada_log, ada::url_components::hash_start, and ada::url_components::omitted.

◆ has_hash() [2/2]

bool ada::url_aggregator::has_hash ( ) const
inlineoverridevirtualnoexcept
Returns
true if the URL has a hash component

Implements ada::url_base.

◆ has_hostname() [1/2]

bool ada::url_aggregator::has_hostname ( ) const
inlinenoexcept
Returns
true if it has a host (included an empty host)

Definition at line 804 of file url_aggregator-inl.h.

Referenced by has_empty_hostname(), and has_port().

◆ has_hostname() [2/2]

bool ada::url_aggregator::has_hostname ( ) const
inlinenoexcept
Returns
true if it has a host (included an empty host)

◆ has_non_empty_password() [1/2]

bool ada::url_aggregator::has_non_empty_password ( ) const
inlinenoexcept
Returns
true if the URL has a non-empty password

Definition at line 779 of file url_aggregator-inl.h.

References ada_log, ada::url_components::host_start, and ada::url_components::username_end.

Referenced by has_credentials().

◆ has_non_empty_password() [2/2]

bool ada::url_aggregator::has_non_empty_password ( ) const
inlinenoexcept
Returns
true if the URL has a non-empty password

◆ has_non_empty_username() [1/2]

bool ada::url_aggregator::has_non_empty_username ( ) const
inlinenoexcept
Returns
true if the URL has a non-empty username

Definition at line 774 of file url_aggregator-inl.h.

References ada_log, ada::url_components::protocol_end, and ada::url_components::username_end.

Referenced by has_credentials().

◆ has_non_empty_username() [2/2]

bool ada::url_aggregator::has_non_empty_username ( ) const
inlinenoexcept
Returns
true if the URL has a non-empty username

◆ has_password() [1/2]

bool ada::url_aggregator::has_password ( ) const
inlinenoexcept
Returns
true if the URL has a password

Definition at line 784 of file url_aggregator-inl.h.

References ada_log, ada::url_components::host_start, and ada::url_components::username_end.

◆ has_password() [2/2]

bool ada::url_aggregator::has_password ( ) const
inlinenoexcept
Returns
true if the URL has a password

◆ has_port() [1/2]

bool ada::url_aggregator::has_port ( ) const
inlinenoexcept
Returns
true if the URL has a (non default) port

Definition at line 808 of file url_aggregator-inl.h.

References ada_log, has_hostname(), ada::url_components::host_end, and ada::url_components::pathname_start.

◆ has_port() [2/2]

bool ada::url_aggregator::has_port ( ) const
inlinenoexcept
Returns
true if the URL has a (non default) port

◆ has_search() [1/2]

bool ada::url_aggregator::has_search ( ) const
inlineoverridevirtualnoexcept
Returns
true if the URL has a search component

Implements ada::url_base.

Definition at line 714 of file url_aggregator-inl.h.

References ada_log, ada::url_components::omitted, and ada::url_components::search_start.

◆ has_search() [2/2]

bool ada::url_aggregator::has_search ( ) const
inlineoverridevirtualnoexcept
Returns
true if the URL has a search component

Implements ada::url_base.

◆ has_valid_domain() [1/2]

bool ada::url_aggregator::has_valid_domain ( ) const
overridevirtualnoexcept

Returns true if this URL has a valid domain as per RFC 1034 and corresponding specifications. Among other things, it requires that the domain string has fewer than 255 octets.

Implements ada::url_base.

Definition at line 14043 of file ada.cpp.

References get_hostname(), ada::url_components::host_end, and ada::url_components::host_start.

◆ has_valid_domain() [2/2]

bool ada::url_aggregator::has_valid_domain ( ) const
overridevirtualnoexcept

Returns true if this URL has a valid domain as per RFC 1034 and corresponding specifications. Among other things, it requires that the domain string has fewer than 255 octets.

Implements ada::url_base.

◆ operator=() [1/4]

url_aggregator & ada::url_aggregator::operator= ( const url_aggregator & u)
default

◆ operator=() [2/4]

url_aggregator & ada::url_aggregator::operator= ( const url_aggregator & u)
default

◆ operator=() [3/4]

url_aggregator & ada::url_aggregator::operator= ( url_aggregator && u)
defaultnoexcept

◆ operator=() [4/4]

url_aggregator & ada::url_aggregator::operator= ( url_aggregator && u)
defaultnoexcept

◆ set_hash() [1/2]

void ada::url_aggregator::set_hash ( std::string_view input)

Definition at line 13574 of file ada.cpp.

References ADA_ASSERT_TRUE, and ada_log.

◆ set_hash() [2/2]

void ada::url_aggregator::set_hash ( std::string_view input)

◆ set_host() [1/2]

bool ada::url_aggregator::set_host ( std::string_view input)

Definition at line 13792 of file ada.cpp.

References ADA_ASSERT_TRUE, and ada_log.

◆ set_host() [2/2]

bool ada::url_aggregator::set_host ( std::string_view input)

◆ set_hostname() [1/2]

bool ada::url_aggregator::set_hostname ( std::string_view input)

Definition at line 13799 of file ada.cpp.

References ADA_ASSERT_TRUE, and ada_log.

◆ set_hostname() [2/2]

bool ada::url_aggregator::set_hostname ( std::string_view input)

◆ set_href() [1/2]

bool ada::url_aggregator::set_href ( std::string_view input)

◆ set_href() [2/2]

bool ada::url_aggregator::set_href ( std::string_view input)

◆ set_password() [1/2]

bool ada::url_aggregator::set_password ( std::string_view input)

Definition at line 13439 of file ada.cpp.

References ADA_ASSERT_TRUE, ada_log, and ada::unicode::percent_encode_index().

◆ set_password() [2/2]

bool ada::url_aggregator::set_password ( std::string_view input)

◆ set_pathname() [1/2]

bool ada::url_aggregator::set_pathname ( std::string_view input)

Definition at line 13493 of file ada.cpp.

References ADA_ASSERT_TRUE, and ada_log.

◆ set_pathname() [2/2]

bool ada::url_aggregator::set_pathname ( std::string_view input)

◆ set_port() [1/2]

bool ada::url_aggregator::set_port ( std::string_view input)

Definition at line 13459 of file ada.cpp.

References ADA_ASSERT_TRUE, and ada_log.

◆ set_port() [2/2]

bool ada::url_aggregator::set_port ( std::string_view input)

◆ set_protocol() [1/2]

bool ada::url_aggregator::set_protocol ( std::string_view input)

Definition at line 13392 of file ada.cpp.

References ADA_ASSERT_TRUE, and ada_log.

◆ set_protocol() [2/2]

bool ada::url_aggregator::set_protocol ( std::string_view input)

◆ set_search() [1/2]

void ada::url_aggregator::set_search ( std::string_view input)

◆ set_search() [2/2]

void ada::url_aggregator::set_search ( std::string_view input)

◆ set_username() [1/2]

bool ada::url_aggregator::set_username ( std::string_view input)

Definition at line 13419 of file ada.cpp.

References ADA_ASSERT_TRUE, ada_log, and ada::unicode::percent_encode_index().

◆ set_username() [2/2]

bool ada::url_aggregator::set_username ( std::string_view input)

◆ to_diagram() [1/2]

◆ to_diagram() [2/2]

std::string ada::url_aggregator::to_diagram ( ) const

Returns a string diagram of this URL.

◆ to_string() [1/2]

◆ to_string() [2/2]

std::string ada::url_aggregator::to_string ( ) const
overridevirtual

Returns a string representation of this URL.

Implements ada::url_base.

◆ validate() [1/2]

bool ada::url_aggregator::validate ( ) const
noexcept

Verifies that the parsed URL could be valid. Useful for debugging purposes.

Returns
true if the URL is valid, otherwise return true of the offsets are possible.

https://user:pass@example.com:1234/foo/bar?baz#quux | | | | ^^^^| | | | | | | | | | ----- hash_start | | | | | |------— search_start | | | | | ----------------- pathname_start | | | |------------------— port | | | ----------------------- host_end | |-------------------------------— host_start | --------------------------------------- username_end ------------------------------------------— protocol_end

https://user:pass@example.com:1234/foo/bar?baz#quux | | | | ^^^^| | | | | | | | | | ----- hash_start | | | | | |------— search_start | | | | | ----------------- pathname_start | | | |------------------— port | | | ----------------------- host_end | |-------------------------------— host_start | --------------------------------------- username_end ------------------------------------------— protocol_end

Definition at line 14565 of file ada.cpp.

References ada_log, ada::url_components::check_offset_consistency(), ada::url_base::has_opaque_path, ada::url_components::hash_start, ada::url_components::host_end, ada::url_components::host_start, ada::url_base::is_valid, ada::url_components::omitted, ada::url_components::pathname_start, ada::url_components::protocol_end, ada::url_components::search_start, to_diagram(), and ada::url_components::username_end.

Referenced by clear_hash(), clear_port(), and clear_search().

◆ validate() [2/2]

bool ada::url_aggregator::validate ( ) const
noexcept

Verifies that the parsed URL could be valid. Useful for debugging purposes.

Returns
true if the URL is valid, otherwise return true of the offsets are possible.

Friends And Related Symbol Documentation

◆ ada::helpers::strip_trailing_spaces_from_opaque_path [1/2]

void ada::helpers::strip_trailing_spaces_from_opaque_path ( ada::url_aggregator & url)
friend

◆ ada::helpers::strip_trailing_spaces_from_opaque_path [2/2]

void ada::helpers::strip_trailing_spaces_from_opaque_path ( ada::url_aggregator & url)
friend

◆ ada::parser::parse_url [1/2]

◆ ada::parser::parse_url [2/2]

◆ ada::parser::parse_url_impl [1/4]

◆ ada::parser::parse_url_impl [2/4]

◆ ada::parser::parse_url_impl [3/4]

◆ ada::parser::parse_url_impl [4/4]


The documentation for this struct was generated from the following files: