
This commit un-deprecates DeprecatedString, and repurposes it as a byte string. As the null state has already been removed, there are no other particularly hairy blockers in repurposing this type as a byte string (what it _really_ is). This commit is auto-generated: $ xs=$(ack -l \bDeprecatedString\b\|deprecated_string AK Userland \ Meta Ports Ladybird Tests Kernel) $ perl -pie 's/\bDeprecatedString\b/ByteString/g; s/deprecated_string/byte_string/g' $xs $ clang-format --style=file -i \ $(git diff --name-only | grep \.cpp\|\.h) $ gn format $(git ls-files '*.gn' '*.gni')
35 lines
909 B
C++
35 lines
909 B
C++
/*
|
|
* Copyright (c) 2021, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibWeb/DOM/CharacterData.h>
|
|
|
|
namespace Web::DOM {
|
|
|
|
class ProcessingInstruction final : public CharacterData {
|
|
WEB_PLATFORM_OBJECT(ProcessingInstruction, CharacterData);
|
|
JS_DECLARE_ALLOCATOR(ProcessingInstruction);
|
|
|
|
public:
|
|
virtual ~ProcessingInstruction() override = default;
|
|
|
|
virtual FlyString node_name() const override { return MUST(FlyString::from_deprecated_fly_string(m_target)); }
|
|
|
|
ByteString const& target() const { return m_target; }
|
|
|
|
private:
|
|
ProcessingInstruction(Document&, ByteString const& data, ByteString const& target);
|
|
|
|
virtual void initialize(JS::Realm&) override;
|
|
|
|
ByteString m_target;
|
|
};
|
|
|
|
template<>
|
|
inline bool Node::fast_is<ProcessingInstruction>() const { return node_type() == (u16)NodeType::PROCESSING_INSTRUCTION_NODE; }
|
|
|
|
}
|