| Index: third_party/WebKit/Source/core/editing/markers/TextMatchMarker.cpp
|
| diff --git a/third_party/WebKit/Source/core/editing/markers/TextMatchMarker.cpp b/third_party/WebKit/Source/core/editing/markers/TextMatchMarker.cpp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..efa13dba9e321d7a6c708a1694f77288b37f1db4
|
| --- /dev/null
|
| +++ b/third_party/WebKit/Source/core/editing/markers/TextMatchMarker.cpp
|
| @@ -0,0 +1,42 @@
|
| +// Copyright 2017 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.
|
| +
|
| +#include "core/editing/markers/TextMatchMarker.h"
|
| +
|
| +#include "core/dom/Range.h"
|
| +
|
| +namespace blink {
|
| +
|
| +TextMatchMarker::TextMatchMarker(unsigned start_offset,
|
| + unsigned end_offset,
|
| + DocumentMarker::MatchStatus match_status)
|
| + : DocumentMarker(start_offset, end_offset, match_status),
|
| + state_(State::kInvalid) {}
|
| +
|
| +void TextMatchMarker::UpdateRenderedRectIfNeeded(const Node& node) {
|
| + if (!IsValid())
|
| + UpdateRenderedRect(node);
|
| +}
|
| +
|
| +void TextMatchMarker::UpdateRenderedRect(const Node& node) {
|
| + Range* range = Range::Create(node.GetDocument());
|
| + // The offsets of the marker may be out-dated, so check for exceptions.
|
| + DummyExceptionStateForTesting exceptionState;
|
| + range->setStart(&const_cast<Node&>(node), StartOffset(), exceptionState);
|
| + if (!exceptionState.HadException()) {
|
| + range->setEnd(&const_cast<Node&>(node), EndOffset(),
|
| + IGNORE_EXCEPTION_FOR_TESTING);
|
| + }
|
| +
|
| + if (!exceptionState.HadException()) {
|
| + // TODO(yosin): Once we have a |EphemeralRange| version of
|
| + // |boundingBox()|, we should use it instead of |Range| version.
|
| + SetRenderedRect(LayoutRect(range->BoundingBox()));
|
| + } else {
|
| + NullifyRenderedRect();
|
| + }
|
| + range->Dispose();
|
| +}
|
| +
|
| +} // namespace blink
|
|
|