// 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 System.Collections.Generic;
using Microsoft.AspNetCore.Mvc.Razor.Compilation;
using Microsoft.CodeAnalysis;
using Microsoft.CodeAnalysis.CSharp;
using Microsoft.Extensions.FileProviders;
namespace Microsoft.AspNetCore.Mvc.Razor
{
///
/// Provides programmatic configuration for the .
///
public class RazorViewEngineOptions
{
private CSharpParseOptions _parseOptions = new CSharpParseOptions(LanguageVersion.CSharp6);
private CSharpCompilationOptions _compilationOptions =
new CSharpCompilationOptions(CodeAnalysis.OutputKind.DynamicallyLinkedLibrary);
private Action _compilationCallback = c => { };
///
/// Gets a used by the .
///
public IList ViewLocationExpanders { get; }
= new List();
///
/// Gets the sequence of instances used by to
/// locate Razor files.
///
///
/// At startup, this is initialized to include an instance of that is
/// rooted at the application root.
///
public IList FileProviders { get; } = new List();
///
/// Gets the locations where will search for views.
///
///
///
/// The locations of the views returned from controllers that do not belong to an area.
/// Locations are composite format strings (see http://msdn.microsoft.com/en-us/library/txafckwd.aspx),
/// which may contain the following format items:
///
///
/// -
/// {0} - Action Name
///
/// -
/// {1} - Controller Name
///
///
///
/// The values for these locations are case-sensitive on case-sensitive file systems.
/// For example, the view for the Test action of HomeController should be located at
/// /Views/Home/Test.cshtml. Locations such as /views/home/test.cshtml would not be discovered.
///
///
public IList ViewLocationFormats { get; } = new List();
///
/// Gets the locations where will search for views within an
/// area.
///
///
///
/// The locations of the views returned from controllers that belong to an area.
/// Locations are composite format strings (see http://msdn.microsoft.com/en-us/library/txafckwd.aspx),
/// which may contain the following format items:
///
///
/// -
/// {0} - Action Name
///
/// -
/// {1} - Controller Name
///
/// -
/// {2} - Area Name
///
///
///
/// The values for these locations are case-sensitive on case-sensitive file systems.
/// For example, the view for the Test action of HomeController under Admin area should
/// be located at /Areas/Admin/Views/Home/Test.cshtml.
/// Locations such as /areas/admin/views/home/test.cshtml would not be discovered.
///
///
public IList AreaViewLocationFormats { get; } = new List();
///
/// Gets the instances that should be included in Razor compilation, along with
/// those discovered by s.
///
public IList AdditionalCompilationReferences { get; } = new List();
///
/// Gets or sets the callback that is used to customize Razor compilation
/// to change compilation settings you can update property.
///
///
/// Customizations made here would not reflect in tooling (Intellisense).
///
public Action CompilationCallback
{
get { return _compilationCallback; }
set
{
if (value == null)
{
throw new ArgumentNullException(nameof(value));
}
_compilationCallback = value;
}
}
///
/// Gets or sets the options used by Razor view compilation.
///
public CSharpParseOptions ParseOptions
{
get { return _parseOptions; }
set
{
if (value == null)
{
throw new ArgumentNullException(nameof(value));
}
_parseOptions = value;
}
}
///
/// Gets or sets the used by Razor view compilation.
///
public CSharpCompilationOptions CompilationOptions
{
get { return _compilationOptions; }
set
{
if (value == null)
{
throw new ArgumentNullException(nameof(value));
}
_compilationOptions = value;
}
}
}
}