* 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.
*/
#include "frameworks/bridge/codec/byte_buffer_operator.h"
namespace OHOS::Ace::Framework {
bool ByteBufferReader::ReadData(std::map<std::string, std::string>& mapValue) const
{
int32_t size = -1;
if (!ReadData(size) || size < 0) {
LOGW("Could not read map size or map size is invalid");
return false;
}
mapValue.clear();
std::string key;
std::string value;
for (int32_t idx = 0; idx < size; ++idx) {
if (!ReadData(key) || !ReadData(value)) {
LOGW("Failed to read key or value");
return false;
}
mapValue.emplace(std::move(key), std::move(value));
}
return true;
}
bool ByteBufferReader::ReadData(std::set<std::string>& setValue) const
{
int32_t size = -1;
if (!ReadData(size) || size < 0) {
LOGW("Could not read map size or map size is invalid");
return false;
}
setValue.clear();
std::string value;
for (int32_t idx = 0; idx < size; ++idx) {
if (!ReadData(value)) {
LOGW("Failed to read string value");
return false;
}
setValue.emplace(std::move(value));
}
return true;
}
void ByteBufferWriter::WriteData(const std::map<std::string, std::string>& mapValue)
{
WriteData(static_cast<int32_t>(mapValue.size()));
for (const auto& [key, value] : mapValue) {
WriteData(key);
WriteData(value);
}
}
void ByteBufferWriter::WriteData(const std::set<std::string>& setValue)
{
WriteData(static_cast<int32_t>(setValue.size()));
for (const auto& value : setValue) {
WriteData(value);
}
}
}