Skip to content
This repository has been archived by the owner on Dec 19, 2018. It is now read-only.

Commit

Permalink
#430 Move Program.Main into WebApplication.Run.
Browse files Browse the repository at this point in the history
  • Loading branch information
Tratcher committed Oct 23, 2015
1 parent 460b9bc commit b25e212
Show file tree
Hide file tree
Showing 2 changed files with 94 additions and 53 deletions.
54 changes: 1 addition & 53 deletions src/Microsoft.AspNet.Hosting/Program.cs
Original file line number Diff line number Diff line change
@@ -1,65 +1,13 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.

using System;
using Microsoft.AspNet.Http.Features;
using Microsoft.AspNet.Server.Features;
using Microsoft.Dnx.Compilation;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.DependencyInjection.Extensions;
using Microsoft.Extensions.PlatformAbstractions;

namespace Microsoft.AspNet.Hosting
{
public class Program
{
private const string HostingJsonFile = "Microsoft.AspNet.Hosting.json";
private const string ConfigFileKey = "config";

public static void Main(string[] args)
{
// Allow the location of the json file to be specified via a --config command line arg
var tempBuilder = new ConfigurationBuilder().AddCommandLine(args);
var tempConfig = tempBuilder.Build();
var configFilePath = tempConfig[ConfigFileKey] ?? HostingJsonFile;

var appBasePath = PlatformServices.Default.Application.ApplicationBasePath;
var config = new ConfigurationBuilder()
.SetBasePath(appBasePath)
.AddJsonFile(configFilePath, optional: true)
.AddEnvironmentVariables()
.AddCommandLine(args)
.Build();

var host = new WebHostBuilder(config, captureStartupErrors: true).Build();
using (var app = host.Start())
{
var hostingEnv = app.Services.GetRequiredService<IHostingEnvironment>();
Console.WriteLine("Hosting environment: " + hostingEnv.EnvironmentName);

var serverAddresses = app.ServerFeatures.Get<IServerAddressesFeature>();
if (serverAddresses != null)
{
foreach (var address in serverAddresses.Addresses)
{
Console.WriteLine("Now listening on: " + address);
}
}

Console.WriteLine("Application started. Press Ctrl+C to shut down.");

var appLifetime = app.Services.GetRequiredService<IApplicationLifetime>();

Console.CancelKeyPress += (sender, eventArgs) =>
{
appLifetime.StopApplication();
// Don't terminate the process immediately, wait for the Main thread to exit gracefully.
eventArgs.Cancel = true;
};

appLifetime.ApplicationStopping.WaitHandle.WaitOne();
}
WebApplication.Start(args);
}
}
}
93 changes: 93 additions & 0 deletions src/Microsoft.AspNet.Hosting/WebApplication.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.

using System;
using Microsoft.AspNet.Http.Features;
using Microsoft.AspNet.Server.Features;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;

namespace Microsoft.AspNet.Hosting
{
public class WebApplication
{
private const string HostingJsonFile = "Microsoft.AspNet.Hosting.json";
private const string ConfigFileKey = "config";

public static void Run(string[] args)
{
Run(startupType: null, args: args);
}

public static void Run<TStartup>()
{
Run(typeof(TStartup), null);
}

public static void Run<TStartup>(string[] args)
{
Run(typeof(TStartup), args);
}

public static void Run(Type startupType)
{
Run(startupType, null);
}

public static void Run(Type startupType, string[] args)
{
// Allow the location of the json file to be specified via a --config command line arg
var tempBuilder = new ConfigurationBuilder().AddCommandLine(args);
var tempConfig = tempBuilder.Build();
var configFilePath = tempConfig[ConfigFileKey] ?? HostingJsonFile;


#if DOTNET5_4
var appBasePath = AppContext.BaseDirectory ?? string.Empty;
#else
var appBasePath = AppDomain.CurrentDomain.GetData("APP_CONTEXT_BASE_DIRECTORY") as string ??
AppDomain.CurrentDomain.BaseDirectory ?? string.Empty;
#endif
var config = new ConfigurationBuilder()
.SetBasePath(appBasePath)
.AddJsonFile(configFilePath, optional: true)
.AddEnvironmentVariables()
.AddCommandLine(args)
.Build();

var hostBuilder = new WebHostBuilder(config, captureStartupErrors: true);
if (startupType != null)
{
hostBuilder.UseStartup(startupType);
}
var host = hostBuilder.Build();
using (var app = host.Start())
{
var hostingEnv = app.Services.GetRequiredService<IHostingEnvironment>();
Console.WriteLine("Hosting environment: " + hostingEnv.EnvironmentName);

var serverAddresses = app.ServerFeatures.Get<IServerAddressesFeature>();
if (serverAddresses != null)
{
foreach (var address in serverAddresses.Addresses)
{
Console.WriteLine("Now listening on: " + address);
}
}

Console.WriteLine("Application started. Press Ctrl+C to shut down.");

var appLifetime = app.Services.GetRequiredService<IApplicationLifetime>();

Console.CancelKeyPress += (sender, eventArgs) =>
{
appLifetime.StopApplication();
// Don't terminate the process immediately, wait for the Main thread to exit gracefully.
eventArgs.Cancel = true;
};

appLifetime.ApplicationStopping.WaitHandle.WaitOne();
}
}
}
}

0 comments on commit b25e212

Please sign in to comment.