| // Copyright 2017 The Android Open Source Project |
| // |
| // 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. |
| |
| #pragma once |
| |
| #include "aemu/base/containers/SmallVector.h" |
| #include "aemu/base/files/MemStream.h" |
| #include "aemu/base/files/Stream.h" |
| #include "aemu/base/TypeTraits.h" |
| |
| #include <string> |
| #include <vector> |
| |
| namespace gfxstream { |
| namespace guest { |
| |
| // |
| // Save/load operations for different types. |
| // |
| |
| void saveStream(Stream* stream, const MemStream& memStream); |
| void loadStream(Stream* stream, MemStream* memStream); |
| |
| void saveBufferRaw(Stream* stream, char* buffer, uint32_t len); |
| bool loadBufferRaw(Stream* stream, char* buffer); |
| |
| template <class T, class = enable_if<std::is_standard_layout<T>>> |
| void saveBuffer(Stream* stream, const std::vector<T>& buffer) { |
| stream->putBe32(buffer.size()); |
| stream->write(buffer.data(), sizeof(T) * buffer.size()); |
| } |
| |
| template <class T, class = enable_if<std::is_standard_layout<T>>> |
| bool loadBuffer(Stream* stream, std::vector<T>* buffer) { |
| auto len = stream->getBe32(); |
| buffer->resize(len); |
| auto ret = static_cast<std::size_t>(stream->read(buffer->data(), len * sizeof(T))); |
| return ret == len * sizeof(T); |
| } |
| |
| template <class T, class = enable_if<std::is_standard_layout<T>>> |
| void saveBuffer(Stream* stream, const SmallVector<T>& buffer) { |
| stream->putBe32(buffer.size()); |
| stream->write(buffer.data(), sizeof(T) * buffer.size()); |
| } |
| |
| template <class T, class = enable_if<std::is_standard_layout<T>>> |
| bool loadBuffer(Stream* stream, SmallVector<T>* buffer) { |
| auto len = stream->getBe32(); |
| buffer->clear(); |
| buffer->resize_noinit(len); |
| int ret = (int)stream->read(buffer->data(), len * sizeof(T)); |
| return ret == len * sizeof(T); |
| } |
| |
| template <class T, class SaveFunc> |
| void saveBuffer(Stream* stream, const std::vector<T>& buffer, SaveFunc&& saver) { |
| stream->putBe32(buffer.size()); |
| for (const auto& val : buffer) { |
| saver(stream, val); |
| } |
| } |
| |
| template <class T> |
| void saveBuffer(Stream* stream, const T* buffer, size_t numElts) { |
| stream->putBe32(numElts); |
| stream->write(buffer, sizeof(T) * numElts); |
| } |
| |
| template <class T> |
| void loadBufferPtr(Stream* stream, T* out) { |
| auto len = stream->getBe32(); |
| stream->read(out, len * sizeof(T)); |
| } |
| |
| template <class T, class LoadFunc> |
| void loadBuffer(Stream* stream, std::vector<T>* buffer, LoadFunc&& loader) { |
| auto len = stream->getBe32(); |
| buffer->clear(); |
| buffer->reserve(len); |
| for (uint32_t i = 0; i < len; i++) { |
| buffer->emplace_back(loader(stream)); |
| } |
| } |
| |
| template <class Collection, class SaveFunc> |
| void saveCollection(Stream* stream, const Collection& c, SaveFunc&& saver) { |
| stream->putBe32(c.size()); |
| for (const auto& val : c) { |
| saver(stream, val); |
| } |
| } |
| |
| template <class Collection, class LoadFunc> |
| void loadCollection(Stream* stream, Collection* c, LoadFunc&& loader) { |
| const int size = stream->getBe32(); |
| for (int i = 0; i < size; ++i) { |
| c->emplace(loader(stream)); |
| } |
| } |
| |
| void saveStringArray(Stream* stream, const char* const* strings, uint32_t count); |
| std::vector<std::string> loadStringArray(Stream* stream); |
| |
| } // namespace base |
| } // namespace android |