Blame view

Pods/Realm/include/core/realm/array_key.hpp 3.26 KB
75d24c15   yangbin   123
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
  /*************************************************************************
   *
   * Copyright 2016 Realm Inc.
   *
   * Licensed under the Apache License, Version 2.0 (the "License");
   * you may not use this file except in compliance with the License.
   * You may obtain a copy of the License at
   *
   * http://www.apache.org/licenses/LICENSE-2.0
   *
   * Unless required by applicable law or agreed to in writing, software
   * distributed under the License is distributed on an "AS IS" BASIS,
   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   * See the License for the specific language governing permissions and
   * limitations under the License.
   *
   **************************************************************************/
  
  #ifndef REALM_ARRAY_KEY_HPP
  #define REALM_ARRAY_KEY_HPP
  
  #include <realm/array.hpp>
  #include <realm/cluster.hpp>
  #include <realm/impl/destroy_guard.hpp>
  
  namespace realm {
  
  // If this class is used directly in a cluster leaf, the links are stored as the
  // link value +1 in order to represent the null_key (-1) as 0. If the class is used
  // in BPlusTree<ObjKey> class, the values should not be adjusted.
  template <int adj>
  class ArrayKeyBase : public ArrayPayload, private Array {
  public:
      using value_type = ObjKey;
  
      using Array::is_attached;
      using Array::init_from_mem;
      using Array::init_from_parent;
      using Array::update_parent;
      using Array::get_ref;
      using Array::size;
      using Array::erase;
      using Array::clear;
      using Array::destroy;
  
      ArrayKeyBase(Allocator& allocator)
          : Array(allocator)
      {
      }
  
      static ObjKey default_value(bool)
      {
          return {};
      }
  
      void init_from_ref(ref_type ref) noexcept override
      {
          Array::init_from_ref(ref);
      }
  
      void set_parent(ArrayParent* parent, size_t ndx_in_parent) noexcept override
      {
          Array::set_parent(parent, ndx_in_parent);
      }
  
      void create()
      {
          Array::create(type_Normal);
      }
  
      void add(ObjKey value)
      {
          Array::add(value.value + adj);
      }
      void set(size_t ndx, ObjKey value)
      {
          Array::set(ndx, value.value + adj);
      }
  
      void set_null(size_t ndx)
      {
          Array::set(ndx, 0);
      }
      void insert(size_t ndx, ObjKey value)
      {
          Array::insert(ndx, value.value + adj);
      }
      ObjKey get(size_t ndx) const
      {
          return ObjKey{Array::get(ndx) - adj};
      }
      Mixed get_any(size_t ndx) const override
      {
          return Mixed(get(ndx));
      }
      bool is_null(size_t ndx) const
      {
          ObjKey key = get(ndx);
          return !key || key.is_unresolved();
      }
      void move(ArrayKeyBase& dst, size_t ndx)
      {
          Array::move(dst, ndx);
      }
  
      size_t find_first(ObjKey value, size_t begin, size_t end) const noexcept
      {
          return Array::find_first(value.value + adj, begin, end);
      }
  
      void nullify(ObjKey key)
      {
          size_t begin = find_first(key, 0, Array::size());
          // There must be one
          REALM_ASSERT(begin != realm::npos);
          Array::erase(begin);
      }
      void verify() const;
  };
  
  class ArrayKey : public ArrayKeyBase<1> {
  public:
      using ArrayKeyBase::ArrayKeyBase;
  };
  
  class ArrayKeyNonNullable : public ArrayKeyBase<0> {
  public:
      using ArrayKeyBase::ArrayKeyBase;
  };
  }
  
  #endif /* SRC_REALM_ARRAY_KEY_HPP_ */