src/Elastic.Apm/Libraries/Newtonsoft.Json/Serialization/ITraceWriter.cs (11 lines of code) (raw):
using System;
using System.Diagnostics;
#nullable enable
namespace Elastic.Apm.Libraries.Newtonsoft.Json.Serialization
{
/// <summary>
/// Represents a trace writer.
/// </summary>
internal interface ITraceWriter
{
/// <summary>
/// Gets the <see cref="TraceLevel" /> that will be used to filter the trace messages passed to the writer.
/// For example a filter level of <see cref="TraceLevel.Info" /> will exclude <see cref="TraceLevel.Verbose" /> messages
/// and include <see cref="TraceLevel.Info" />,
/// <see cref="TraceLevel.Warning" /> and <see cref="TraceLevel.Error" /> messages.
/// </summary>
/// <value>The <see cref="TraceLevel" /> that will be used to filter the trace messages passed to the writer.</value>
TraceLevel LevelFilter { get; }
/// <summary>
/// Writes the specified trace level, message and optional exception.
/// </summary>
/// <param name="level">The <see cref="TraceLevel" /> at which to write this trace.</param>
/// <param name="message">The trace message.</param>
/// <param name="ex">The trace exception. This parameter is optional.</param>
void Trace(TraceLevel level, string message, Exception? ex);
}
}