mirror of
https://gitee.com/openharmony/arkcompiler_ets_runtime
synced 2024-10-07 16:13:49 +00:00
7b47de5a55
Signed-off-by: hwx1163501 <hanjing35@huawei.com> https://gitee.com/openharmony/arkcompiler_ets_runtime/issues/I7LLDJ
126 lines
7.1 KiB
C++
126 lines
7.1 KiB
C++
/*
|
|
* Copyright (c) 2022 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_JS_API_LIGHTWEIGHTMAP_H
|
|
#define ECMASCRIPT_JS_API_LIGHTWEIGHTMAP_H
|
|
|
|
#include "ecmascript/js_object.h"
|
|
#include "ecmascript/js_tagged_value-inl.h"
|
|
|
|
namespace panda::ecmascript {
|
|
enum class AccossorsKind { HASH = 0, KEY, VALUE };
|
|
struct HashParams {
|
|
JSHandle<TaggedArray> hashArray;
|
|
JSHandle<TaggedArray> keyArray;
|
|
JSTaggedValue *key;
|
|
};
|
|
|
|
// The status of the KEY in the container, including whether the KEY exists,
|
|
// the HASH corresponding to the KEY, and the INDEX where the KEY is located or will be inserted.
|
|
struct KeyState {
|
|
bool existed;
|
|
int32_t hash;
|
|
int32_t index;
|
|
};
|
|
class JSAPILightWeightMap : public JSObject {
|
|
public:
|
|
static constexpr int DEFAULT_CAPACITY_LENGTH = 8;
|
|
static constexpr int32_t HASH_REBELLION = 0xFFFFFFFF;
|
|
static JSAPILightWeightMap *Cast(TaggedObject *object)
|
|
{
|
|
ASSERT(JSTaggedValue(object).IsJSAPILightWeightMap());
|
|
return static_cast<JSAPILightWeightMap *>(object);
|
|
}
|
|
static void InsertValue(const JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
int32_t index, const JSHandle<JSTaggedValue> &value, AccossorsKind kind);
|
|
static void ReplaceValue(const JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
int32_t index, const JSHandle<JSTaggedValue> &value, AccossorsKind kind);
|
|
static void Set(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &key, const JSHandle<JSTaggedValue> &value);
|
|
static JSTaggedValue Get(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &key);
|
|
static JSTaggedValue HasAll(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSAPILightWeightMap> &newLightWeightMap);
|
|
static JSTaggedValue HasKey(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &key);
|
|
static JSTaggedValue HasValue(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &value);
|
|
static int32_t GetIndexOfKey(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &key);
|
|
static KeyState GetStateOfKey(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &key);
|
|
static int32_t GetIndexOfValue(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &value);
|
|
static JSTaggedValue GetKeyAt(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap, int32_t index);
|
|
static void SetAll(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSAPILightWeightMap> &newLightWeightMap);
|
|
static JSTaggedValue Remove(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<JSTaggedValue> &key);
|
|
static JSTaggedValue RemoveAt(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap, int32_t index);
|
|
static void Clear(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap);
|
|
static JSTaggedValue SetValueAt(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
int32_t index, const JSHandle<JSTaggedValue> &value);
|
|
static JSTaggedValue IncreaseCapacityTo(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
int32_t index);
|
|
static JSTaggedValue ToString(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap);
|
|
static JSTaggedValue GetValueAt(JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
int32_t index);
|
|
static JSTaggedValue GetIteratorObj(JSThread *thread, const JSHandle<JSAPILightWeightMap> &obj, IterationKind type);
|
|
static bool GetOwnProperty(JSThread *thread, const JSHandle<JSAPILightWeightMap> &map,
|
|
const JSHandle<JSTaggedValue> &key,
|
|
PropertyDescriptor &desc);
|
|
JSTaggedValue IsEmpty();
|
|
inline uint32_t GetSize() const
|
|
{
|
|
return GetLength();
|
|
}
|
|
|
|
static constexpr size_t LWP_HASHES_OFFSET = JSObject::SIZE;
|
|
ACCESSORS(Hashes, LWP_HASHES_OFFSET, LWP_KEYS_OFFSET);
|
|
ACCESSORS(Keys, LWP_KEYS_OFFSET, LWP_VALUES_OFFSET);
|
|
ACCESSORS(Values, LWP_VALUES_OFFSET, LWP_LENGTH_OFFSET);
|
|
ACCESSORS_PRIMITIVE_FIELD(Length, uint32_t, LWP_LENGTH_OFFSET, LAST_OFFSET);
|
|
DEFINE_ALIGN_SIZE(LAST_OFFSET);
|
|
|
|
DECL_VISIT_OBJECT_FOR_JS_OBJECT(JSObject, LWP_HASHES_OFFSET, LWP_LENGTH_OFFSET)
|
|
DECL_DUMP()
|
|
|
|
private:
|
|
static inline uint32_t ComputeCapacity(uint32_t oldCapacity)
|
|
{
|
|
uint32_t newCapacity = oldCapacity + (oldCapacity >> 1U);
|
|
return newCapacity > DEFAULT_CAPACITY_LENGTH ? newCapacity : DEFAULT_CAPACITY_LENGTH;
|
|
};
|
|
static JSHandle<TaggedArray> GrowCapacity(const JSThread *thread, JSHandle<TaggedArray> &oldArray,
|
|
uint32_t needCapacity);
|
|
static void SetArrayByKind(const JSThread *thread,
|
|
const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
const JSHandle<TaggedArray> &array,
|
|
AccossorsKind kind);
|
|
static void RemoveValue(const JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap, uint32_t index,
|
|
AccossorsKind kind);
|
|
static void SetValue(const JSThread *thread, const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
int32_t index, const JSHandle<JSTaggedValue> &value, AccossorsKind kind);
|
|
static int32_t Hash(JSTaggedValue key);
|
|
static int32_t BinarySearchHashes(JSHandle<TaggedArray> &array, int32_t hash, int32_t size);
|
|
static JSHandle<TaggedArray> GetArrayByKind(const JSThread *thread,
|
|
const JSHandle<JSAPILightWeightMap> &lightWeightMap,
|
|
AccossorsKind kind);
|
|
static int32_t AvoidHashCollision(HashParams ¶ms, int32_t index, uint32_t size, int32_t hash);
|
|
};
|
|
} // namespace panda::ecmascript
|
|
|
|
#endif // ECMASCRIPT_JS_API_LIGHTWEIGHTMAP_H
|