//===- MemoryArea.h -------------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef MCLD_SUPPORT_MEMORYAREA_H_
#define MCLD_SUPPORT_MEMORYAREA_H_
#include "mcld/Support/Compiler.h"
#include <llvm/ADT/StringRef.h>
#include <llvm/Support/MemoryBuffer.h>
namespace mcld {
/** \class MemoryArea
* \brief MemoryArea is used to manage input read-only memory space.
*/
class MemoryArea {
friend class MemoryAreaFactory;
public:
// constructor by file handler.
// If the given file handler is read-only, client can not request a region
// that out of the file size.
// @param pFileHandle - file handler
explicit MemoryArea(llvm::StringRef pFilename);
explicit MemoryArea(const char* pMemBuffer, size_t pSize);
// request - create a MemoryRegion within a sufficient space
// find an existing space to hold the MemoryRegion.
// if MemoryArea does not find such space, then it creates a new space and
// assign a MemoryRegion into the space.
llvm::StringRef request(size_t pOffset, size_t pLength);
size_t size() const;
private:
std::unique_ptr<llvm::MemoryBuffer> m_pMemoryBuffer;
private:
DISALLOW_COPY_AND_ASSIGN(MemoryArea);
};
} // namespace mcld
#endif // MCLD_SUPPORT_MEMORYAREA_H_