1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#ifndef OHOS_HDI_CODEC_IMAGE_V2_0_HEIF_ENCODE_TEST_HELPER
17094332d3Sopenharmony_ci#define OHOS_HDI_CODEC_IMAGE_V2_0_HEIF_ENCODE_TEST_HELPER
18094332d3Sopenharmony_ci
19094332d3Sopenharmony_ci#include <list>
20094332d3Sopenharmony_ci#include <securec.h>
21094332d3Sopenharmony_ci#include <sys/mman.h>
22094332d3Sopenharmony_ci#include "hdf_log.h"
23094332d3Sopenharmony_ci#include "ashmem.h"
24094332d3Sopenharmony_ci#include "v2_0/icodec_image.h"
25094332d3Sopenharmony_ci
26094332d3Sopenharmony_ci#define IF_TRUE_RETURN_VAL(cond, val)  \
27094332d3Sopenharmony_ci    do {                               \
28094332d3Sopenharmony_ci        if (cond) {                    \
29094332d3Sopenharmony_ci            return val;                \
30094332d3Sopenharmony_ci        }                              \
31094332d3Sopenharmony_ci    } while (0)
32094332d3Sopenharmony_ci
33094332d3Sopenharmony_ciclass PropWriter {
34094332d3Sopenharmony_cipublic:
35094332d3Sopenharmony_ci    PropWriter() = default;
36094332d3Sopenharmony_ci    ~PropWriter()
37094332d3Sopenharmony_ci    {
38094332d3Sopenharmony_ci        for (auto iter = data_.begin(); iter != data_.end(); ++iter) {
39094332d3Sopenharmony_ci            delete [] iter->data;
40094332d3Sopenharmony_ci        }
41094332d3Sopenharmony_ci        data_.clear();
42094332d3Sopenharmony_ci    }
43094332d3Sopenharmony_ci    template <typename T>
44094332d3Sopenharmony_ci    bool AddData(OHOS::HDI::Codec::Image::V2_0::PropertyType key, T& value)
45094332d3Sopenharmony_ci    {
46094332d3Sopenharmony_ci        std::size_t keySize = sizeof(key);
47094332d3Sopenharmony_ci        std::size_t valueSize = sizeof(value);
48094332d3Sopenharmony_ci        std::size_t dataSize = keySize + valueSize;
49094332d3Sopenharmony_ci        uint8_t* p = new uint8_t[dataSize];
50094332d3Sopenharmony_ci        IF_TRUE_RETURN_VAL(p == nullptr, false);
51094332d3Sopenharmony_ci        data_.emplace_back(DataBlock {
52094332d3Sopenharmony_ci            .data = p,
53094332d3Sopenharmony_ci            .len = dataSize
54094332d3Sopenharmony_ci        });
55094332d3Sopenharmony_ci        totalSize_ += dataSize;
56094332d3Sopenharmony_ci        errno_t ret = memset_s(p, dataSize, 0, dataSize);
57094332d3Sopenharmony_ci        IF_TRUE_RETURN_VAL(ret != EOK, false);
58094332d3Sopenharmony_ci        ret = memcpy_s(p, dataSize, reinterpret_cast<uint8_t*>(&key), keySize);
59094332d3Sopenharmony_ci        IF_TRUE_RETURN_VAL(ret != EOK, false);
60094332d3Sopenharmony_ci        ret = memcpy_s(p + keySize, valueSize, reinterpret_cast<uint8_t*>(&value), valueSize);
61094332d3Sopenharmony_ci        IF_TRUE_RETURN_VAL(ret != EOK, false);
62094332d3Sopenharmony_ci        return true;
63094332d3Sopenharmony_ci    }
64094332d3Sopenharmony_ci    bool Finalize(std::vector<uint8_t>& dst)
65094332d3Sopenharmony_ci    {
66094332d3Sopenharmony_ci        dst.clear();
67094332d3Sopenharmony_ci        dst.resize(totalSize_);
68094332d3Sopenharmony_ci        uint8_t* dstStart = reinterpret_cast<uint8_t*>(dst.data());
69094332d3Sopenharmony_ci        size_t offset = 0;
70094332d3Sopenharmony_ci        errno_t ret = EOK;
71094332d3Sopenharmony_ci        for (auto iter = data_.begin(); (iter != data_.end()) && (ret == EOK); ++iter) {
72094332d3Sopenharmony_ci            ret = memcpy_s(dstStart + offset, iter->len, iter->data, iter->len);
73094332d3Sopenharmony_ci            offset += iter->len;
74094332d3Sopenharmony_ci        }
75094332d3Sopenharmony_ci        return (ret == EOK);
76094332d3Sopenharmony_ci    }
77094332d3Sopenharmony_ciprivate:
78094332d3Sopenharmony_ci    struct DataBlock {
79094332d3Sopenharmony_ci        uint8_t* data = nullptr;
80094332d3Sopenharmony_ci        std::size_t len = 0;
81094332d3Sopenharmony_ci    };
82094332d3Sopenharmony_ciprivate:
83094332d3Sopenharmony_ci    std::list<DataBlock> data_;
84094332d3Sopenharmony_ci    std::size_t totalSize_ = 0;
85094332d3Sopenharmony_ci};
86094332d3Sopenharmony_ci#endif // OHOS_HDI_CODEC_IMAGE_V2_0_HEIF_ENCODE_TEST_HELPER