mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-10 01:59:31 +00:00
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:
parent
53ad982bb7
commit
43973f2d0a
Notes:
github-actions[bot]
2024-10-05 08:47:44 +00:00
Author: https://github.com/shannonbooth
Commit: 43973f2d0a
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/1636
5 changed files with 58 additions and 33 deletions
|
@ -1,6 +1,7 @@
|
|||
set(SOURCES
|
||||
URL.cpp
|
||||
Origin.cpp
|
||||
Parser.cpp
|
||||
URL.cpp
|
||||
)
|
||||
|
||||
serenity_lib(LibURL url)
|
||||
|
|
50
Userland/Libraries/LibURL/Origin.cpp
Normal file
50
Userland/Libraries/LibURL/Origin.cpp
Normal 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
|
|
@ -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
|
||||
|
|
|
@ -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>
|
||||
|
|
|
@ -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>
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue