Skip to content

Zastai/MetaBrainz.Common

Repository files navigation

MetaBrainz.Common Build Status NuGet Package Version

General helper classes, for use by the other MetaBrainz.* packages.

Debugging

The HttpUtils class provides a TraceSource that can be used to configure debug output; its name is MetaBrainz.Common.HttpUtils.

Configuration

In Code

In code, you can enable tracing like follows:

// Use the default switch, turning it on.
HttpUtils.TraceSource.Switch.Level = SourceLevels.All;

// Alternatively, use your own switch so multiple things can be
// enabled/disabled at the same time.
var mySwitch = new TraceSwitch("MyAppDebugSwitch", "All");
HttpUtils.TraceSource.Switch = mySwitch;

// By default, there is a single listener that writes trace events to
// the debug output (typically only seen in an IDE's debugger). You can
// add (and remove) listeners as desired.
var listener = new ConsoleTraceListener {
  Name = "MyAppConsole",
  TraceOutputOptions = TraceOptions.DateTime | TraceOptions.ProcessId,
};
HttpUtils.TraceSource.Listeners.Clear();
HttpUtils.TraceSource.Listeners.Add(listener);

In Configuration

Your application can also be set up to read tracing configuration from the application configuration file. To do so, the following needs to be added to its startup code:

System.Diagnostics.TraceConfiguration.Register();

(Provided by the System.Configuration.ConfigurationManager package.)

The application config file can then have a system.diagnostics section where sources, switches and listeners can be configured.

<configuration>
  <system.diagnostics>
    <sharedListeners>
      <add name="console" type="System.Diagnostics.ConsoleTraceListener" traceOutputOptions="DateTime,ProcessId" />
    </sharedListeners>
    <sources>
      <source name="MetaBrainz.Common.HttpUtils" switchName="MetaBrainz.Common.HttpUtils">
        <listeners>
          <add name="console" />
          <add name="http-log" type="System.Diagnostics.TextWriterTraceListener" initializeData="http-utils.log" />
        </listeners>
      </source>
    </sources>
    <switches>
      <add name="MetaBrainz.Common.HttpUtils" value="All" />
    </switches>
  </system.diagnostics>
</configuration>

Release Notes

These are available on GitHub.

About

Classes shared between various MetaBrainz packages

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors 2

  •  
  •