[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
//===--- FSProvider.cpp - VFS provider for ClangdServer -------------------===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "FSProvider.h"
|
|
|
|
#include "llvm/ADT/STLExtras.h"
|
|
|
|
#include "llvm/ADT/SmallString.h"
|
|
|
|
#include "llvm/ADT/StringRef.h"
|
|
|
|
#include "llvm/Support/Path.h"
|
|
|
|
#include "llvm/Support/VirtualFileSystem.h"
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace clangd {
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
/// Always opens files in the underlying filesystem as "volatile", meaning they
|
|
|
|
/// won't be memory-mapped. This avoid locking the files on Windows.
|
|
|
|
class VolatileFileSystem : public llvm::vfs::ProxyFileSystem {
|
|
|
|
public:
|
|
|
|
explicit VolatileFileSystem(llvm::IntrusiveRefCntPtr<FileSystem> FS)
|
|
|
|
: ProxyFileSystem(std::move(FS)) {}
|
|
|
|
|
2019-01-07 23:45:19 +08:00
|
|
|
llvm::ErrorOr<std::unique_ptr<llvm::vfs::File>>
|
|
|
|
openFileForRead(const llvm::Twine &InPath) override {
|
|
|
|
llvm::SmallString<128> Path;
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
InPath.toVector(Path);
|
|
|
|
|
|
|
|
auto File = getUnderlyingFS().openFileForRead(Path);
|
|
|
|
if (!File)
|
|
|
|
return File;
|
|
|
|
// Try to guess preamble files, they can be memory-mapped even on Windows as
|
|
|
|
// clangd has exclusive access to those.
|
2019-01-07 23:45:19 +08:00
|
|
|
llvm::StringRef FileName = llvm::sys::path::filename(Path);
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
if (FileName.startswith("preamble-") && FileName.endswith(".pch"))
|
|
|
|
return File;
|
2019-01-03 21:28:05 +08:00
|
|
|
return std::unique_ptr<VolatileFile>(new VolatileFile(std::move(*File)));
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2019-01-07 23:45:19 +08:00
|
|
|
class VolatileFile : public llvm::vfs::File {
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
public:
|
2019-01-07 23:45:19 +08:00
|
|
|
VolatileFile(std::unique_ptr<llvm::vfs::File> Wrapped)
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
: Wrapped(std::move(Wrapped)) {
|
|
|
|
assert(this->Wrapped);
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>>
|
2019-01-07 23:45:19 +08:00
|
|
|
getBuffer(const llvm::Twine &Name, int64_t FileSize,
|
|
|
|
bool RequiresNullTerminator, bool /*IsVolatile*/) override {
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
return Wrapped->getBuffer(Name, FileSize, RequiresNullTerminator,
|
|
|
|
/*IsVolatile=*/true);
|
|
|
|
}
|
|
|
|
|
2019-01-07 23:45:19 +08:00
|
|
|
llvm::ErrorOr<llvm::vfs::Status> status() override {
|
|
|
|
return Wrapped->status();
|
|
|
|
}
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
llvm::ErrorOr<std::string> getName() override { return Wrapped->getName(); }
|
|
|
|
std::error_code close() override { return Wrapped->close(); }
|
|
|
|
|
|
|
|
private:
|
|
|
|
std::unique_ptr<File> Wrapped;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem>
|
|
|
|
clang::clangd::RealFileSystemProvider::getFileSystem() const {
|
|
|
|
// Avoid using memory-mapped files on Windows, they cause file locking issues.
|
|
|
|
// FIXME: Try to use a similar approach in Sema instead of relying on
|
|
|
|
// propagation of the 'isVolatile' flag through all layers.
|
|
|
|
#ifdef _WIN32
|
2019-01-15 02:59:17 +08:00
|
|
|
return new VolatileFileSystem(llvm::vfs::getRealFileSystem());
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
#else
|
2019-01-15 02:59:17 +08:00
|
|
|
return llvm::vfs::getRealFileSystem();
|
[clangd] Avoid memory-mapping files on Windows
Summary:
Memory-mapping files on Windows leads to them being locked and prevents
editors from saving changes to those files on disk. This is fine for the
compiler, but not acceptable for an interactive tool like clangd.
Therefore, we choose to avoid using memory-mapped files on Windows.
Reviewers: hokein, kadircet
Reviewed By: kadircet
Subscribers: yvvan, zturner, nik, malaperle, mgorny, ioeric, MaskRay, jkorous, arphaman, cfe-commits
Differential Revision: https://reviews.llvm.org/D55139
llvm-svn: 348147
2018-12-03 23:21:49 +08:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|