From 7b793245481bcdbe01672eda1303a2ee329a6523 Mon Sep 17 00:00:00 2001 From: Shannon Booth Date: Sat, 26 Aug 2023 16:46:33 +1200 Subject: [PATCH] LibWeb: Port Range interface from DeprecatedString to String --- Userland/Libraries/LibWeb/DOM/Range.cpp | 10 +++++----- Userland/Libraries/LibWeb/DOM/Range.h | 4 ++-- Userland/Libraries/LibWeb/Selection/Selection.cpp | 2 +- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/Userland/Libraries/LibWeb/DOM/Range.cpp b/Userland/Libraries/LibWeb/DOM/Range.cpp index 49c62ab92ab..57a7793e683 100644 --- a/Userland/Libraries/LibWeb/DOM/Range.cpp +++ b/Userland/Libraries/LibWeb/DOM/Range.cpp @@ -551,7 +551,7 @@ WebIDL::ExceptionOr Range::compare_point(Node const& node, u32 offset) cons } // https://dom.spec.whatwg.org/#dom-range-stringifier -DeprecatedString Range::to_deprecated_string() const +String Range::to_string() const { // 1. Let s be the empty string. StringBuilder builder; @@ -559,7 +559,7 @@ DeprecatedString Range::to_deprecated_string() const // 2. If this’s start node is this’s end node and it is a Text node, // then return the substring of that Text node’s data beginning at this’s start offset and ending at this’s end offset. if (start_container() == end_container() && is(*start_container())) - return static_cast(*start_container()).data().substring(start_offset(), end_offset() - start_offset()); + return String::from_deprecated_string(static_cast(*start_container()).data().substring(start_offset(), end_offset() - start_offset())).release_value(); // 3. If this’s start node is a Text node, then append the substring of that node’s data from this’s start offset until the end to s. if (is(*start_container())) @@ -576,7 +576,7 @@ DeprecatedString Range::to_deprecated_string() const builder.append(static_cast(*end_container()).data().substring_view(0, end_offset())); // 6. Return s. - return builder.to_deprecated_string(); + return MUST(builder.to_string()); } // https://dom.spec.whatwg.org/#dom-range-extractcontents @@ -1145,7 +1145,7 @@ JS::NonnullGCPtr Range::get_bounding_client_rect() const } // https://w3c.github.io/DOM-Parsing/#dom-range-createcontextualfragment -WebIDL::ExceptionOr> Range::create_contextual_fragment(DeprecatedString const& fragment) +WebIDL::ExceptionOr> Range::create_contextual_fragment(String const& fragment) { // 1. Let node be the context object's start node. JS::NonnullGCPtr node = *start_container(); @@ -1185,7 +1185,7 @@ WebIDL::ExceptionOr> Range::create_contextual } // 3. Let fragment node be the result of invoking the fragment parsing algorithm with fragment as markup, and element as the context element. - auto fragment_node = TRY(DOMParsing::parse_fragment(fragment, *element)); + auto fragment_node = TRY(DOMParsing::parse_fragment(fragment.to_deprecated_string(), *element)); // 4. Unmark all scripts in fragment node as "already started" and as "parser-inserted". fragment_node->for_each_in_subtree_of_type([&](HTML::HTMLScriptElement& script_element) { diff --git a/Userland/Libraries/LibWeb/DOM/Range.h b/Userland/Libraries/LibWeb/DOM/Range.h index 97f20f852af..a855ec90816 100644 --- a/Userland/Libraries/LibWeb/DOM/Range.h +++ b/Userland/Libraries/LibWeb/DOM/Range.h @@ -79,7 +79,7 @@ public: WebIDL::ExceptionOr insert_node(JS::NonnullGCPtr); WebIDL::ExceptionOr surround_contents(JS::NonnullGCPtr new_parent); - DeprecatedString to_deprecated_string() const; + String to_string() const; static HashTable& live_ranges(); @@ -89,7 +89,7 @@ public: void set_associated_selection(Badge, JS::GCPtr); - WebIDL::ExceptionOr> create_contextual_fragment(DeprecatedString const& fragment); + WebIDL::ExceptionOr> create_contextual_fragment(String const& fragment); private: explicit Range(Document&); diff --git a/Userland/Libraries/LibWeb/Selection/Selection.cpp b/Userland/Libraries/LibWeb/Selection/Selection.cpp index 2bb2fc75bda..1047cc0d447 100644 --- a/Userland/Libraries/LibWeb/Selection/Selection.cpp +++ b/Userland/Libraries/LibWeb/Selection/Selection.cpp @@ -427,7 +427,7 @@ String Selection::to_string() const // See https://www.w3.org/Bugs/Public/show_bug.cgi?id=10583 if (!m_range) return String {}; - return String::from_deprecated_string(m_range->to_deprecated_string()).release_value(); + return m_range->to_string(); } JS::NonnullGCPtr Selection::document() const