xref: /aosp_15_r20/system/chre/util/dynamic_vector_base.cc (revision 84e339476a462649f82315436d70fd732297a399)
1*84e33947SAndroid Build Coastguard Worker /*
2*84e33947SAndroid Build Coastguard Worker  * Copyright (C) 2018 The Android Open Source Project
3*84e33947SAndroid Build Coastguard Worker  *
4*84e33947SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*84e33947SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*84e33947SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*84e33947SAndroid Build Coastguard Worker  *
8*84e33947SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*84e33947SAndroid Build Coastguard Worker  *
10*84e33947SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*84e33947SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*84e33947SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*84e33947SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*84e33947SAndroid Build Coastguard Worker  * limitations under the License.
15*84e33947SAndroid Build Coastguard Worker  */
16*84e33947SAndroid Build Coastguard Worker 
17*84e33947SAndroid Build Coastguard Worker #include "chre/util/dynamic_vector_base.h"
18*84e33947SAndroid Build Coastguard Worker 
19*84e33947SAndroid Build Coastguard Worker #include <cstdint>
20*84e33947SAndroid Build Coastguard Worker #include <cstring>
21*84e33947SAndroid Build Coastguard Worker 
22*84e33947SAndroid Build Coastguard Worker #include "chre/util/container_support.h"
23*84e33947SAndroid Build Coastguard Worker 
24*84e33947SAndroid Build Coastguard Worker namespace chre {
25*84e33947SAndroid Build Coastguard Worker 
DynamicVectorBase(DynamicVectorBase && other)26*84e33947SAndroid Build Coastguard Worker DynamicVectorBase::DynamicVectorBase(DynamicVectorBase &&other)
27*84e33947SAndroid Build Coastguard Worker     : mData(other.mData), mSize(other.mSize), mCapacity(other.mCapacity) {
28*84e33947SAndroid Build Coastguard Worker   other.mData = nullptr;
29*84e33947SAndroid Build Coastguard Worker   other.mSize = 0;
30*84e33947SAndroid Build Coastguard Worker   other.mCapacity = 0;
31*84e33947SAndroid Build Coastguard Worker }
32*84e33947SAndroid Build Coastguard Worker 
doReserve(size_t newCapacity,size_t elementSize)33*84e33947SAndroid Build Coastguard Worker bool DynamicVectorBase::doReserve(size_t newCapacity, size_t elementSize) {
34*84e33947SAndroid Build Coastguard Worker   bool success = (newCapacity <= mCapacity);
35*84e33947SAndroid Build Coastguard Worker   if (!success) {
36*84e33947SAndroid Build Coastguard Worker     void *newData = memoryAlloc(newCapacity * elementSize);
37*84e33947SAndroid Build Coastguard Worker     if (newData != nullptr) {
38*84e33947SAndroid Build Coastguard Worker       if (mData != nullptr) {
39*84e33947SAndroid Build Coastguard Worker         memcpy(newData, mData, mSize * elementSize);
40*84e33947SAndroid Build Coastguard Worker         memoryFree(mData);
41*84e33947SAndroid Build Coastguard Worker       }
42*84e33947SAndroid Build Coastguard Worker       mData = newData;
43*84e33947SAndroid Build Coastguard Worker       mCapacity = newCapacity;
44*84e33947SAndroid Build Coastguard Worker       success = true;
45*84e33947SAndroid Build Coastguard Worker     }
46*84e33947SAndroid Build Coastguard Worker   }
47*84e33947SAndroid Build Coastguard Worker 
48*84e33947SAndroid Build Coastguard Worker   return success;
49*84e33947SAndroid Build Coastguard Worker }
50*84e33947SAndroid Build Coastguard Worker 
doPrepareForPush(size_t elementSize)51*84e33947SAndroid Build Coastguard Worker bool DynamicVectorBase::doPrepareForPush(size_t elementSize) {
52*84e33947SAndroid Build Coastguard Worker   return doReserve(getNextGrowthCapacity(), elementSize);
53*84e33947SAndroid Build Coastguard Worker }
54*84e33947SAndroid Build Coastguard Worker 
getNextGrowthCapacity() const55*84e33947SAndroid Build Coastguard Worker size_t DynamicVectorBase::getNextGrowthCapacity() const {
56*84e33947SAndroid Build Coastguard Worker   size_t newCapacity;
57*84e33947SAndroid Build Coastguard Worker   if (mCapacity == 0) {
58*84e33947SAndroid Build Coastguard Worker     newCapacity = 1;
59*84e33947SAndroid Build Coastguard Worker   } else if (mSize == mCapacity) {
60*84e33947SAndroid Build Coastguard Worker     newCapacity = mCapacity * 2;
61*84e33947SAndroid Build Coastguard Worker   } else {
62*84e33947SAndroid Build Coastguard Worker     newCapacity = mCapacity;
63*84e33947SAndroid Build Coastguard Worker   }
64*84e33947SAndroid Build Coastguard Worker 
65*84e33947SAndroid Build Coastguard Worker   return newCapacity;
66*84e33947SAndroid Build Coastguard Worker }
67*84e33947SAndroid Build Coastguard Worker 
doErase(size_t index,size_t elementSize)68*84e33947SAndroid Build Coastguard Worker void DynamicVectorBase::doErase(size_t index, size_t elementSize) {
69*84e33947SAndroid Build Coastguard Worker   mSize--;
70*84e33947SAndroid Build Coastguard Worker   size_t moveAmount = (mSize - index) * elementSize;
71*84e33947SAndroid Build Coastguard Worker   memmove(static_cast<uint8_t *>(mData) + (index * elementSize),
72*84e33947SAndroid Build Coastguard Worker           static_cast<uint8_t *>(mData) + ((index + 1) * elementSize),
73*84e33947SAndroid Build Coastguard Worker           moveAmount);
74*84e33947SAndroid Build Coastguard Worker }
75*84e33947SAndroid Build Coastguard Worker 
doPushBack(const void * element,size_t elementSize)76*84e33947SAndroid Build Coastguard Worker bool DynamicVectorBase::doPushBack(const void *element, size_t elementSize) {
77*84e33947SAndroid Build Coastguard Worker   bool spaceAvailable = doPrepareForPush(elementSize);
78*84e33947SAndroid Build Coastguard Worker   if (spaceAvailable) {
79*84e33947SAndroid Build Coastguard Worker     memcpy(static_cast<uint8_t *>(mData) + (mSize * elementSize), element,
80*84e33947SAndroid Build Coastguard Worker            elementSize);
81*84e33947SAndroid Build Coastguard Worker     mSize++;
82*84e33947SAndroid Build Coastguard Worker   }
83*84e33947SAndroid Build Coastguard Worker 
84*84e33947SAndroid Build Coastguard Worker   return spaceAvailable;
85*84e33947SAndroid Build Coastguard Worker }
86*84e33947SAndroid Build Coastguard Worker 
87*84e33947SAndroid Build Coastguard Worker }  // namespace chre
88