Instantiates a Trace log for detailed tracking of an application's internal activities. : Log « Development Class « C# / C Sharp






Instantiates a Trace log for detailed tracking of an application's internal activities.

      
//-----------------------------------------------------------------------
// <copyright file="Utility.cs" company="ParanoidMike">
//     Copyright (c) ParanoidMike. All rights reserved.
// </copyright>
//-----------------------------------------------------------------------

namespace ParanoidMike
{
    using System;
    using System.Diagnostics;
    using System.IO;
    using System.Runtime.Serialization.Formatters.Binary;
    using Microsoft.Win32;

    /// <summary>
    /// Reusable functions for many uses.
    /// </summary>
    public static class Utility
    {

        /// <summary>
        /// Instantiates a Trace log for detailed tracking of an application's internal activities.
        /// </summary>
        /// <param name="appLoggingFolder">
        /// Name of folder to create in the current user's %LOCALAPPDATA% profile location.
        /// </param>
        /// <param name="traceLogFileName">
        /// Name of file to create in the appLoggingFolder location.
        /// </param>
        public static void AddTraceLog(
            string appLoggingFolder,
            string traceLogFileName)
        {
            // Setup Trace log
            TextWriterTraceListener traceLog;
            string traceLogBaseFolder;
            traceLogBaseFolder = System.Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData);

            Directory.CreateDirectory(Path.Combine(traceLogBaseFolder, appLoggingFolder));

            // concatenate the full path
            string fullPath = traceLogBaseFolder + "\\" + appLoggingFolder;

            try
            {
                Stream traceLogFile = File.Open(Path.Combine(fullPath, traceLogFileName), FileMode.Create, FileAccess.Write);

                // Create a new text writer using the output stream, and add it to the trace listeners.
                traceLog = new TextWriterTraceListener(traceLogFile);
                ((StreamWriter)(traceLog.Writer)).AutoFlush = true;
            }
            catch (Exception e)
            {
                Console.WriteLine(e.Message, Environment.NewLine);
                Console.WriteLine(e.StackTrace, Environment.NewLine);
                throw;
            }

            Trace.AutoFlush = true;
            Trace.Listeners.Clear();
            Trace.Listeners.Add(traceLog);
        }

    }
}

   
    
    
    
    
    
  








Related examples in the same category

1.Demonstrates registering and event source and writing to the Application LogDemonstrates registering and event source and writing to the Application Log
2.Add a EventLogTraceListener to the listener collection and writing error messages to the Application log
3.Test Log
4.Set Text Output To Event LogSet Text Output To Event Log
5.Log utility based on File with File.AppendAllText
6.Log message with StreamWriter
7.File Logger
8.Log error to a file
9.Logger
10.Log Utility
11.Log Exception with Event Log
12.Logger class
13.Logger 2
14.Your own Logger
15.Implements a TextWriter for writing information to the debugger log.