/*
* Copyright (C) 2016 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.
*/
#ifndef BYTE_BUFFER_H_
#define BYTE_BUFFER_H_
#include <array>
#include <cstring>
#include "android-base/logging.h"
#include "wifilogd/local_utils.h"
namespace android {
namespace wifilogd {
// A fixed-size buffer, which provides the ability to accumulate bytes.
// The buffer tracks its (populated) size, and does not require dynamic
// memory allocation.
//
// Usage could be as follows:
// const auto& buffer = ByteBuffer<1024>()
// .AppendOrDie(header.data(), header.size())
// .AppendOrDie(body.data(), body.size());
// write(fd, buffer.data(), buffer.size());
template <size_t SizeBytes>
class ByteBuffer {
public:
ByteBuffer() : write_pos_(0) {}
// Appends data to the end of this buffer. Aborts if the available
// space in the buffer is less than |data_len|. Returns a reference to
// the ByteBuffer, to support chaining.
ByteBuffer<SizeBytes>& AppendOrDie(NONNULL const void* data,
size_t data_len) {
CHECK(data_len <= raw_buffer_.size() - write_pos_);
std::memcpy(raw_buffer_.data() + write_pos_, data, data_len);
write_pos_ += data_len;
return *this;
}
// Returns a pointer to the head of this buffer.
RETURNS_NONNULL const uint8_t* data() const { return raw_buffer_.data(); }
// Returns the number of bytes written to this buffer.
size_t size() const { return write_pos_; }
private:
std::array<uint8_t, SizeBytes> raw_buffer_;
size_t write_pos_;
};
} // namespace wifilogd
} // namespace android
#endif // BYTE_BUFFER_H_