Files
qt-creator/src/libs/languageserverprotocol/initializemessages.cpp
David Schulz e3c7b72003 LanguageClient: introduce new type for gorgeous formatted errors
Change-Id: Ia76bd768bcb6d33ce66319dddf8cc355a41ffa31
Reviewed-by: Christian Stenger <christian.stenger@qt.io>
2020-02-12 11:25:01 +00:00

163 lines
5.9 KiB
C++

/****************************************************************************
**
** Copyright (C) 2018 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/
#include "initializemessages.h"
#include <QCoreApplication>
namespace LanguageServerProtocol {
constexpr const char InitializeRequest::methodName[];
constexpr const char InitializeNotification::methodName[];
constexpr Trace::Values s_trace = Trace::off;
Trace Trace::fromString(const QString &val)
{
if (val == "messages")
return messages;
if (val == "verbose")
return verbose;
return off;
}
#define RETURN_CASE(name) case Trace::name: return QString(#name);
QString Trace::toString() const
{
switch (m_value) {
RETURN_CASE(off);
RETURN_CASE(messages);
RETURN_CASE(verbose);
}
return QString("off");
}
#undef RETURN_CASE
Utils::optional<QList<MarkupKind>>
TextDocumentClientCapabilities::CompletionCapabilities::CompletionItemCapbilities::
documentationFormat() const
{
return optionalArray<MarkupKind>(documentationFormatKey);
}
void
TextDocumentClientCapabilities::CompletionCapabilities::CompletionItemCapbilities::
setDocumentationFormat(const QList<MarkupKind> &documentationFormat)
{
insertArray(documentationFormatKey, documentationFormat);
}
TextDocumentClientCapabilities::CompletionCapabilities::CompletionItemKindCapabilities::CompletionItemKindCapabilities()
{
setValueSet({CompletionItemKind::Text, CompletionItemKind::Method, CompletionItemKind::Function,
CompletionItemKind::Constructor, CompletionItemKind::Field, CompletionItemKind::Variable,
CompletionItemKind::Class, CompletionItemKind::Interface, CompletionItemKind::Module,
CompletionItemKind::Property, CompletionItemKind::Unit, CompletionItemKind::Value,
CompletionItemKind::Enum, CompletionItemKind::Keyword, CompletionItemKind::Snippet,
CompletionItemKind::Color, CompletionItemKind::File, CompletionItemKind::Reference,
CompletionItemKind::Folder, CompletionItemKind::EnumMember, CompletionItemKind::Constant,
CompletionItemKind::Struct, CompletionItemKind::Event, CompletionItemKind::Operator,
CompletionItemKind::TypeParameter});
}
Utils::optional<QList<CompletionItemKind::Kind>>
TextDocumentClientCapabilities::CompletionCapabilities::CompletionItemKindCapabilities::
valueSet() const
{
Utils::optional<QList<int>> array = optionalArray<int>(valueSetKey);
if (!array)
return Utils::nullopt;
return Utils::make_optional(Utils::transform(array.value(), [] (int value) {
return static_cast<CompletionItemKind::Kind>(value);
}));
}
void
TextDocumentClientCapabilities::CompletionCapabilities::CompletionItemKindCapabilities::
setValueSet(const QList<CompletionItemKind::Kind> &valueSet)
{
insert(valueSetKey, enumArrayToJsonArray<CompletionItemKind::Kind>(valueSet));
}
Utils::optional<QList<MarkupKind> > TextDocumentClientCapabilities::HoverCapabilities::contentFormat() const
{
return optionalArray<MarkupKind>(contentFormatKey);
}
void TextDocumentClientCapabilities::HoverCapabilities::setContentFormat(const QList<MarkupKind> &contentFormat)
{
insertArray(contentFormatKey, contentFormat);
}
Utils::optional<QList<MarkupKind>>
TextDocumentClientCapabilities::SignatureHelpCapabilities::SignatureInformationCapabilities::
documentationFormat() const
{
return optionalArray<MarkupKind>(documentationFormatKey);
}
void
TextDocumentClientCapabilities::SignatureHelpCapabilities::SignatureInformationCapabilities::
setDocumentationFormat(const QList<MarkupKind> &documentationFormat)
{
insertArray(documentationFormatKey, documentationFormat);
}
InitializeParams::InitializeParams()
{
setProcessId(int(QCoreApplication::applicationPid()));
setRootUri(LanguageClientValue<DocumentUri>());
setCapabilities(ClientCapabilities());
setTrace(s_trace);
}
Utils::optional<Trace> InitializeParams::trace() const
{
const QJsonValue &traceValue = value(traceKey);
if (traceValue.isUndefined())
return Utils::nullopt;
return Utils::make_optional(Trace(traceValue.toString()));
}
bool InitializeParams::isValid(ErrorHierarchy *error) const
{
return checkVariant<int, std::nullptr_t>(error, processIdKey)
&& checkOptional<QString, std::nullptr_t>(error, rootPathKey)
&& checkOptional<QString, std::nullptr_t>(error, rootUriKey)
&& check<ClientCapabilities>(error, capabilitiesKey)
&& checkOptional<int>(error, traceKey)
&& (checkOptional<std::nullptr_t>(error, workSpaceFoldersKey)
|| checkOptionalArray<WorkSpaceFolder>(error, workSpaceFoldersKey));
}
InitializeRequest::InitializeRequest(const InitializeParams &params)
: Request(methodName, params)
{ }
InitializeNotification::InitializeNotification()
: Notification(methodName)
{ }
} // namespace LanguageServerProtocol