// Copyright © 2016 The CefSharp Authors. All rights reserved.
//
// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using CefSharp.Internals;
namespace CefSharp
{
///
/// Provides a callback implementation of .
///
public class TaskResolveCallback : IResolveCallback
{
private readonly TaskCompletionSource taskCompletionSource;
private volatile bool isDisposed;
private bool onComplete; //Only ever accessed on the same CEF thread, so no need for thread safety
///
/// Default constructor
///
public TaskResolveCallback()
{
taskCompletionSource = new TaskCompletionSource();
}
void IResolveCallback.OnResolveCompleted(CefErrorCode result, IList resolvedIpAddresses)
{
onComplete = true;
taskCompletionSource.TrySetResultAsync(new ResolveCallbackResult(result, resolvedIpAddresses));
}
bool IResolveCallback.IsDisposed
{
get { return isDisposed; }
}
///
/// Task used to await this callback
///
public Task Task
{
get { return taskCompletionSource.Task; }
}
void IDisposable.Dispose()
{
var task = taskCompletionSource.Task;
//If onComplete is false then IResolveCallback.OnResolveCompleted was never called,
//so we'll set the result to false. Calling TrySetResultAsync multiple times
//can result in the issue outlined in https://github.com/cefsharp/CefSharp/pull/2349
if (onComplete == false && task.IsCompleted == false)
{
taskCompletionSource.TrySetResultAsync(new ResolveCallbackResult(CefErrorCode.Unexpected, null));
}
isDisposed = true;
}
}
}