1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-16 11:37:58 +02:00
Sonarr/NzbDrone/AppMain.cs

73 lines
2.5 KiB
C#
Raw Normal View History

using System;
using System.Diagnostics;
using System.Reflection;
2013-03-01 03:50:50 +03:00
using NLog;
2013-05-24 06:23:59 +03:00
using NzbDrone.Common;
using NzbDrone.Common.Instrumentation;
namespace NzbDrone
{
public static class AppMain
{
2013-03-01 03:50:50 +03:00
private static readonly Logger logger = LogManager.GetLogger("AppMain");
public static void Main(string[] args)
{
try
{
2013-05-24 06:23:59 +03:00
new LogglyTarget(new EnvironmentProvider()).Register(LogLevel.Warn);
2013-03-01 03:50:50 +03:00
logger.Info("Starting NzbDrone Console. Version {0}", Assembly.GetExecutingAssembly().GetName().Version);
AppDomain.CurrentDomain.UnhandledException += ((s, e) => AppDomainException(e.ExceptionObject as Exception));
//Check if full version .NET is installed.
try
{
2012-01-10 01:10:44 +03:00
Assembly.Load("System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a");
}
2012-01-10 01:10:44 +03:00
catch (Exception)
{
2013-03-01 03:50:50 +03:00
logger.Error("It looks like you don't have full version of .NET Framework installed. Press any key and you will be directed to the download page.");
Console.Read();
try
{
Process.Start("http://www.microsoft.com/download/en/details.aspx?id=17851");
}
2013-03-01 03:50:50 +03:00
catch (Exception e)
{
2013-03-01 03:50:50 +03:00
logger.Warn("Oops. can't start default browser. Please visit http://www.microsoft.com/download/en/details.aspx?id=17851 to download .NET Framework 4.");
Console.ReadLine();
}
2013-03-01 03:50:50 +03:00
return;
}
2013-04-20 03:05:48 +03:00
var container = MainAppContainerBuilder.BuildContainer();
/*try
2013-05-20 03:30:02 +03:00
{
container.Resolve<IUpdateService>().Execute(new ApplicationUpdateCommand());
}
catch (Exception e)
{
logger.ErrorException("Application update failed.", e);
}
*/
2013-04-19 04:47:54 +03:00
container.Resolve<Router>().Route(args);
}
catch (Exception e)
{
2013-03-01 03:50:50 +03:00
AppDomainException(e);
}
}
2013-03-01 03:50:50 +03:00
public static void AppDomainException(Exception exception)
{
Console.WriteLine("EPIC FAIL: {0}", exception);
logger.FatalException("EPIC FAIL: " + exception.Message, exception);
}
}
}