本文整理匯總了C#中Orchard.Environment.Extensions.Models.ExtensionDescriptor類的典型用法代碼示例。如果您正苦於以下問題:C# ExtensionDescriptor類的具體用法?C# ExtensionDescriptor怎麽用?C# ExtensionDescriptor使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
ExtensionDescriptor類屬於Orchard.Environment.Extensions.Models命名空間,在下文中一共展示了ExtensionDescriptor類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Load
public ExtensionEntry Load(ExtensionDescriptor descriptor)
{
if (!ExtensionsSearchPaths.Contains(descriptor.Location))
{
return null;
}
var directory = _fileSystem.GetDirectoryInfo(descriptor.Location);
using (_loaderContainer.AddLoader(_extensionAssemblyLoader.WithPath(directory.FullName)))
{
try
{
var assembly = Assembly.Load(new AssemblyName(descriptor.Id));
if (_logger.IsEnabled(LogLevel.Information))
{
_logger.LogInformation("Loaded referenced extension \"{0}\": assembly name=\"{1}\"", descriptor.Name, assembly.FullName);
}
return new ExtensionEntry
{
Descriptor = descriptor,
Assembly = assembly,
ExportedTypes = assembly.ExportedTypes
};
}
catch (System.Exception ex)
{
_logger.LogError(string.Format("Error trying to load extension {0}", descriptor.Id), ex);
throw;
}
}
}
示例2: Load
public ExtensionEntry Load(ExtensionDescriptor descriptor)
{
if (!ExtensionsSearchPaths.Contains(descriptor.Location))
{
return null;
}
try
{
var assembly = _extensionLibraryService.LoadDynamicExtension(descriptor);
if (assembly == null)
{
return null;
}
if (_logger.IsEnabled(LogLevel.Information))
{
_logger.LogInformation("Loaded referenced dynamic extension \"{0}\": assembly name=\"{1}\"", descriptor.Name, assembly.FullName);
}
return new ExtensionEntry
{
Descriptor = descriptor,
Assembly = assembly,
ExportedTypes = assembly.ExportedTypes
};
}
catch
{
return null;
}
}
示例3: Probe
public override ExtensionProbeEntry Probe(ExtensionDescriptor descriptor) {
if (Disabled)
return null;
if (descriptor.Location == "~/Themes") {
string projectPath = _virtualPathProvider.Combine(descriptor.Location, descriptor.Id,
descriptor.Id + ".csproj");
// ignore themes including a .csproj in this loader
if ( _virtualPathProvider.FileExists(projectPath) ) {
return null;
}
var assemblyPath = _virtualPathProvider.Combine(descriptor.Location, descriptor.Id, "bin",
descriptor.Id + ".dll");
// ignore themes with /bin in this loader
if ( _virtualPathProvider.FileExists(assemblyPath) )
return null;
return new ExtensionProbeEntry {
Descriptor = descriptor,
Loader = this,
VirtualPath = "~/Theme/" + descriptor.Id,
VirtualPathDependencies = Enumerable.Empty<string>(),
};
}
return null;
}
示例4: GetThemeAsync
public async Task<ExtensionDescriptor> GetThemeAsync()
{
// For performance reason, processes the current theme only once per scope (request).
// This can't be cached as each request gets a different value.
if (_theme == null)
{
var allThemeResults = await Task.WhenAll(_themeSelectors.Select(async x => await x.GetThemeAsync().ConfigureAwait(false))).ConfigureAwait(false);
var requestTheme = allThemeResults
.Where(x => x != null)
.OrderByDescending(x => x.Priority)
.ToList();
if (requestTheme.Count == 0)
{
return null;
}
// Try to load the theme to ensure it's present
foreach (var theme in requestTheme)
{
var t = _extensionManager.GetExtension(theme.ThemeName);
if (t != null)
{
return _theme = t;
}
}
// No valid theme. Don't save the result right now.
return null;
}
return _theme;
}
示例5: ExtractLayoutNames
private IEnumerable<string> ExtractLayoutNames(ExtensionDescriptor theme)
{
var views = Directory.EnumerateFiles(HttpContext.Current.Server.MapPath(
string.Format("{0}/{1}/Views/", theme.Location, theme.Name.Replace(" ", ""))), "*.cshtml").Select(template =>
{
var f = new FileInfo(template);
if (f.Name.StartsWith("Layout-"))
{
string fname = f.Name.Replace("Layout-", "")
.Replace("-", " ")
.Replace(f.Extension, "");
if (fname.Length > 0)
return fname;
}
return null;
}).Where(n => n != null);
// Traverse base themes
if (!String.IsNullOrWhiteSpace(theme.BaseTheme))
{
var baseTheme = _extensionManager.GetExtension(theme.BaseTheme);
// Concat not Union since Distinct is enforce in service anyway
views = views.Concat(ExtractLayoutNames(baseTheme));
}
return views;
}
示例6: Load
public ExtensionEntry Load(ExtensionDescriptor descriptor)
{
if (!ExtensionsSearchPaths.Contains(descriptor.Location)) {
return null;
}
var plocation = _hostEnvironment.MapPath(descriptor.Location);
using (_loaderContainer.AddLoader(_extensionAssemblyLoader.WithPath(plocation))) {
try {
var assembly = Assembly.Load(new AssemblyName(descriptor.Id));
_logger.LogInformation("Loaded referenced extension \"{0}\": assembly name=\"{1}\"", descriptor.Name, assembly.FullName);
return new ExtensionEntry {
Descriptor = descriptor,
Assembly = assembly,
ExportedTypes = assembly.ExportedTypes
};
}
catch (System.Exception ex) {
_logger.LogError(string.Format("Error trying to load extension {0}", descriptor.Id), ex);
throw;
}
}
}
示例7: Probe
public override ExtensionProbeEntry Probe(ExtensionDescriptor descriptor) {
if (Disabled)
return null;
// Temporary - theme without own project should be under ~/themes
if (descriptor.Location.StartsWith("~/Themes",StringComparison.InvariantCultureIgnoreCase)) {
string projectPath = _virtualPathProvider.Combine(descriptor.Location, descriptor.Id,
descriptor.Id + ".csproj");
// ignore themes including a .csproj in this loader
if ( _virtualPathProvider.FileExists(projectPath) ) {
return null;
}
var assemblyPath = _virtualPathProvider.Combine(descriptor.Location, descriptor.Id, "bin",
descriptor.Id + ".dll");
// ignore themes with /bin in this loader
if ( _virtualPathProvider.FileExists(assemblyPath) )
return null;
return new ExtensionProbeEntry {
Descriptor = descriptor,
Loader = this,
VirtualPath = descriptor.VirtualPath,
VirtualPathDependencies = Enumerable.Empty<string>(),
};
}
return null;
}
示例8: Load
public ExtensionEntry Load(ExtensionDescriptor descriptor)
{
//var probingFolder = _fileSystem.GetDirectoryInfo("bin");
//if (!probingFolder.Exists)
//{
// probingFolder.Create();
//}
//var location = Path.Combine(_fileSystem.RootPath, descriptor.Location, descriptor.Id);
//Process.Start("dotnet", $"build \"{location}\" --output \"{probingFolder}\" --framework netstandard1.5").WaitForExit();
//var assembly = AssemblyLoadContext.Default.LoadFromAssemblyPath(Path.Combine(probingFolder.FullName, descriptor.Id) + ".dll");
//if (assembly == null)
//{
// return null;
//}
//return new ExtensionEntry
//{
// Descriptor = descriptor,
// Assembly = assembly,
// ExportedTypes = assembly.ExportedTypes
//};
return null;
}
示例9: Load
public ExtensionEntry Load(ExtensionDescriptor descriptor)
{
if (!descriptor.Location.StartsWith("Core"))
{
return null;
}
var directory = _fileSystem.GetDirectoryInfo("Core");
using (_loaderContainer.AddLoader(_extensionAssemblyLoader.WithPath(directory.FullName)))
{
var assembly = Assembly.Load(new AssemblyName(CoreAssemblyName));
if (_logger.IsEnabled(LogLevel.Information))
{
_logger.LogInformation("Loaded referenced extension \"{0}\": assembly name=\"{1}\"", descriptor.Name, assembly.FullName);
}
return new ExtensionEntry
{
Descriptor = descriptor,
Assembly = assembly,
ExportedTypes = assembly.ExportedTypes.Where(x => IsTypeFromModule(x, descriptor))
};
}
}
示例10: HarvestRecipesAsync
private async Task<IEnumerable<RecipeDescriptor>> HarvestRecipesAsync(ExtensionDescriptor extension)
{
var recipeLocation = _fileSystem.Combine(extension.Location, extension.Id, "Recipes");
var recipeOptions = _recipeOptions.Value;
List<RecipeDescriptor> recipeDescriptors = new List<RecipeDescriptor>();
foreach(var recipeFileExtension in recipeOptions.RecipeFileExtensions)
{
var fileMatcher = new Matcher(System.StringComparison.OrdinalIgnoreCase);
fileMatcher.AddInclude(recipeFileExtension.Key);
var recipeFiles = _fileSystem.ListFiles(recipeLocation, fileMatcher);
recipeDescriptors.AddRange(await recipeFiles.InvokeAsync(recipeFile => {
var recipeParser = _recipeParsers.First(x => x.GetType() == recipeFileExtension.Value);
using (var stream = recipeFile.CreateReadStream()) {
var recipe = recipeParser.ParseRecipe(stream);
recipe.Location = recipeFile.PhysicalPath.Replace(_fileSystem.RootPath, "").TrimStart(System.IO.Path.DirectorySeparatorChar);
return Task.FromResult(recipe);
}
}, Logger));
}
return recipeDescriptors;
}
示例11: DeepEngines
private IViewEngine DeepEngines(ExtensionDescriptor theme) {
return _configuredEnginesCache.BindDeepEngines(theme.Id, () => {
// The order for searching for views is:
// 1. Current "theme"
// 2. Base themes of the current theme (in "base" order)
// 3. Active features from modules in dependency order
var engines = Enumerable.Empty<IViewEngine>();
// 1. current theme
engines = engines.Concat(CreateThemeViewEngines(theme));
// 2. Base themes of the current theme (in "base" order)
engines = GetBaseThemes(theme).Aggregate(engines, (current, baseTheme) => current.Concat(CreateThemeViewEngines(baseTheme)));
// 3. Active features from modules in dependency order
var enabledModules = _extensionManager.EnabledFeatures(_shellDescriptor)
.Reverse() // reverse from (C <= B <= A) to (A => B => C)
.Where(fd => DefaultExtensionTypes.IsModule(fd.Extension.ExtensionType));
var allLocations = enabledModules.Concat(enabledModules)
.Select(fd => fd.Extension.Location + "/" + fd.Extension.Id)
.Distinct(StringComparer.OrdinalIgnoreCase)
.ToList();
var moduleParams = new CreateModulesViewEngineParams { VirtualPaths = allLocations };
engines = engines.Concat(_viewEngineProviders.Select(vep => vep.CreateModulesViewEngine(moduleParams)));
return new ViewEngineCollectionWrapper(engines);
});
}
示例12: BuildPackage
public Stream BuildPackage(ExtensionDescriptor extensionDescriptor) {
var context = new CreateContext();
BeginPackage(context);
try {
EstablishPaths(context, _webSiteFolder, extensionDescriptor.Location, extensionDescriptor.Id, extensionDescriptor.ExtensionType);
SetCoreProperties(context, extensionDescriptor);
string projectFile = extensionDescriptor.Id + ".csproj";
if (LoadProject(context, projectFile)) {
EmbedVirtualFile(context, projectFile, MediaTypeNames.Text.Xml);
EmbedProjectFiles(context, "Compile", "Content", "None", "EmbeddedResource");
EmbedReferenceFiles(context);
} else if (DefaultExtensionTypes.IsTheme(extensionDescriptor.ExtensionType)) {
// this is a simple theme with no csproj
EmbedThemeFiles(context);
}
}
finally {
EndPackage(context);
}
if (context.Stream.CanSeek) {
context.Stream.Seek(0, SeekOrigin.Begin);
}
return context.Stream;
}
示例13: AvailableExtensions
public IEnumerable<ExtensionDescriptor> AvailableExtensions()
{
return _extensionsByName.
Select(extensionByName =>
{
var extensionDescriptor = new ExtensionDescriptor
{
Location = string.Empty,
Id = extensionByName.Key,
ExtensionType = DefaultExtensionTypes.Module,
Path = extensionByName.Key
};
var features = extensionByName.Value.Features.Select(feature =>
new FeatureDescriptor
{
Extension = extensionDescriptor,
Id = feature
});
extensionDescriptor.Features = features;
return extensionDescriptor;
});
}
示例14: Resolve
protected override void Resolve(ILifetimeScope container) {
_compositionStrategy = container.Resolve<CompositionStrategy>();
_compositionStrategy.Logger = container.Resolve<ILogger>();
var alphaExtension = new ExtensionDescriptor {
Id = "Alpha",
Name = "Alpha",
ExtensionType = "Module"
};
var alphaFeatureDescriptor = new FeatureDescriptor {
Id = "Alpha",
Name = "Alpha",
Extension = alphaExtension
};
var betaFeatureDescriptor = new FeatureDescriptor {
Id = "Beta",
Name = "Beta",
Extension = alphaExtension,
Dependencies = new List<string> {
"Alpha"
}
};
alphaExtension.Features = new List<FeatureDescriptor> {
alphaFeatureDescriptor,
betaFeatureDescriptor
};
_availableExtensions = new[] {
alphaExtension
};
_installedFeatures = new List<Feature> {
new Feature {
Descriptor = alphaFeatureDescriptor,
ExportedTypes = new List<Type> {
typeof(AlphaDependency)
}
},
new Feature {
Descriptor = betaFeatureDescriptor,
ExportedTypes = new List<Type> {
typeof(BetaDependency)
}
}
};
_loggerMock.Setup(x => x.IsEnabled(It.IsAny<LogLevel>())).Returns(true);
_extensionManager.Setup(x => x.AvailableExtensions()).Returns(() => _availableExtensions);
_extensionManager.Setup(x => x.AvailableFeatures()).Returns(() =>
_extensionManager.Object.AvailableExtensions()
.SelectMany(ext => ext.Features)
.ToReadOnlyCollection());
_extensionManager.Setup(x => x.LoadFeatures(It.IsAny<IEnumerable<FeatureDescriptor>>())).Returns(() => _installedFeatures);
}
示例15: GetZones
public IEnumerable<string> GetZones(ExtensionDescriptor theme) {
if(theme == null) {
return Enumerable.Empty<string>();
}
IEnumerable<string> zones = new List<string>();
// get the zones for this theme
if (theme.Zones != null)
zones = theme.Zones.Split(new [] { ',' }, StringSplitOptions.RemoveEmptyEntries)
.Select(x => x.Trim())
.Distinct()
.ToList();
// if this theme has no zones defined then walk the BaseTheme chain until we hit a theme which defines zones
while (zones.Count() == 0 && theme != null && !string.IsNullOrWhiteSpace(theme.BaseTheme)) {
string baseTheme = theme.BaseTheme;
theme = _extensionManager.GetExtension(baseTheme);
if (theme != null && theme.Zones != null)
zones = theme.Zones.Split(new [] { ',' }, StringSplitOptions.RemoveEmptyEntries)
.Select(x => x.Trim())
.Distinct()
.ToList();
}
return zones;
}