75 lines
1.9 KiB
C
75 lines
1.9 KiB
C
|
/*============================================================================
|
||
|
CMake - Cross Platform Makefile Generator
|
||
|
Copyright 2014 Ruslan Baratov
|
||
|
|
||
|
Distributed under the OSI-approved BSD License (the "License");
|
||
|
see accompanying file Copyright.txt for details.
|
||
|
|
||
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
||
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||
|
See the License for more information.
|
||
|
============================================================================*/
|
||
|
|
||
|
#ifndef cmFileLock_h
|
||
|
#define cmFileLock_h
|
||
|
|
||
|
#include "cmStandardIncludes.h"
|
||
|
|
||
|
#if defined(_WIN32)
|
||
|
# include <windows.h> // HANDLE
|
||
|
#endif
|
||
|
|
||
|
class cmFileLockResult;
|
||
|
|
||
|
/**
|
||
|
* @brief Cross-platform file locking.
|
||
|
* @details Under the hood this class use 'fcntl' for Unix-like platforms and
|
||
|
* 'LockFileEx'/'UnlockFileEx' for Win32 platform. Locks are exclusive and
|
||
|
* advisory.
|
||
|
*/
|
||
|
class cmFileLock
|
||
|
{
|
||
|
public:
|
||
|
cmFileLock();
|
||
|
~cmFileLock();
|
||
|
|
||
|
/**
|
||
|
* @brief Lock the file.
|
||
|
* @param timeoutSec Lock timeout. If -1 try until success or fatal error.
|
||
|
*/
|
||
|
cmFileLockResult Lock(const std::string& filename, unsigned timeoutSec);
|
||
|
|
||
|
/**
|
||
|
* @brief Unlock the file.
|
||
|
*/
|
||
|
cmFileLockResult Release();
|
||
|
|
||
|
/**
|
||
|
* @brief Check file is locked by this class.
|
||
|
* @details This function helps to find double locks (deadlocks) and to do
|
||
|
* explicit unlocks.
|
||
|
*/
|
||
|
bool IsLocked(const std::string& filename) const;
|
||
|
|
||
|
private:
|
||
|
cmFileLock(const cmFileLock&);
|
||
|
cmFileLock& operator=(const cmFileLock&);
|
||
|
|
||
|
cmFileLockResult OpenFile();
|
||
|
cmFileLockResult LockWithoutTimeout();
|
||
|
cmFileLockResult LockWithTimeout(unsigned timeoutSec);
|
||
|
|
||
|
#if defined(_WIN32)
|
||
|
typedef HANDLE FileId;
|
||
|
BOOL LockFile(DWORD flags);
|
||
|
#else
|
||
|
typedef int FileId;
|
||
|
int LockFile(int cmd, int type);
|
||
|
#endif
|
||
|
|
||
|
FileId File;
|
||
|
std::string Filename;
|
||
|
};
|
||
|
|
||
|
#endif // cmFileLock_h
|