blob: 0b5f061f8d99a33718cb4fd67ee2c7656a2b2367 [file] [log] [blame]
//===-------- ExponentialGrowthAppendingBinaryByteStream.cpp --------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2018 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
#include "swift/Basic/ExponentialGrowthAppendingBinaryByteStream.h"
using namespace llvm;
using namespace swift;
Error ExponentialGrowthAppendingBinaryByteStream::readBytes(
uint32_t Offset, uint32_t Size, ArrayRef<uint8_t> &Buffer) {
if (auto Error = checkOffsetForRead(Offset, Size)) {
return Error;
}
Buffer = ArrayRef<uint8_t>(Data.data() + Offset, Size);
return Error::success();
}
Error ExponentialGrowthAppendingBinaryByteStream::readLongestContiguousChunk(
uint32_t Offset, ArrayRef<uint8_t> &Buffer) {
if (auto Error = checkOffsetForRead(Offset, 0)) {
return Error;
}
Buffer = ArrayRef<uint8_t>(Data.data() + Offset, Data.size() - Offset);
return Error::success();
}
void ExponentialGrowthAppendingBinaryByteStream::reserve(size_t Size) {
Data.reserve(Size);
}
Error ExponentialGrowthAppendingBinaryByteStream::writeBytes(
uint32_t Offset, ArrayRef<uint8_t> Buffer) {
if (Buffer.empty())
return Error::success();
if (auto Error = checkOffsetForWrite(Offset, Buffer.size())) {
return Error;
}
// Resize the internal buffer if needed.
uint32_t RequiredSize = Offset + Buffer.size();
if (RequiredSize > Data.size()) {
Data.resize(RequiredSize);
}
::memcpy(Data.data() + Offset, Buffer.data(), Buffer.size());
return Error::success();
}