mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-02 03:39:43 -06:00
Sort include directives within each block (separated by a blank line) in
lexicographic order (except to prioritize `sys/types.h` first). First
run `clang-format` with the config file:
---
SortIncludes: false
...
Commit the result temporarily. Then run `clang-format` again with:
---
SortIncludes: true
IncludeCategories:
- Regex: 'sys/types.h'
Priority: -1
...
Commit the result temporarily. Start a new branch and cherry-pick the
second commit. Manually resolve conflicts to preserve indentation of
re-ordered includes. This cleans up the include ordering without
changing any other style.
Use the following command to run `clang-format`:
$ git ls-files -z -- \
'*.c' '*.cc' '*.cpp' '*.cxx' '*.h' '*.hh' '*.hpp' '*.hxx' |
egrep -z -v '(Lexer|Parser|ParserHelper)\.' |
egrep -z -v '^Source/cm_sha2' |
egrep -z -v '^Source/(kwsys|CursesDialog/form)/' |
egrep -z -v '^Utilities/(KW|cm).*/' |
egrep -z -v '^Tests/Module/GenerateExportHeader' |
egrep -z -v '^Tests/RunCMake/CommandLine/cmake_depends/test_UTF-16LE.h' |
xargs -0 clang-format -i
This selects source files that do not come from a third-party.
Inspired-by: Daniel Pfeifer <daniel@pfeifer-mail.de>
130 lines
2.9 KiB
C++
130 lines
2.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.
|
|
============================================================================*/
|
|
|
|
#include "cmFileLock.h"
|
|
|
|
#include "cmSystemTools.h"
|
|
#include <windows.h> // CreateFileW
|
|
|
|
cmFileLock::cmFileLock(): File(INVALID_HANDLE_VALUE)
|
|
{
|
|
}
|
|
|
|
cmFileLockResult cmFileLock::Release()
|
|
{
|
|
if (this->Filename.empty())
|
|
{
|
|
return cmFileLockResult::MakeOk();
|
|
}
|
|
const unsigned long len = static_cast<unsigned long>(-1);
|
|
static OVERLAPPED overlapped;
|
|
const DWORD reserved = 0;
|
|
const BOOL unlockResult = UnlockFileEx(
|
|
File,
|
|
reserved,
|
|
len,
|
|
len,
|
|
&overlapped
|
|
);
|
|
|
|
this->Filename = "";
|
|
|
|
CloseHandle(this->File);
|
|
this->File = INVALID_HANDLE_VALUE;
|
|
|
|
if (unlockResult)
|
|
{
|
|
return cmFileLockResult::MakeOk();
|
|
}
|
|
else
|
|
{
|
|
return cmFileLockResult::MakeSystem();
|
|
}
|
|
}
|
|
|
|
cmFileLockResult cmFileLock::OpenFile()
|
|
{
|
|
const DWORD access = GENERIC_READ | GENERIC_WRITE;
|
|
const DWORD shareMode = FILE_SHARE_READ | FILE_SHARE_WRITE;
|
|
const PSECURITY_ATTRIBUTES security = NULL;
|
|
const DWORD attr = 0;
|
|
const HANDLE templ = NULL;
|
|
this->File = CreateFileW(
|
|
cmSystemTools::ConvertToWindowsExtendedPath(this->Filename).c_str(),
|
|
access,
|
|
shareMode,
|
|
security,
|
|
OPEN_EXISTING,
|
|
attr,
|
|
templ
|
|
);
|
|
if (this->File == INVALID_HANDLE_VALUE)
|
|
{
|
|
return cmFileLockResult::MakeSystem();
|
|
}
|
|
else
|
|
{
|
|
return cmFileLockResult::MakeOk();
|
|
}
|
|
}
|
|
|
|
cmFileLockResult cmFileLock::LockWithoutTimeout()
|
|
{
|
|
if (!this->LockFile(LOCKFILE_EXCLUSIVE_LOCK))
|
|
{
|
|
return cmFileLockResult::MakeSystem();
|
|
}
|
|
else
|
|
{
|
|
return cmFileLockResult::MakeOk();
|
|
}
|
|
}
|
|
|
|
cmFileLockResult cmFileLock::LockWithTimeout(unsigned long seconds)
|
|
{
|
|
const DWORD flags = LOCKFILE_EXCLUSIVE_LOCK | LOCKFILE_FAIL_IMMEDIATELY;
|
|
while (true)
|
|
{
|
|
const BOOL result = this->LockFile(flags);
|
|
if (result)
|
|
{
|
|
return cmFileLockResult::MakeOk();
|
|
}
|
|
const DWORD error = GetLastError();
|
|
if (error != ERROR_LOCK_VIOLATION)
|
|
{
|
|
return cmFileLockResult::MakeSystem();
|
|
}
|
|
if (seconds == 0)
|
|
{
|
|
return cmFileLockResult::MakeTimeout();
|
|
}
|
|
--seconds;
|
|
cmSystemTools::Delay(1000);
|
|
}
|
|
}
|
|
|
|
BOOL cmFileLock::LockFile(DWORD flags)
|
|
{
|
|
const DWORD reserved = 0;
|
|
const unsigned long len = static_cast<unsigned long>(-1);
|
|
static OVERLAPPED overlapped;
|
|
return LockFileEx(
|
|
this->File,
|
|
flags,
|
|
reserved,
|
|
len,
|
|
len,
|
|
&overlapped
|
|
);
|
|
}
|