xref: /aosp_15_r20/external/pigweed/pw_containers/aa_tree.cc (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker // Copyright 2024 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker //     https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker 
15*61c4878aSAndroid Build Coastguard Worker #include "pw_containers/internal/aa_tree.h"
16*61c4878aSAndroid Build Coastguard Worker 
17*61c4878aSAndroid Build Coastguard Worker namespace pw::containers::internal {
18*61c4878aSAndroid Build Coastguard Worker 
SetRoot(AATreeItem * item)19*61c4878aSAndroid Build Coastguard Worker void GenericAATree::SetRoot(AATreeItem* item) {
20*61c4878aSAndroid Build Coastguard Worker   if (item != nullptr) {
21*61c4878aSAndroid Build Coastguard Worker     item->parent_.set(nullptr);
22*61c4878aSAndroid Build Coastguard Worker   }
23*61c4878aSAndroid Build Coastguard Worker   root_ = item;
24*61c4878aSAndroid Build Coastguard Worker }
25*61c4878aSAndroid Build Coastguard Worker 
size() const26*61c4878aSAndroid Build Coastguard Worker size_t GenericAATree::size() const {
27*61c4878aSAndroid Build Coastguard Worker   return empty() ? 0 : root_->GetTreeSize();
28*61c4878aSAndroid Build Coastguard Worker }
29*61c4878aSAndroid Build Coastguard Worker 
clear()30*61c4878aSAndroid Build Coastguard Worker void GenericAATree::clear() {
31*61c4878aSAndroid Build Coastguard Worker   if (root_ != nullptr) {
32*61c4878aSAndroid Build Coastguard Worker     root_->Clear();
33*61c4878aSAndroid Build Coastguard Worker     SetRoot(nullptr);
34*61c4878aSAndroid Build Coastguard Worker   }
35*61c4878aSAndroid Build Coastguard Worker }
36*61c4878aSAndroid Build Coastguard Worker 
erase_one(AATreeItem & item)37*61c4878aSAndroid Build Coastguard Worker GenericAATree::iterator GenericAATree::erase_one(AATreeItem& item) {
38*61c4878aSAndroid Build Coastguard Worker   if (item.GetRoot() != root_) {
39*61c4878aSAndroid Build Coastguard Worker     return iterator(&root_);
40*61c4878aSAndroid Build Coastguard Worker   }
41*61c4878aSAndroid Build Coastguard Worker   AATreeItem* next = item.GetSuccessor();
42*61c4878aSAndroid Build Coastguard Worker   SetRoot(item.Unmap());
43*61c4878aSAndroid Build Coastguard Worker   return iterator(&root_, next);
44*61c4878aSAndroid Build Coastguard Worker }
45*61c4878aSAndroid Build Coastguard Worker 
erase_range(AATreeItem & first,AATreeItem & last)46*61c4878aSAndroid Build Coastguard Worker GenericAATree::iterator GenericAATree::erase_range(AATreeItem& first,
47*61c4878aSAndroid Build Coastguard Worker                                                    AATreeItem& last) {
48*61c4878aSAndroid Build Coastguard Worker   iterator iter(&root_, &first);
49*61c4878aSAndroid Build Coastguard Worker   while (&(*iter) != &last) {
50*61c4878aSAndroid Build Coastguard Worker     iter = erase_one(*iter);
51*61c4878aSAndroid Build Coastguard Worker   }
52*61c4878aSAndroid Build Coastguard Worker   return iter;
53*61c4878aSAndroid Build Coastguard Worker }
54*61c4878aSAndroid Build Coastguard Worker 
swap(GenericAATree & other)55*61c4878aSAndroid Build Coastguard Worker void GenericAATree::swap(GenericAATree& other) {
56*61c4878aSAndroid Build Coastguard Worker   std::swap(root_, other.root_);
57*61c4878aSAndroid Build Coastguard Worker }
58*61c4878aSAndroid Build Coastguard Worker 
59*61c4878aSAndroid Build Coastguard Worker }  // namespace pw::containers::internal
60