|
| 1 | +using System; |
| 2 | +using System.IO; |
| 3 | + |
| 4 | +namespace Semmle.Util.Logging |
| 5 | +{ |
| 6 | + /// <summary> |
| 7 | + /// A logger that outputs to a <code>csharp.log</code> |
| 8 | + /// file. |
| 9 | + /// </summary> |
| 10 | + public sealed class FileLogger : ILogger |
| 11 | + { |
| 12 | + private readonly StreamWriter writer; |
| 13 | + private readonly Verbosity verbosity; |
| 14 | + private readonly bool logThreadId; |
| 15 | + |
| 16 | + public FileLogger(Verbosity verbosity, string outputFile, bool logThreadId) |
| 17 | + { |
| 18 | + this.verbosity = verbosity; |
| 19 | + this.logThreadId = logThreadId; |
| 20 | + |
| 21 | + try |
| 22 | + { |
| 23 | + var dir = Path.GetDirectoryName(outputFile); |
| 24 | + if (!string.IsNullOrEmpty(dir) && !System.IO.Directory.Exists(dir)) |
| 25 | + Directory.CreateDirectory(dir); |
| 26 | + writer = new PidStreamWriter( |
| 27 | + new FileStream(outputFile, FileMode.Append, FileAccess.Write, FileShare.ReadWrite, 8192)); |
| 28 | + } |
| 29 | + catch (Exception ex) // lgtm[cs/catch-of-all-exceptions] |
| 30 | + { |
| 31 | + Console.Error.WriteLine("CodeQL: Couldn't initialise C# extractor output: " + ex.Message + "\n" + ex.StackTrace); |
| 32 | + Console.Error.Flush(); |
| 33 | + throw; |
| 34 | + } |
| 35 | + } |
| 36 | + |
| 37 | + public void Dispose() |
| 38 | + { |
| 39 | + writer.Dispose(); |
| 40 | + } |
| 41 | + |
| 42 | + private static string GetSeverityPrefix(Severity s) |
| 43 | + { |
| 44 | + return "[" + s.ToString().ToUpper() + "] "; |
| 45 | + } |
| 46 | + |
| 47 | + public void Log(Severity s, string text, int? threadId = null) |
| 48 | + { |
| 49 | + if (verbosity.Includes(s)) |
| 50 | + { |
| 51 | + threadId ??= Environment.CurrentManagedThreadId; |
| 52 | + |
| 53 | + var prefix = this.logThreadId ? $"[{threadId:D3}] " : ""; |
| 54 | + writer.WriteLine(prefix + GetSeverityPrefix(s) + text); |
| 55 | + } |
| 56 | + } |
| 57 | + } |
| 58 | +} |
0 commit comments