Files
sourcekit-lsp/Sources/BuildSystemIntegration/BuildSystemDelegate.swift

53 lines
2.5 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
//
//===----------------------------------------------------------------------===//
import BuildServerProtocol
import LanguageServerProtocol
/// Handles build system events, such as file build settings changes.
// FIXME: (BSP migration) The build system should exclusively communicate back to SourceKit-LSP using BSP and this protocol should be deleted.
package protocol BuildSystemDelegate: AnyObject, Sendable {
/// Notify the delegate that the given files' build settings have changed.
func fileBuildSettingsChanged(_ changedFiles: Set<DocumentURI>) async
/// Notify the delegate that the dependencies of the given files have changed
/// and that ASTs may need to be refreshed. If the given set is empty, assume
/// that all watched files are affected.
///
/// The callee should refresh ASTs unless it is able to determine that a
/// refresh is not necessary.
func filesDependenciesUpdated(_ changedFiles: Set<DocumentURI>) async
/// Notify the delegate that the file handling capability of this build system
/// for some file has changed. The delegate should discard any cached file
/// handling capability.
func fileHandlingCapabilityChanged() async
}
/// Handles build system events, such as file build settings changes.
package protocol BuildSystemManagerDelegate: AnyObject, Sendable {
/// Notify the delegate that the given files' build settings have changed.
func fileBuildSettingsChanged(_ changedFiles: Set<DocumentURI>) async
/// Notify the delegate that the dependencies of the given files have changed
/// and that ASTs may need to be refreshed. If the given set is empty, assume
/// that all watched files are affected.
///
/// The callee should refresh ASTs unless it is able to determine that a
/// refresh is not necessary.
func filesDependenciesUpdated(_ changedFiles: Set<DocumentURI>) async
/// Notify the delegate that the file handling capability of this build system
/// for some file has changed. The delegate should discard any cached file
/// handling capability.
func fileHandlingCapabilityChanged() async
}