2017-05-21 19:51:15 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "serializer.h"
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
struct Config {
|
|
|
|
// Root directory of the project. **Not serialized**
|
|
|
|
std::string projectRoot;
|
2017-11-17 22:45:49 +00:00
|
|
|
// Location of compile_commands.json.
|
2017-11-21 16:47:28 +00:00
|
|
|
std::string compilationDatabaseDirectory;
|
2017-07-16 00:25:52 +00:00
|
|
|
// Cache directory for indexed files.
|
2017-05-21 19:51:15 +00:00
|
|
|
std::string cacheDirectory;
|
2018-01-06 23:29:53 +00:00
|
|
|
// Cache serialization format
|
|
|
|
SerializeFormat cacheFormat = SerializeFormat::Json;
|
2017-10-25 01:02:15 +00:00
|
|
|
// Value to use for clang -resource-dir if not present in
|
|
|
|
// compile_commands.json.
|
|
|
|
std::string resourceDirectory;
|
2017-05-22 06:45:47 +00:00
|
|
|
|
2017-05-21 19:51:15 +00:00
|
|
|
std::vector<std::string> extraClangArguments;
|
|
|
|
|
2017-05-22 06:45:47 +00:00
|
|
|
std::vector<std::string> indexWhitelist;
|
|
|
|
std::vector<std::string> indexBlacklist;
|
|
|
|
// If true, project paths that were skipped by the whitelist/blacklist will
|
|
|
|
// be logged.
|
|
|
|
bool logSkippedPathsForIndex = false;
|
2017-09-22 01:14:57 +00:00
|
|
|
|
2017-05-21 19:51:15 +00:00
|
|
|
// Maximum workspace search results.
|
2017-12-24 06:49:45 +00:00
|
|
|
int maxWorkspaceSearchResults = 500;
|
2018-01-07 21:08:18 +00:00
|
|
|
// If true, workspace search results will be dynamically rescored/reordered
|
|
|
|
// as the search progresses. Some clients do their own ordering and assume
|
|
|
|
// that the results stay sorted in the same order as the search progresses.
|
|
|
|
bool sortWorkspaceSearchResults = true;
|
2017-05-21 19:51:15 +00:00
|
|
|
|
|
|
|
// Force a certain number of indexer threads. If less than 1 a default value
|
|
|
|
// should be used.
|
|
|
|
int indexerCount = 0;
|
|
|
|
// If false, the indexer will be disabled.
|
|
|
|
bool enableIndexing = true;
|
|
|
|
// If false, indexed files will not be written to disk.
|
|
|
|
bool enableCacheWrite = true;
|
|
|
|
// If false, the index will not be loaded from a previous run.
|
|
|
|
bool enableCacheRead = true;
|
|
|
|
|
2017-11-26 22:20:43 +00:00
|
|
|
// If true, cquery will send progress reports while indexing
|
2018-01-07 21:06:18 +00:00
|
|
|
// How often should cquery send progress report messages?
|
|
|
|
// -1: never
|
|
|
|
// 0: as often as possible
|
|
|
|
// xxx: at most every xxx milliseconds
|
|
|
|
//
|
|
|
|
// Empty progress reports (ie, idle) are delivered as often as they are
|
|
|
|
// available and may exceed this value.
|
|
|
|
//
|
|
|
|
// This does not guarantee a progress report will be delivered every
|
|
|
|
// interval; it could take significantly longer if cquery is completely idle.
|
|
|
|
int progressReportFrequencyMs = 500;
|
2017-11-26 22:20:43 +00:00
|
|
|
|
2017-05-21 19:51:15 +00:00
|
|
|
// If true, document links are reported for #include directives.
|
|
|
|
bool showDocumentLinksOnIncludes = true;
|
|
|
|
|
2017-05-21 21:01:52 +00:00
|
|
|
// Maximum path length to show in completion results. Paths longer than this
|
|
|
|
// will be elided with ".." put at the front. Set to 0 or a negative number
|
|
|
|
// to disable eliding.
|
|
|
|
int includeCompletionMaximumPathLength = 30;
|
2017-05-21 19:51:15 +00:00
|
|
|
// Whitelist that file paths will be tested against. If a file path does not
|
|
|
|
// end in one of these values, it will not be considered for auto-completion.
|
|
|
|
// An example value is { ".h", ".hpp" }
|
|
|
|
//
|
|
|
|
// This is significantly faster than using a regex.
|
|
|
|
std::vector<std::string> includeCompletionWhitelistLiteralEnding;
|
|
|
|
// Regex patterns to match include completion candidates against. They
|
|
|
|
// receive the absolute file path.
|
|
|
|
//
|
|
|
|
// For example, to hide all files in a /CACHE/ folder, use ".*/CACHE/.*"
|
|
|
|
std::vector<std::string> includeCompletionWhitelist;
|
|
|
|
std::vector<std::string> includeCompletionBlacklist;
|
|
|
|
|
2017-07-16 00:25:52 +00:00
|
|
|
// If true, diagnostics from a full document parse will be reported.
|
|
|
|
bool diagnosticsOnParse = true;
|
|
|
|
// If true, diagnostics from code completion will be reported.
|
|
|
|
bool diagnosticsOnCodeCompletion = true;
|
|
|
|
|
2017-05-21 19:51:15 +00:00
|
|
|
// Enables code lens on parameter and function variables.
|
|
|
|
bool codeLensOnLocalVariables = true;
|
|
|
|
|
2017-12-04 08:29:38 +00:00
|
|
|
// Version of the client. If undefined the version check is skipped. Used to
|
|
|
|
// inform users their vscode client is too old and needs to be updated.
|
|
|
|
optional<int> clientVersion;
|
2017-11-19 12:57:16 +00:00
|
|
|
|
2018-01-21 17:52:28 +00:00
|
|
|
struct ClientCapability {
|
|
|
|
// TextDocumentClientCapabilities.completion.completionItem.snippetSupport
|
|
|
|
bool snippetSupport = false;
|
|
|
|
};
|
|
|
|
ClientCapability client;
|
|
|
|
|
|
|
|
struct Completion {
|
|
|
|
// If true, filter and sort completion response.
|
|
|
|
bool filterAndSort = true;
|
|
|
|
};
|
|
|
|
Completion completion;
|
2018-01-19 03:25:23 +00:00
|
|
|
|
2018-01-21 06:34:41 +00:00
|
|
|
struct Index {
|
2018-01-21 17:52:28 +00:00
|
|
|
bool builtinTypes = false;
|
2018-01-21 06:34:41 +00:00
|
|
|
|
|
|
|
// 0: no; 1: Doxygen comment markers; 2: -fparse-all-comments, which includes
|
|
|
|
// plain // /*
|
2018-01-24 06:54:54 +00:00
|
|
|
int comments = 2;
|
2018-01-21 06:34:41 +00:00
|
|
|
};
|
|
|
|
Index index;
|
|
|
|
|
2018-01-08 07:51:36 +00:00
|
|
|
//// For debugging
|
|
|
|
|
|
|
|
// Dump AST after parsing if some pattern matches the source filename.
|
|
|
|
std::vector<std::string> dumpAST;
|
2017-05-21 19:51:15 +00:00
|
|
|
};
|
2018-01-21 17:52:28 +00:00
|
|
|
MAKE_REFLECT_STRUCT(Config::ClientCapability, snippetSupport);
|
|
|
|
MAKE_REFLECT_STRUCT(Config::Completion, filterAndSort);
|
|
|
|
MAKE_REFLECT_STRUCT(Config::Index, builtinTypes, comments);
|
2017-05-21 19:51:15 +00:00
|
|
|
MAKE_REFLECT_STRUCT(Config,
|
2017-11-21 16:47:28 +00:00
|
|
|
compilationDatabaseDirectory,
|
2017-09-22 01:14:57 +00:00
|
|
|
cacheDirectory,
|
2018-01-07 02:56:15 +00:00
|
|
|
cacheFormat,
|
2017-10-25 01:02:15 +00:00
|
|
|
resourceDirectory,
|
2017-05-22 06:45:47 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
extraClangArguments,
|
2017-05-21 19:51:15 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
indexWhitelist,
|
|
|
|
indexBlacklist,
|
|
|
|
logSkippedPathsForIndex,
|
2017-05-22 06:45:47 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
maxWorkspaceSearchResults,
|
2018-01-07 21:08:18 +00:00
|
|
|
sortWorkspaceSearchResults,
|
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
indexerCount,
|
|
|
|
enableIndexing,
|
|
|
|
enableCacheWrite,
|
|
|
|
enableCacheRead,
|
2018-01-07 21:06:18 +00:00
|
|
|
progressReportFrequencyMs,
|
2017-05-21 19:51:15 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
includeCompletionMaximumPathLength,
|
|
|
|
includeCompletionWhitelistLiteralEnding,
|
|
|
|
includeCompletionWhitelist,
|
|
|
|
includeCompletionBlacklist,
|
2017-05-21 19:51:15 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
showDocumentLinksOnIncludes,
|
2017-05-21 19:51:15 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
diagnosticsOnParse,
|
|
|
|
diagnosticsOnCodeCompletion,
|
2017-07-16 00:25:52 +00:00
|
|
|
|
2017-09-22 01:14:57 +00:00
|
|
|
codeLensOnLocalVariables,
|
2017-05-21 19:51:15 +00:00
|
|
|
|
2017-11-19 12:57:16 +00:00
|
|
|
clientVersion,
|
2018-01-08 07:51:36 +00:00
|
|
|
|
2018-01-21 17:52:28 +00:00
|
|
|
client,
|
|
|
|
completion,
|
2018-01-21 06:34:41 +00:00
|
|
|
index,
|
|
|
|
|
2018-01-11 02:43:01 +00:00
|
|
|
dumpAST);
|
2017-12-05 07:57:41 +00:00
|
|
|
|
|
|
|
// Expected client version. We show an error if this doesn't match.
|
2017-12-24 03:23:29 +00:00
|
|
|
constexpr const int kExpectedClientVersion = 3;
|