am 0b2bce06: am bda375fa: am c6c6ab50: Merge "Implement C++11 move semantics for android::FileMap"

* commit '0b2bce06382b5517a4dba33da5328c751f2c7a3e':
  Implement C++11 move semantics for android::FileMap
This commit is contained in:
Adam Lesinski 2015-10-02 01:31:53 +00:00 committed by Android Git Automerger
commit 7e59e17474
2 changed files with 40 additions and 0 deletions

View File

@ -52,6 +52,9 @@ class FileMap {
public:
FileMap(void);
FileMap(FileMap&& f);
FileMap& operator=(FileMap&& f);
/*
* Create a new mapping on an open file.
*

View File

@ -53,6 +53,43 @@ FileMap::FileMap(void)
{
}
// Move Constructor.
FileMap::FileMap(FileMap&& other)
: mFileName(other.mFileName), mBasePtr(other.mBasePtr), mBaseLength(other.mBaseLength),
mDataOffset(other.mDataOffset), mDataPtr(other.mDataPtr), mDataLength(other.mDataLength)
#if defined(__MINGW32__)
, mFileHandle(other.mFileHandle), mFileMapping(other.mFileMapping)
#endif
{
other.mFileName = NULL;
other.mBasePtr = NULL;
other.mDataPtr = NULL;
#if defined(__MINGW32__)
other.mFileHandle = 0;
other.mFileMapping = 0;
#endif
}
// Move assign operator.
FileMap& FileMap::operator=(FileMap&& other) {
mFileName = other.mFileName;
mBasePtr = other.mBasePtr;
mBaseLength = other.mBaseLength;
mDataOffset = other.mDataOffset;
mDataPtr = other.mDataPtr;
mDataLength = other.mDataLength;
other.mFileName = NULL;
other.mBasePtr = NULL;
other.mDataPtr = NULL;
#if defined(__MINGW32__)
mFileHandle = other.mFileHandle;
mFileMapping = other.mFileMapping;
other.mFileHandle = 0;
other.mFileMapping = 0;
#endif
return *this;
}
// Destructor.
FileMap::~FileMap(void)
{