blob: 6b50b23995a0072643fdc7acd45717e9ab6675b6 [file] [log] [blame]
//===--- DraftStore.h - File contents container -----------------*- C++ -*-===//
//
// 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
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_DRAFTSTORE_H
#define LLVM_CLANG_TOOLS_EXTRA_CLANGD_DRAFTSTORE_H
#include "Protocol.h"
#include "support/Path.h"
#include "clang/Basic/LLVM.h"
#include "llvm/ADT/StringMap.h"
#include "llvm/Support/VirtualFileSystem.h"
#include <mutex>
#include <string>
#include <vector>
namespace clang {
namespace clangd {
/// A thread-safe container for files opened in a workspace, addressed by
/// filenames. The contents are owned by the DraftStore.
/// Each time a draft is updated, it is assigned a version. This can be
/// specified by the caller or incremented from the previous version.
class DraftStore {
public:
struct Draft {
std::shared_ptr<const std::string> Contents;
std::string Version;
};
/// \return Contents of the stored document.
/// For untracked files, a llvm::None is returned.
llvm::Optional<Draft> getDraft(PathRef File) const;
/// \return List of names of the drafts in this store.
std::vector<Path> getActiveFiles() const;
/// Replace contents of the draft for \p File with \p Contents.
/// If version is empty, one will be automatically assigned.
/// Returns the version.
std::string addDraft(PathRef File, llvm::StringRef Version,
StringRef Contents);
/// Remove the draft from the store.
void removeDraft(PathRef File);
llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem> asVFS() const;
private:
struct DraftAndTime {
Draft D;
std::time_t MTime;
};
mutable std::mutex Mutex;
llvm::StringMap<DraftAndTime> Drafts;
};
} // namespace clangd
} // namespace clang
#endif