File: Handler\ServerLifetime\InitializeHandler.cs
Web Access
Project: ..\..\..\src\Features\LanguageServer\Protocol\Microsoft.CodeAnalysis.LanguageServer.Protocol.csproj (Microsoft.CodeAnalysis.LanguageServer.Protocol)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
 
using System;
using System.Composition;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.CodeAnalysis.Host.Mef;
using Microsoft.CodeAnalysis.Internal.Log;
using Microsoft.VisualStudio.LanguageServer.Protocol;
using Newtonsoft.Json;
 
namespace Microsoft.CodeAnalysis.LanguageServer.Handler;
 
[Method(Methods.InitializeName)]
internal class InitializeHandler : ILspServiceRequestHandler<InitializeParams, InitializeResult>
{
    public InitializeHandler()
    {
    }
 
    public bool MutatesSolutionState => true;
    public bool RequiresLSPSolution => false;
 
    public Task<InitializeResult> HandleRequestAsync(InitializeParams request, RequestContext context, CancellationToken cancellationToken)
    {
        var logger = context.GetRequiredLspService<ILspServiceLogger>();
        try
        {
            logger.LogStartContext("Initialize");
 
            var clientCapabilitiesManager = context.GetRequiredLspService<IClientCapabilitiesManager>();
            var clientCapabilities = clientCapabilitiesManager.TryGetClientCapabilities();
            if (clientCapabilities != null)
            {
                throw new InvalidOperationException($"{nameof(Methods.InitializeName)} called multiple times");
            }
 
            clientCapabilities = request.Capabilities;
            clientCapabilitiesManager.SetClientCapabilities(clientCapabilities);
 
            var capabilitiesProvider = context.GetRequiredLspService<ICapabilitiesProvider>();
            var serverCapabilities = capabilitiesProvider.GetCapabilities(clientCapabilities);
 
            // Record a telemetry event indicating what capabilities are being provided by the server.
            // Useful for figuring out if a particular session is opted into an LSP feature.
            Logger.Log(FunctionId.LSP_Initialize, KeyValueLogMessage.Create(m =>
            {
                m["serverKind"] = context.ServerKind.ToTelemetryString();
                m["capabilities"] = JsonConvert.SerializeObject(serverCapabilities);
            }));
 
            return Task.FromResult(new InitializeResult
            {
                Capabilities = serverCapabilities,
            });
        }
        finally
        {
            logger.LogEndContext("Initialize");
        }
    }
}