本文整理汇总了C#中LoggerResult.Warning方法的典型用法代码示例。如果您正苦于以下问题:C# LoggerResult.Warning方法的具体用法?C# LoggerResult.Warning怎么用?C# LoggerResult.Warning使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LoggerResult
的用法示例。
在下文中一共展示了LoggerResult.Warning方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Save
/// <summary>
/// Saves all packages and assets.
/// </summary>
/// <param name="log">The <see cref="LoggerResult"/> in which to report result.</param>
public void Save(LoggerResult log, PackageSaveParameters saveParameters = null)
{
bool packagesSaved = false;
//var clock = Stopwatch.StartNew();
using (var profile = Profiler.Begin(PackageSessionProfilingKeys.Saving))
{
try
{
saveParameters = saveParameters ?? PackageSaveParameters.Default();
var assetsOrPackagesToRemove = BuildAssetsOrPackagesToRemove();
// Compute packages that have been renamed
// TODO: Disable for now, as not sure if we want to delete a previous package
//foreach (var package in packagesCopy)
//{
// var newPackage = packages.Find(package.Id);
// if (newPackage != null && package.PackagePath != null && newPackage.PackagePath != package.PackagePath)
// {
// assetsOrPackagesToRemove[package.PackagePath] = package;
// }
//}
// Depending on saveParameters, select the list of source file operations to do
List<SourceFileOperation> sourceFileOperations;
switch (saveParameters.SaveSourceFileOperations)
{
case PackageSaveSourceFileOperations.All:
sourceFileOperations = BuildSourceFileOperations(assetsOrPackagesToRemove);
break;
case PackageSaveSourceFileOperations.ReversibleOnly:
sourceFileOperations = BuildSourceFileOperations(assetsOrPackagesToRemove).Where(x => !x.Irreversible).ToList();
break;
case PackageSaveSourceFileOperations.None:
sourceFileOperations = new List<SourceFileOperation>();
break;
default:
throw new ArgumentOutOfRangeException();
}
// If package are not modified, return immediately
if (!CheckModifiedPackages() && assetsOrPackagesToRemove.Count == 0 && sourceFileOperations.Count == 0)
{
return;
}
// Suspend tracking when saving as we don't want to receive
// all notification events
if (dependencies != null)
{
dependencies.BeginSavingSession();
}
// Return immediately if there is any error
if (log.HasErrors)
{
return;
}
// Perform source file operations
foreach (var sourceFileOperation in sourceFileOperations)
{
switch (sourceFileOperation.Type)
{
case SourceFileOperationType.Move:
try
{
// Move target already exists: try to copy and then delete
if (File.Exists(sourceFileOperation.Destination))
{
// Use upper try/catch
File.Copy(sourceFileOperation.Source, sourceFileOperation.Destination, true);
// Try to delete source
try
{
File.Delete(sourceFileOperation.Source);
}
catch (Exception ex)
{
// File locked?
log.Warning(sourceFileOperation.AssetItem.Package, sourceFileOperation.AssetItem.ToReference(), AssetMessageCode.AssetCannotDelete, ex, sourceFileOperation.Source);
}
}
else
{
try
{
File.Move(sourceFileOperation.Source, sourceFileOperation.Destination);
}
catch (Exception ex)
{
// Could not Move, revert back to a Copy instead
// Use upper try/catch
File.Copy(sourceFileOperation.Source, sourceFileOperation.Destination, true);
log.Warning(sourceFileOperation.AssetItem.Package, sourceFileOperation.AssetItem.ToReference(), AssetMessageCode.AssetCannotDelete, ex,
//.........这里部分代码省略.........
示例2: CheckDependencies
/// <summary>
/// Checks the package.
/// </summary>
/// <returns>LoggerResult.</returns>
public LoggerResult CheckDependencies()
{
var log = new LoggerResult();
// Can only check dependencies if we are inside a session
if (package.Session == null)
{
return log;
}
// If ProjetcPath is null, the package was not saved.
if (Parameters.ConvertUPathTo == UPathType.Relative && package.FullPath == null)
{
log.Error(package, null, AssetMessageCode.PackageFilePathNotSet);
return log;
}
// 1. Check all store package references
foreach (var packageDependency in package.Meta.Dependencies)
{
// Try to find the package reference
var subPackage = package.Session.Packages.Find(packageDependency);
if (subPackage == null)
{
if (packageDependency.Name == PackageStore.Instance.DefaultPackageName)
{
log.Warning(package, null, AssetMessageCode.PackageDependencyModified, packageDependency, PackageStore.Instance.DefaultPackageMinVersion);
packageDependency.Version = PackageStore.Instance.DefaultPackageMinVersion;
package.IsDirty = true;
}
else
{
log.Error(package, null, AssetMessageCode.PackageNotFound, packageDependency);
}
}
}
// 2. Check all local package references
foreach (var packageReference in package.LocalDependencies)
{
// Try to find the package reference
var newSubPackage = package.Session.Packages.Find(packageReference.Id);
if (newSubPackage == null)
{
log.Error(package, null, AssetMessageCode.PackageNotFound, packageReference.Location);
continue;
}
if (newSubPackage.FullPath == null || newSubPackage.IsSystem)
{
continue;
}
// If package was found, check that the path is correctly setup
var pathToSubPackage = Parameters.ConvertUPathTo == UPathType.Relative ? newSubPackage.FullPath.MakeRelative(package.RootDirectory) : newSubPackage.FullPath;
if (packageReference.Location != pathToSubPackage)
{
// Modify package path to be relative if different
packageReference.Location = pathToSubPackage;
if (Parameters.SetDirtyFlagOnAssetWhenFixingUFile)
{
package.IsDirty = true;
}
}
}
// TODO: Check profiles
return log;
}