1
0
mirror of https://github.com/JKorf/CryptoExchange.Net synced 2025-06-08 16:36:15 +00:00
2019-10-20 13:36:38 +02:00

57 lines
1.6 KiB
C#

using System.Collections.Generic;
using System.IO;
using System.Text;
namespace CryptoExchange.Net.Logging
{
/// <summary>
/// File writer
/// </summary>
public class ThreadSafeFileWriter: TextWriter
{
private static readonly object openedFilesLock = new object();
private static readonly List<string> openedFiles = new List<string>();
private readonly StreamWriter logWriter;
private readonly object writeLock;
/// <inheritdoc />
public override Encoding Encoding => Encoding.ASCII;
/// <summary>
/// ctor
/// </summary>
/// <param name="path"></param>
public ThreadSafeFileWriter(string path)
{
logWriter = new StreamWriter(File.Open(path, FileMode.OpenOrCreate, FileAccess.Write, FileShare.ReadWrite)) {AutoFlush = true};
writeLock = new object();
lock(openedFilesLock)
{
if (openedFiles.Contains(path))
throw new System.Exception("Can't have multiple ThreadSafeFileWriters for the same file, reuse a single instance");
openedFiles.Add(path);
}
}
/// <inheritdoc />
public override void WriteLine(string logMessage)
{
lock(writeLock)
logWriter.WriteLine(logMessage);
}
/// <summary>
/// Dispose
/// </summary>
/// <param name="disposing"></param>
protected override void Dispose(bool disposing)
{
lock (writeLock)
logWriter.Close();
}
}
}