Files
sourcekit-lsp/Sources/LanguageServerProtocol/Requests/HoverRequest.swift
Alex Hoppen d0fc00ce98 Format using swift-format
Add `.swift-format` to the repo and format the repo with `swift-format`.

This commit does not add any automation to enforce formatting of sourcekit-lsp in CI. The goal of this commit is to get the majority of source changes out of the way so that the diff of actually enforcing formatting will have fewer changes or conflicts.
2023-10-10 13:44:47 -07:00

124 lines
4.2 KiB
Swift

//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2019 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
/// Request for documentation information about the symbol at a given location.
///
/// This request looks up the symbol (if any) at a given text document location and returns the
/// documentation markup content for that location, suitable to show in an dialog when hovering over
/// that symbol in an editor.
///
/// Servers that provide document highlights should set the `hoverProvider` server capability.
///
/// - Parameters:
/// - textDocument: The document in which to lookup the symbol location.
/// - position: The document location at which to lookup symbol information.
///
/// - Returns: HoverResponse for the given location, which contains the `MarkupContent`.
public struct HoverRequest: TextDocumentRequest, Hashable {
public static let method: String = "textDocument/hover"
public typealias Response = HoverResponse?
/// The document in which to lookup the symbol location.
public var textDocument: TextDocumentIdentifier
/// The document location at which to lookup symbol information.
public var position: Position
public init(textDocument: TextDocumentIdentifier, position: Position) {
self.textDocument = textDocument
self.position = position
}
}
/// Documentation markup contents for a symbol found by the hover request.
public struct HoverResponse: ResponseType, Hashable {
/// The documentation markup content.
public var contents: HoverResponseContents
/// An optional range to visually distinguish during hover.
@CustomCodable<PositionRange?>
public var range: Range<Position>?
public init(contents: HoverResponseContents, range: Range<Position>?) {
self.contents = contents
self._range = CustomCodable(wrappedValue: range)
}
}
public enum HoverResponseContents: Hashable {
case markedStrings([MarkedString])
case markupContent(MarkupContent)
}
public enum MarkedString: Hashable {
private struct MarkdownCodeBlock: Codable {
let language: String
let value: String
}
case markdown(value: String)
case codeBlock(language: String, value: String)
}
extension MarkedString: Codable {
public init(from decoder: Decoder) throws {
if let value = try? decoder.singleValueContainer().decode(String.self) {
self = .markdown(value: value)
} else if let codeBlock = try? MarkdownCodeBlock(from: decoder) {
self = .codeBlock(language: codeBlock.language, value: codeBlock.value)
} else {
let context = DecodingError.Context(
codingPath: decoder.codingPath,
debugDescription: "Expected String or MarkdownCodeBlock"
)
throw DecodingError.dataCorrupted(context)
}
}
public func encode(to encoder: Encoder) throws {
switch self {
case .markdown(value: let value):
try value.encode(to: encoder)
case .codeBlock(language: let language, value: let value):
try MarkdownCodeBlock(language: language, value: value).encode(to: encoder)
}
}
}
extension HoverResponseContents: Codable {
public init(from decoder: Decoder) throws {
if let value = try? MarkupContent(from: decoder) {
self = .markupContent(value)
} else if let value = try? [MarkedString](from: decoder) {
self = .markedStrings(value)
} else if let value = try? MarkedString(from: decoder) {
self = .markedStrings([value])
} else {
let context = DecodingError.Context(
codingPath: decoder.codingPath,
debugDescription: "Expected MarkedString, [MarkedString], or MarkupContent"
)
throw DecodingError.dataCorrupted(context)
}
}
public func encode(to encoder: Encoder) throws {
switch self {
case .markedStrings(let value):
try value.encode(to: encoder)
case .markupContent(let value):
try value.encode(to: encoder)
}
}
}