当前位置: 首页>>代码示例>>C#>>正文


C# Logger.?.AppendHeader方法代码示例

本文整理汇总了C#中Logger.?.AppendHeader方法的典型用法代码示例。如果您正苦于以下问题:C# Logger.?.AppendHeader方法的具体用法?C# Logger.?.AppendHeader怎么用?C# Logger.?.AppendHeader使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Logger的用法示例。


在下文中一共展示了Logger.?.AppendHeader方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Compile

	private static int Compile(string[] args, Logger logger, Settings settings)
	{
		logger?.AppendHeader();

		var responseFile = args[0];
		var compilationOptions = File.ReadAllLines(responseFile.TrimStart('@'));
		var unityEditorDataDir = GetUnityEditorDataDir();
		var projectDir = Directory.GetCurrentDirectory();
		var targetAssembly = compilationOptions.First(line => line.StartsWith("-out:")).Substring(10).Trim('\'');

		logger?.Append($"CSharpCompilerWrapper.exe version: {Assembly.GetExecutingAssembly().GetName().Version}");
		logger?.Append($"Platform: {CurrentPlatform}");
		logger?.Append($"Target assembly: {targetAssembly}");
		logger?.Append($"Project directory: {projectDir}");
		logger?.Append($"Unity 'Data' or 'Frameworks' directory: {unityEditorDataDir}");

		if (CurrentPlatform == Platform.Linux)
		{
			logger?.Append("");
			logger?.Append("Platform is not supported");
			return -1;
		}

		var compiler = CreateCompiler(settings.Compiler, logger, CurrentPlatform, projectDir, compilationOptions, unityEditorDataDir);

		logger?.Append($"Compiler: {compiler.Name}");
		logger?.Append("");
		logger?.Append("- Compilation -----------------------------------------------");
		logger?.Append("");

		var stopwatch = Stopwatch.StartNew();
		var exitCode = compiler.Compile(CurrentPlatform, unityEditorDataDir, responseFile);
		stopwatch.Stop();

		logger?.Append($"Elapsed time: {stopwatch.ElapsedMilliseconds / 1000f:F2} sec");
		logger?.Append("");
		compiler.PrintCompilerOutputAndErrors();

		if (exitCode != 0 || compiler.NeedsPdb2MdbConversion == false)
		{
			return exitCode;
		}

		logger?.Append("");
		logger?.Append("- PDB to MDB conversion --------------------------------------");
		logger?.Append("");

		stopwatch.Reset();
		stopwatch.Start();

		var libraryPath = Path.Combine("Temp", targetAssembly);
		compiler.ConvertDebugSymbols(CurrentPlatform, libraryPath, unityEditorDataDir);

		stopwatch.Stop();
		logger?.Append($"Elapsed time: {stopwatch.ElapsedMilliseconds / 1000f:F2} sec");
		logger?.Append("");
		compiler.PrintPdb2MdbOutputAndErrors();

		return 0;
	}
开发者ID:cupsster,项目名称:Unity3D.IncrementalCompiler,代码行数:60,代码来源:Program.cs

示例2: Compile

	private static int Compile(string[] args, Logger logger)
	{
		logger?.AppendHeader();

		var compilationOptions = GetCompilationOptions(args);
		var unityEditorDataDir = GetUnityEditorDataDir(compilationOptions);
		var targetAssembly = compilationOptions.First(line => line.StartsWith("-out:")).Substring(10);

		logger?.Append($"smcs.exe version: {Assembly.GetExecutingAssembly().GetName().Version}");
		logger?.Append($"Target assembly: {targetAssembly}");
		logger?.Append($"Project directory: {Directory.GetCurrentDirectory()}");
		logger?.Append($"Unity directory: {unityEditorDataDir}");

		CompilerVersion compilerVersion;
		if (Directory.Exists(Path.Combine(Directory.GetCurrentDirectory(), "Roslyn")))
		{
			compilerVersion = CompilerVersion.Version6Microsoft;
		}
		else if (File.Exists("mcs.exe"))
		{
			compilerVersion = CompilerVersion.Version6Mono;
		}
		else if (compilationOptions.Any(line => line.Contains("AsyncBridge.Net35.dll")))
		{
			compilerVersion = CompilerVersion.Version5;
		}
		else
		{
			compilerVersion = CompilerVersion.Version3;
		}

		logger?.Append($"Compiler: {compilerVersion}");
		logger?.Append("");
		logger?.Append("- Compilation -----------------------------------------------");
		logger?.Append("");

		var stopwatch = Stopwatch.StartNew();
		var process = CreateCompilerProcess(compilerVersion, unityEditorDataDir, args[0]);

		logger?.Append($"Process: {process.StartInfo.FileName}");
		logger?.Append($"Arguments: {process.StartInfo.Arguments}");

		process.Start();
		process.BeginOutputReadLine();
		process.BeginErrorReadLine();
		process.WaitForExit();

		stopwatch.Stop();
		logger?.Append($"Exit code: {process.ExitCode}");
		logger?.Append($"Elapsed time: {stopwatch.ElapsedMilliseconds / 1000f:F2} sec");

		if (compilerVersion == CompilerVersion.Version6Microsoft)
		{
			// Microsoft's compiler writes all warnings and errors to the standard output channel,
			// so move them to the error channel skipping first 3 lines that are just part of the header.

			while (OutputLines.Count > 3)
			{
				var line = OutputLines[3];
				OutputLines.RemoveAt(3);
				ErrorLines.Add(line);
			}
		}

		logger?.Append("");
		logger?.Append("- Compiler output:");

		var lines = from line in OutputLines
					let trimmedLine = line?.Trim()
					where string.IsNullOrEmpty(trimmedLine) == false
					select trimmedLine;

		int lineIndex = 0;
		foreach (var line in lines)
		{
			Console.Out.WriteLine(line);
			logger?.Append($"{lineIndex++}: {line}");
		}

		logger?.Append("");
		logger?.Append("- Compiler errors:");

		lines = from line in ErrorLines
				let trimmedLine = line?.Trim()
				where string.IsNullOrEmpty(trimmedLine) == false
				select trimmedLine;

		lineIndex = 0;
		foreach (var line in lines)
		{
			Console.Error.WriteLine(line);
			logger?.Append($"{lineIndex++}: {line}");
		}

		if (process.ExitCode != 0 || compilerVersion != CompilerVersion.Version6Microsoft)
		{
			return process.ExitCode;
		}

		logger?.Append("");
//.........这里部分代码省略.........
开发者ID:iamchenxin,项目名称:CShape6_Unity3D,代码行数:101,代码来源:Program.cs


注:本文中的Logger.?.AppendHeader方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。