Radarr/NzbDrone.Host/PriorityMonitor.cs

45 lines
1.2 KiB
C#
Raw Normal View History

2013-07-19 03:47:55 +00:00
using System;
2011-10-07 06:36:04 +00:00
using System.Diagnostics;
using System.Threading;
2011-10-07 06:36:04 +00:00
using NLog;
using NzbDrone.Common;
using NzbDrone.Common.Processes;
2011-10-07 06:36:04 +00:00
namespace NzbDrone.Host
2011-10-07 06:36:04 +00:00
{
2013-03-01 00:50:50 +00:00
public class PriorityMonitor
2011-10-07 06:36:04 +00:00
{
2013-05-10 23:53:50 +00:00
private readonly IProcessProvider _processProvider;
2013-03-01 00:50:50 +00:00
private readonly Logger _logger;
2011-10-07 06:36:04 +00:00
private Timer _processPriorityCheckTimer;
2011-10-07 06:36:04 +00:00
2013-05-10 23:53:50 +00:00
public PriorityMonitor(IProcessProvider processProvider, Logger logger)
2011-10-07 06:36:04 +00:00
{
_processProvider = processProvider;
2013-03-01 00:50:50 +00:00
_logger = logger;
2011-10-07 06:36:04 +00:00
}
public void Start()
{
_processPriorityCheckTimer = new Timer(EnsurePriority);
_processPriorityCheckTimer.Change(TimeSpan.FromSeconds(15), TimeSpan.FromMinutes(30));
2011-10-07 06:36:04 +00:00
}
public virtual void EnsurePriority(object sender)
2011-10-07 06:36:04 +00:00
{
try
2011-10-07 06:36:04 +00:00
{
if (_processProvider.GetCurrentProcessPriority() != ProcessPriorityClass.Normal)
{
_processProvider.SetPriority(_processProvider.GetCurrentProcess().Id, ProcessPriorityClass.Normal);
}
}
catch (Exception e)
2011-10-07 06:36:04 +00:00
{
2013-03-01 00:50:50 +00:00
_logger.WarnException("Unable to verify priority", e);
2011-10-07 06:36:04 +00:00
}
}
}
}