jellyfin/MediaBrowser.Common/Events/EventHelper.cs

65 lines
2.0 KiB
C#
Raw Normal View History

using System;
2018-12-27 23:27:57 +00:00
using System.Threading.Tasks;
using Microsoft.Extensions.Logging;
2018-12-27 23:27:57 +00:00
namespace MediaBrowser.Common.Events
{
// TODO: @bond Remove
2018-12-27 23:27:57 +00:00
/// <summary>
/// Class EventHelper
/// </summary>
public static class EventHelper
{
/// <summary>
/// Fires the event.
/// </summary>
/// <param name="handler">The handler.</param>
/// <param name="sender">The sender.</param>
/// <param name="args">The <see cref="EventArgs" /> instance containing the event data.</param>
/// <param name="logger">The logger.</param>
public static void QueueEventIfNotNull(EventHandler handler, object sender, EventArgs args, ILogger logger)
{
if (handler != null)
{
Task.Run(() =>
{
try
{
handler(sender, args);
}
catch (Exception ex)
{
2018-12-20 12:11:26 +00:00
logger.LogError(ex, "Error in event handler");
2018-12-27 23:27:57 +00:00
}
});
}
}
/// <summary>
/// Queues the event.
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="handler">The handler.</param>
/// <param name="sender">The sender.</param>
/// <param name="args">The args.</param>
/// <param name="logger">The logger.</param>
public static void QueueEventIfNotNull<T>(EventHandler<T> handler, object sender, T args, ILogger logger)
{
if (handler != null)
{
Task.Run(() =>
{
try
{
handler(sender, args);
}
catch (Exception ex)
{
2018-12-20 12:11:26 +00:00
logger.LogError(ex, "Error in event handler");
2018-12-27 23:27:57 +00:00
}
});
}
}
}
}