1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
// Copyright 2021 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef THIRD_PARTY_BLINK_RENDERER_CORE_HIGHLIGHT_HIGHLIGHT_REGISTRY_H_
#define THIRD_PARTY_BLINK_RENDERER_CORE_HIGHLIGHT_HIGHLIGHT_REGISTRY_H_
#include "third_party/blink/renderer/bindings/core/v8/maplike.h"
#include "third_party/blink/renderer/core/core_export.h"
#include "third_party/blink/renderer/core/highlight/highlight.h"
#include "third_party/blink/renderer/core/highlight/highlight_registry_map_entry.h"
#include "third_party/blink/renderer/platform/bindings/script_wrappable.h"
#include "third_party/blink/renderer/platform/heap/heap_allocator.h"
#include "third_party/blink/renderer/platform/wtf/forward.h"
#include "third_party/blink/renderer/platform/wtf/text/atomic_string_hash.h"
namespace blink {
// Using LinkedHashSet<HighlightRegistryMapEntry> to store the map entries
// because order of insertion needs to be preserved (for iteration and breaking
// priority ties during painting) and there's no generic LinkedHashMap. Note
// that the hash functions for HighlightRegistryMapEntry don't allow storing
// more than one entry with the same key (highlight name).
using HighlightRegistryMap =
HeapLinkedHashSet<Member<HighlightRegistryMapEntry>,
HashTraits<Member<HighlightRegistryMapEntry>>>;
using HighlightRegistryMapIterable = Maplike<AtomicString, Member<Highlight>>;
class LocalFrame;
class CORE_EXPORT HighlightRegistry : public ScriptWrappable,
public Supplement<LocalDOMWindow>,
public HighlightRegistryMapIterable {
DEFINE_WRAPPERTYPEINFO();
public:
static const char kSupplementName[];
static HighlightRegistry* From(LocalDOMWindow&);
explicit HighlightRegistry(LocalDOMWindow&);
~HighlightRegistry() override;
void Trace(blink::Visitor*) const override;
HighlightRegistry* setForBinding(ScriptState*,
AtomicString,
Member<Highlight>,
ExceptionState&);
void clearForBinding(ScriptState*, ExceptionState&);
bool deleteForBinding(ScriptState*, const AtomicString&, ExceptionState&);
wtf_size_t size() const { return highlights_.size(); }
const HighlightRegistryMap& GetHighlights() const { return highlights_; }
void ValidateHighlightMarkers();
void ScheduleRepaint() const;
enum OverlayStackingPosition {
kOverlayStackingPositionBelow = -1,
kOverlayStackingPositionEquivalent = 0,
kOverlayStackingPositionAbove = 1,
};
int8_t CompareOverlayStackingPosition(const AtomicString& highlight_name1,
const Highlight* highlight1,
const AtomicString& highlight_name2,
const Highlight* highlight2) const;
class IterationSource final
: public HighlightRegistryMapIterable::IterationSource {
public:
explicit IterationSource(const HighlightRegistry& highlight_registry);
bool Next(ScriptState*,
AtomicString&,
Member<Highlight>&,
ExceptionState&) override;
void Trace(blink::Visitor*) const override;
private:
wtf_size_t index_;
HeapVector<Member<HighlightRegistryMapEntry>> highlights_snapshot_;
};
private:
HighlightRegistryMap highlights_;
Member<LocalFrame> frame_;
HighlightRegistryMap::iterator GetMapIterator(const AtomicString& key) {
return highlights_.find(
MakeGarbageCollected<HighlightRegistryMapEntry>(key));
}
bool GetMapEntry(ScriptState*,
const AtomicString& key,
Member<Highlight>& value,
ExceptionState&) override {
auto iterator = GetMapIterator(key);
if (iterator == highlights_.end())
return false;
value = iterator->Get()->highlight;
return true;
}
HighlightRegistryMapIterable::IterationSource* StartIteration(
ScriptState*,
ExceptionState&) override;
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_RENDERER_CORE_HIGHLIGHT_HIGHLIGHT_REGISTRY_H_
|