Files
llvm/lldb/source/Utility/DataBufferLLVM.cpp
Zachary Turner 4479ac15c9 iwyu fixes on lldbUtility.
This patch makes adjustments to header file includes in
lldbUtility based on recommendations by the iwyu tool
(include-what-you-use).  The goal here is to make sure that
all files include the exact set of headers which are needed
for that file only, to eliminate cases of dead includes (e.g.
someone deleted some code but forgot to delete the header
includes that that code necessitated), and to eliminate the
case where header includes are picked up transitively.

llvm-svn: 299676
2017-04-06 18:12:24 +00:00

71 lines
2.2 KiB
C++

//===--- DataBufferLLVM.cpp -------------------------------------*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#include "lldb/Utility/DataBufferLLVM.h"
#include "llvm/ADT/Twine.h"
#include "llvm/Support/FileSystem.h"
#include "llvm/Support/MemoryBuffer.h"
#include <assert.h> // for assert
#include <type_traits> // for move
using namespace lldb_private;
DataBufferLLVM::DataBufferLLVM(std::unique_ptr<llvm::MemoryBuffer> MemBuffer)
: Buffer(std::move(MemBuffer)) {
assert(Buffer != nullptr &&
"Cannot construct a DataBufferLLVM with a null buffer");
}
DataBufferLLVM::~DataBufferLLVM() {}
std::shared_ptr<DataBufferLLVM>
DataBufferLLVM::CreateSliceFromPath(const llvm::Twine &Path, uint64_t Size,
uint64_t Offset, bool Private) {
// If the file resides non-locally, pass the volatile flag so that we don't
// mmap it.
if (!Private)
Private = !llvm::sys::fs::is_local(Path);
auto Buffer = llvm::MemoryBuffer::getFileSlice(Path, Size, Offset, Private);
if (!Buffer)
return nullptr;
return std::shared_ptr<DataBufferLLVM>(
new DataBufferLLVM(std::move(*Buffer)));
}
std::shared_ptr<DataBufferLLVM>
DataBufferLLVM::CreateFromPath(const llvm::Twine &Path, bool NullTerminate, bool Private) {
// If the file resides non-locally, pass the volatile flag so that we don't
// mmap it.
if (!Private)
Private = !llvm::sys::fs::is_local(Path);
auto Buffer = llvm::MemoryBuffer::getFile(Path, -1, NullTerminate, Private);
if (!Buffer)
return nullptr;
return std::shared_ptr<DataBufferLLVM>(
new DataBufferLLVM(std::move(*Buffer)));
}
uint8_t *DataBufferLLVM::GetBytes() {
return const_cast<uint8_t *>(GetBuffer());
}
const uint8_t *DataBufferLLVM::GetBytes() const { return GetBuffer(); }
lldb::offset_t DataBufferLLVM::GetByteSize() const {
return Buffer->getBufferSize();
}
const uint8_t *DataBufferLLVM::GetBuffer() const {
return reinterpret_cast<const uint8_t *>(Buffer->getBufferStart());
}