-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathAsyncLazy.cs
46 lines (41 loc) · 1.66 KB
/
AsyncLazy.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
using System;
using System.Runtime.CompilerServices;
using System.Threading.Tasks;
namespace TerrariaPixelArtHelper
{
/// <summary>
/// Provides support for asynchronous lazy initialization. This type is fully threadsafe.
/// </summary>
/// <remarks>
/// Comes from http://blog.stephencleary.com/2012/08/asynchronous-lazy-initialization.html
/// </remarks>
/// <typeparam name="T">The type of object that is being asynchronously initialized.</typeparam>
internal sealed class AsyncLazy<T>
{
/// <summary>
/// The underlying lazy task.
/// </summary>
readonly Lazy<Task<T>> instance;
/// <summary>
/// Initializes a new instance of the <see cref="AsyncLazy{T}"/> class.
/// </summary>
/// <param name="factory">The delegate that is invoked on a background thread to produce the value when it is needed.</param>
public AsyncLazy(Func<T> factory) => this.instance = new Lazy<Task<T>>(() => Task.Run(factory));
/// <summary>
/// Initializes a new instance of the <see cref="AsyncLazy{T}"/> class.
/// </summary>
/// <param name="factory">The asynchronous delegate that is invoked on a background thread to produce the value when it is needed.</param>
public AsyncLazy(Func<Task<T>> factory) => this.instance = new Lazy<Task<T>>(() => Task.Run(factory));
/// <summary>
/// Asynchronous infrastructure support. This method permits instances of <see cref="AsyncLazy{T}"/> to be await'ed.
/// </summary>
public TaskAwaiter<T> GetAwaiter() => this.instance.Value.GetAwaiter();
/// <summary>
/// Starts the asynchronous initialization, if it has not already started.
/// </summary>
public void Start()
{
var unused = this.instance.Value;
}
}
}