arkcompiler_ets_runtime/ecmascript/weak_vector.h
dingding 86ed7e81ef Eliminate Level Check in SubTyping Check
1. Use fixed length(WeakVector::DEFAULT_CAPACITY) supers array as default supers of hclass.
2. Eliminate level check if level is less than DEFAULT_CAPACITY.

Issue: https://gitee.com/openharmony/arkcompiler_ets_runtime/issues/I70J0X

Signed-off-by: dingding <dingding5@huawei.com>
Change-Id: I81227d1e766f28621050e0c0c4c7893fff347af4
2023-05-05 17:19:00 +08:00

115 lines
3.8 KiB
C++

/*
* Copyright (c) 2021 Huawei Device Co., Ltd.
* 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 ECMASCRIPT_WEAK_VECTOR_H
#define ECMASCRIPT_WEAK_VECTOR_H
#include "ecmascript/js_handle.h"
#include "ecmascript/js_thread.h"
#include "ecmascript/tagged_array-inl.h"
namespace panda::ecmascript {
class WeakVector : public TaggedArray {
public:
enum ElementType {
NORMAL = 0,
WEAK,
};
static WeakVector *Cast(TaggedObject *object)
{
return static_cast<WeakVector *>(object);
}
static constexpr uint32_t DEFAULT_CAPACITY = 4;
static constexpr uint32_t DEFAULT_GROW_SIZE = 4;
static JSHandle<WeakVector> Create(const JSThread *thread, uint32_t capacity = DEFAULT_CAPACITY);
static JSHandle<WeakVector> Grow(const JSThread *thread, const JSHandle<WeakVector> &old, uint32_t newCapacity);
static JSHandle<WeakVector> Append(const JSThread *thread, const JSHandle<WeakVector> &vec,
const JSHandle<JSTaggedValue> &value, ElementType type = ElementType::NORMAL);
static JSHandle<WeakVector> FillOrAppend(const JSThread *thread, const JSHandle<WeakVector> &vec,
const JSHandle<JSTaggedValue> &value,
ElementType type = ElementType::NORMAL);
static JSHandle<WeakVector> Copy(const JSThread *thread, const JSHandle<WeakVector> &vec, bool needExtend = false);
uint32_t PushBack(const JSThread *thread, JSTaggedValue value);
// just set index value to Hole
bool Delete(const JSThread *thread, uint32_t index);
inline uint32_t GetEnd() const
{
return TaggedArray::GetExtraLength();
}
inline bool Full() const
{
return GetEnd() == GetCapacity();
}
inline bool Empty() const
{
return GetEnd() == 0;
}
inline uint32_t GetCapacity() const
{
return TaggedArray::GetLength();
}
inline JSTaggedValue Get(uint32_t index) const
{
ASSERT(index < GetCapacity());
return TaggedArray::Get(VectorToArrayIndex(index));
}
inline void Set(const JSThread *thread, uint32_t index, JSTaggedValue value)
{
ASSERT(index < GetCapacity());
TaggedArray::Set(thread, VectorToArrayIndex(index), value);
}
template <class Callback>
void Iterate(const Callback &cb)
{
uint32_t end = GetEnd();
for (uint32_t index = 0; index < end; ++index) {
cb(Get(index));
}
}
private:
static const uint32_t MIN_CAPACITY = 2;
static const uint32_t MAX_VECTOR_INDEX = TaggedArray::MAX_ARRAY_INDEX;
inline static constexpr uint32_t VectorToArrayIndex(uint32_t index)
{
return index;
}
inline void SetEnd([[maybe_unused]] const JSThread *thread, uint32_t end)
{
ASSERT(end <= GetCapacity());
SetExtraLength(end);
}
static JSTaggedValue GetStoreVal(const JSHandle<JSTaggedValue> &value, ElementType type);
static uint32_t CheckHole(const JSHandle<WeakVector> &vec);
static JSHandle<WeakVector> AppendToFullVec(const JSThread *thread, const JSHandle<WeakVector> &vec,
const JSHandle<JSTaggedValue> &value, ElementType type);
};
} // namespace panda::ecmascript
#endif // ECMASCRIPT_WEAK_VECTOR_H