File: Services\KeepAlive\RemoteKeepAliveService.cs
Web Access
Project: src\src\Workspaces\Remote\ServiceHub\Microsoft.CodeAnalysis.Remote.ServiceHub.csproj (Microsoft.CodeAnalysis.Remote.ServiceHub)
// 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.Threading;
using System.Threading.Tasks;
 
namespace Microsoft.CodeAnalysis.Remote;
 
internal sealed partial class RemoteKeepAliveService : BrokeredServiceBase, IRemoteKeepAliveService
{
    internal sealed class Factory : FactoryBase<IRemoteKeepAliveService>
    {
        protected override IRemoteKeepAliveService CreateService(in ServiceConstructionArguments arguments)
            => new RemoteKeepAliveService(arguments);
    }
 
    public RemoteKeepAliveService(in ServiceConstructionArguments arguments)
        : base(arguments)
    {
    }
 
    public ValueTask KeepAliveAsync(
        Checksum solutionChecksum,
        CancellationToken cancellationToken)
    {
        // First get the solution, ensuring that it is currently pinned.
        return RunServiceAsync(solutionChecksum, async solution =>
        {
            // Wait for our caller to tell us to cancel.  That way we can release this solution and allow it
            // to be collected if not needed anymore.
            //
            // This was provided by stoub as an idiomatic way to wait indefinitely until a cancellation token triggers.
            await Task.Delay(-1, cancellationToken).ConfigureAwait(false);
        }, cancellationToken);
    }
}