LibURL: Define Origin methods depending on URL::Parser out of line

This is also in an effort towards resolving a future circular dependency
between Origin.h and URL.h
This commit is contained in:
Shannon Booth 2024-10-05 16:33:30 +13:00 committed by Andreas Kling
commit 43973f2d0a
Notes: github-actions[bot] 2024-10-05 08:47:44 +00:00
5 changed files with 58 additions and 33 deletions

View file

@ -1,6 +1,7 @@
set(SOURCES
URL.cpp
Origin.cpp
Parser.cpp
URL.cpp
)
serenity_lib(LibURL url)

View file

@ -0,0 +1,50 @@
/*
* Copyright (c) 2024, Shannon Booth <shannon@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibURL/Origin.h>
#include <LibURL/Parser.h>
namespace URL {
// https://html.spec.whatwg.org/multipage/origin.html#ascii-serialisation-of-an-origin
ByteString Origin::serialize() const
{
// 1. If origin is an opaque origin, then return "null"
if (is_opaque())
return "null";
// 2. Otherwise, let result be origin's scheme.
StringBuilder result;
result.append(scheme());
// 3. Append "://" to result.
result.append("://"sv);
// 4. Append origin's host, serialized, to result.
result.append(Parser::serialize_host(host()).release_value_but_fixme_should_propagate_errors().to_byte_string());
// 5. If origin's port is non-null, append a U+003A COLON character (:), and origin's port, serialized, to result.
if (port() != 0) {
result.append(':');
result.append(ByteString::number(port()));
}
// 6. Return result
return result.to_byte_string();
}
}
namespace AK {
unsigned Traits<URL::Origin>::hash(URL::Origin const& origin)
{
auto hash_without_host = pair_int_hash(origin.scheme().hash(), origin.port());
if (origin.host().has<Empty>())
return hash_without_host;
return pair_int_hash(hash_without_host, URL::Parser::serialize_host(origin.host()).release_value_but_fixme_should_propagate_errors().hash());
}
} // namespace AK

View file

@ -9,7 +9,6 @@
#include <AK/ByteString.h>
#include <LibURL/Host.h>
#include <LibURL/Parser.h>
namespace URL {
@ -72,30 +71,7 @@ public:
}
// https://html.spec.whatwg.org/multipage/origin.html#ascii-serialisation-of-an-origin
ByteString serialize() const
{
// 1. If origin is an opaque origin, then return "null"
if (is_opaque())
return "null";
// 2. Otherwise, let result be origin's scheme.
StringBuilder result;
result.append(scheme());
// 3. Append "://" to result.
result.append("://"sv);
// 4. Append origin's host, serialized, to result.
result.append(Parser::serialize_host(host()).release_value_but_fixme_should_propagate_errors().to_byte_string());
// 5. If origin's port is non-null, append a U+003A COLON character (:), and origin's port, serialized, to result.
if (port() != 0) {
result.append(':');
result.append(ByteString::number(port()));
}
// 6. Return result
return result.to_byte_string();
}
ByteString serialize() const;
// https://html.spec.whatwg.org/multipage/origin.html#concept-origin-effective-domain
Optional<Host> effective_domain() const
@ -121,14 +97,10 @@ private:
}
namespace AK {
template<>
struct Traits<URL::Origin> : public DefaultTraits<URL::Origin> {
static unsigned hash(URL::Origin const& origin)
{
auto hash_without_host = pair_int_hash(origin.scheme().hash(), origin.port());
if (origin.host().has<Empty>())
return hash_without_host;
return pair_int_hash(hash_without_host, URL::Parser::serialize_host(origin.host()).release_value_but_fixme_should_propagate_errors().hash());
}
static unsigned hash(URL::Origin const& origin);
};
} // namespace AK

View file

@ -19,6 +19,7 @@
#include <LibJS/Runtime/FunctionObject.h>
#include <LibJS/Runtime/NativeFunction.h>
#include <LibURL/Origin.h>
#include <LibURL/Parser.h>
#include <LibUnicode/Segmenter.h>
#include <LibWeb/Animations/Animation.h>
#include <LibWeb/Animations/AnimationPlaybackEvent.h>

View file

@ -4,6 +4,7 @@
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibURL/Parser.h>
#include <LibWeb/DOM/Document.h>
#include <LibWeb/Fetch/Fetching/Fetching.h>
#include <LibWeb/Fetch/Infrastructure/FetchAlgorithms.h>