2023-08-21 23:44:20 +00:00
|
|
|
|
using Playnite.SDK;
|
|
|
|
|
using System;
|
2023-03-20 23:37:12 +00:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace LANCommander.PlaynitePlugin.Helpers
|
|
|
|
|
{
|
|
|
|
|
internal static class RetryHelper
|
|
|
|
|
{
|
2023-08-21 23:44:20 +00:00
|
|
|
|
internal static readonly ILogger Logger = LogManager.GetLogger();
|
|
|
|
|
|
2023-03-20 23:37:12 +00:00
|
|
|
|
internal static T RetryOnException<T>(int maxAttempts, TimeSpan delay, T @default, Func<T> action)
|
|
|
|
|
{
|
|
|
|
|
int attempts = 0;
|
|
|
|
|
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2023-08-21 23:44:20 +00:00
|
|
|
|
Logger.Trace($"Attempt #{attempts + 1}/{maxAttempts}...");
|
|
|
|
|
|
2023-03-20 23:37:12 +00:00
|
|
|
|
attempts++;
|
|
|
|
|
return action();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
2023-08-21 23:44:20 +00:00
|
|
|
|
Logger.Error(ex, $"Attempt failed!");
|
|
|
|
|
|
2023-03-20 23:37:12 +00:00
|
|
|
|
if (attempts >= maxAttempts)
|
|
|
|
|
return @default;
|
|
|
|
|
|
|
|
|
|
Task.Delay(delay).Wait();
|
|
|
|
|
}
|
|
|
|
|
} while (true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|