Radarr/src/NzbDrone.Console/ConsoleApp.cs

49 lines
1.6 KiB
C#
Raw Normal View History

2013-03-01 00:50:50 +00:00
using System;
using System.Net.Sockets;
2013-08-30 22:55:01 +00:00
using NLog;
using NzbDrone.Common.EnvironmentInfo;
2013-08-31 01:42:30 +00:00
using NzbDrone.Common.Instrumentation;
using NzbDrone.Host;
2013-03-01 00:50:50 +00:00
namespace NzbDrone.Console
{
public static class ConsoleApp
2013-03-01 00:50:50 +00:00
{
2013-08-31 01:42:30 +00:00
private static readonly Logger Logger = NzbDroneLogger.GetLogger();
2013-03-01 00:50:50 +00:00
public static void Main(string[] args)
{
try
{
2013-11-26 06:53:36 +00:00
var startupArgs = new StartupContext(args);
2013-08-31 01:42:30 +00:00
LogTargets.Register(startupArgs, false, true);
2013-11-26 06:53:36 +00:00
Bootstrap.Start(startupArgs, new ConsoleAlerts());
2013-03-01 00:50:50 +00:00
}
catch (SocketException exception)
{
System.Console.WriteLine("");
System.Console.WriteLine("");
Logger.Fatal(exception.Message + ". This can happen if another instance of NzbDrone is already running or another applicaion is using the port assinged to NzbDrone (default: 8989)");
System.Console.WriteLine("Press any key to exit...");
System.Console.ReadLine();
Environment.Exit(1);
}
catch (Exception e)
2013-03-01 00:50:50 +00:00
{
2013-11-26 05:36:06 +00:00
System.Console.WriteLine("");
System.Console.WriteLine("");
2013-09-05 01:03:41 +00:00
Logger.FatalException("EPIC FAIL!", e);
2013-11-26 05:36:06 +00:00
System.Console.WriteLine("Press any key to exit...");
2013-08-20 22:48:10 +00:00
System.Console.ReadLine();
Environment.Exit(1);
2013-03-01 00:50:50 +00:00
}
Logger.Info("Exiting main.");
//Need this to terminate on mono (thanks nlog)
LogManager.Configuration = null;
Environment.Exit(0);
2013-03-01 00:50:50 +00:00
}
}
2013-08-31 01:42:30 +00:00
}