blob: 7b218aef8bf77033927443737569e354ae1f72e5 [file] [log] [blame]
// Copyright 2016 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 "third_party/blink/renderer/core/layout/depth_ordered_layout_object_list.h"
#include <algorithm>
#include "third_party/blink/renderer/core/frame/local_frame_view.h"
#include "third_party/blink/renderer/core/layout/layout_object.h"
namespace blink {
struct DepthOrderedLayoutObjectListData {
// LayoutObjects sorted by depth (deepest first). This structure is only
// populated at the beginning of enumerations. See ordered().
Vector<DepthOrderedLayoutObjectList::LayoutObjectWithDepth> ordered_objects_;
// Outside of layout, LayoutObjects can be added and removed as needed such
// as when style was changed or destroyed. They're kept in this hashset to
// keep those operations fast.
HashSet<LayoutObject*> objects_;
};
DepthOrderedLayoutObjectList::DepthOrderedLayoutObjectList()
: data_(new DepthOrderedLayoutObjectListData) {}
DepthOrderedLayoutObjectList::~DepthOrderedLayoutObjectList() {
delete data_;
}
int DepthOrderedLayoutObjectList::size() const {
return data_->objects_.size();
}
bool DepthOrderedLayoutObjectList::IsEmpty() const {
return data_->objects_.IsEmpty();
}
void DepthOrderedLayoutObjectList::Add(LayoutObject& object) {
DCHECK(!object.GetFrameView()->IsInPerformLayout());
data_->objects_.insert(&object);
data_->ordered_objects_.clear();
}
void DepthOrderedLayoutObjectList::Remove(LayoutObject& object) {
auto it = data_->objects_.find(&object);
if (it == data_->objects_.end())
return;
DCHECK(!object.GetFrameView()->IsInPerformLayout());
data_->objects_.erase(it);
data_->ordered_objects_.clear();
}
void DepthOrderedLayoutObjectList::Clear() {
data_->objects_.clear();
data_->ordered_objects_.clear();
}
unsigned DepthOrderedLayoutObjectList::LayoutObjectWithDepth::DetermineDepth(
LayoutObject* object) {
unsigned depth = 1;
for (LayoutObject* parent = object->Parent(); parent;
parent = parent->Parent())
++depth;
return depth;
}
const HashSet<LayoutObject*>& DepthOrderedLayoutObjectList::Unordered() const {
return data_->objects_;
}
const Vector<DepthOrderedLayoutObjectList::LayoutObjectWithDepth>&
DepthOrderedLayoutObjectList::Ordered() {
if (data_->objects_.IsEmpty() || !data_->ordered_objects_.IsEmpty())
return data_->ordered_objects_;
CopyToVector(data_->objects_, data_->ordered_objects_);
std::sort(data_->ordered_objects_.begin(), data_->ordered_objects_.end());
return data_->ordered_objects_;
}
} // namespace blink